首页 > 其他分享 >通过 MATLAB 的 cylinder 函数生成圆柱体的表面坐标,生成表示一个具有非标准形状的圆柱体(在本例中是杯子)

通过 MATLAB 的 cylinder 函数生成圆柱体的表面坐标,生成表示一个具有非标准形状的圆柱体(在本例中是杯子)

时间:2024-08-23 18:53:49浏览次数:12  
标签:cylinder 0.125 50 本例 圆柱体 生成 fine

MATLAB的机器人系统工具箱(RST)的官方例程Plan a Reaching Trajectory with Multiple Kinematic Constraints规划具有多个运动学约束的到达轨迹
在这里插入图片描述

% 创建用于视觉化杯子的点
[X,Y,Z] = cylinder(cupRadius*linspace(0,1,50).^0.125);
% 调整 Z 坐标的比例,使其符合杯子的高度
Z = cupHeight*Z - cupHeight/2;
% 将杯子的位置平移到指定位置
X = X + cupPosition(1);
Y = Y + cupPosition(2);
Z = Z + cupPosition(3);
% 将杯子添加到图形中,并配置照明
s = patch(surf2patch(X,Y,Z));
s.FaceColor = 'blue';          % 设置杯子的颜色为蓝色
s.FaceLighting = 'gouraud';    % 设置照明效果为 Gouraud 渲染
s.EdgeAlpha = 0;               % 将边缘透明度设置为 0

% 移动光源的位置,使杯子的侧面被照亮
lightObj = findobj(gca,'Type','Light');
for i = 1:length(lightObj)
    lightObj(i).Position = [1,1,1];
end

Y-Z视图

在这里插入图片描述

[X,Y,Z] = cylinder(cupRadius*linspace(0,1,50).^0.125);

这行代码用于生成表示一个具有非标准形状的圆柱体(在本例中是杯子)的三维坐标点。具体来说,它通过 MATLAB 的 cylinder 函数生成圆柱体的表面坐标,然后对这些坐标进行一定的处理,以实现独特的形状效果。

逐步解释:
  1. linspace(0,1,50):

    • 生成从 0 到 1 之间的 50 个等间距的数值。
    • 这些数值表示圆柱体沿径向(半径方向)的分布,用于生成圆柱体的外形。
  2. linspace(0,1,50).^0.125:

    • 对生成的 50 个数值进行 0.125 次幂运算。
    • 幂次操作:幂次小于 1的幂次操作会导致数值在靠近 0 的部分变化较快,而在接近 1 的部分变化较慢,表现为更“平缓”的增长曲线
  3. cupRadius*linspace(0,1,50).^0.125:

    • 将计算出的半径值乘以 cupRadius,以生成实际的杯子半径。
    • 这一步将非线性调整的半径值缩放到实际的杯子尺寸。
  4. cylinder(cupRadius*linspace(0,1,50).^0.125):

    • cylinder 函数使用给定的半径值生成一个圆柱体的三维坐标点。
    • cylinder 函数默认生成一个高为 1,底部在 z=0,顶部在 z=1 的圆柱体,其参数是圆柱体各层的半径。通过这种方式,生成的圆柱体会有一个非线性收缩的效果,导致生成的形状在底部较窄,而在顶部逐渐变宽,更接近实际杯子的形状。
  5. [X, Y, Z]:

    • cylinder 函数输出三个矩阵 XYZ,它们分别表示圆柱体表面的 x、y 和 z 坐标。
    • 这些矩阵可以直接用于绘制圆柱体的表面,表示杯子的三维形状。

幂次操作演示

clear;clc;close all;

x = linspace(0, 1, 5); % 生成 0 到 1 之间的 5 个等间距数值

% 不同幂次操作
y1 = x .^ 1;        % 线性,不做幂次操作,[0, 0.25, 0.5, 0.75, 1]
y2 = x .^ 0.5;      % 平方根,进行 0.5 次幂的操作,[0, 0.5, 0.7071, 0.866, 1]
y3 = x .^ 0.125;    % 进行 0.125 次幂的操作%,[0, 0.861, 0.9306, 0.9715, 1]

% 绘制第一组曲线
plot(x, y1, '-o', 'DisplayName', 'x^1'); hold on;
plot(x, y2, '-o', 'DisplayName', 'x^0.5');
plot(x, y3, '-o', 'DisplayName', 'x^0.125');
legend show;
xlabel('Original values');
ylabel('Transformed values');
title('Effect of Different Power Operations');

% 生成 0 到 1 之间的 50 个等间距数值
x_fine = linspace(0, 1, 50);

% 对新的数值集进行相同的幂次操作
y1_fine = x_fine .^ 1;
y2_fine = x_fine .^ 0.5;
y3_fine = x_fine .^ 0.125;

% 绘制第二组曲线
plot(x_fine, y1_fine, '*', 'DisplayName', 'x^1 (50 points)'); hold on;
plot(x_fine, y2_fine, '*', 'DisplayName', 'x^0.5 (50 points)');
plot(x_fine, y3_fine, '*', 'DisplayName', 'x^0.125 (50 points)');
legend show;

在这里插入图片描述

1. cylinder 函数的基本用法

[X, Y, Z] = cylinder(r, n)

  • r 是一个向量,定义了圆柱体的半径分布。如果 r 是一个标量,则生成的圆柱体的横截面是一个固定半径的圆。否则,r 的每个元素定义了从底部到顶部的不同半径。
  • n 是圆柱体的侧面点数,表示圆周上生成的点的数量。默认值为 20。

cylinder 函数生成的 XYZ 是网格化的数据,这些数据表示圆柱体的表面。XY 是圆柱体表面的横截面点的 xy 坐标,Z 是圆柱体的高度分布。

2. 解释 X 的大小

[X, Y, Z] = cylinder(cupRadius*linspace(0,1,50).^0.125);
  • cupRadius*linspace(0,1,50).^0.125:这个表达式生成了一个长度为 50 的向量 r,表示圆柱体从底部到顶部的半径变化。

    • linspace(0,1,50) 创建了一个从 0 到 1 之间均匀分布的 50 个点。
    • 然后,这些点被提升到 0.125 次幂,以实现非线性的半径分布。
    • 之后,乘以 cupRadius 以获得实际的半径大小。
  • cylinder(r):此时,r 是一个长度为 50 的向量,因此 cylinder 函数会生成一个圆柱体,其横截面在 Z 方向上变化,形成了 50 个横截面(代表圆柱体从底部到顶部的 50 个切片)。

  • 默认的 n 值为 20cylinder 函数默认在圆周上生成 21 个点(包括 0 度和 360 度位置,重复了一次,以便闭合圆周)。

3. X 的大小分析

  • 50 行:代表了圆柱体沿 Z 轴方向上的 50 个切片。
  • 21 列:代表了圆柱体每个横截面上生成的 21 个点。

因此,X 的大小为 50x21,这意味着有 50 个高度切片,每个切片上有 21 个点,构成圆柱体表面的坐标点。

总结

  • 行数 50:指定的 r 向量的长度(50 个切片)。
  • 列数 21cylinder 默认在圆周上生成 21 个点,以形成完整的圆柱体表面。

标签:cylinder,0.125,50,本例,圆柱体,生成,fine
From: https://blog.csdn.net/qq_45762996/article/details/141394881

相关文章

  • 【生日视频制作】教师节中秋节国庆节直升飞机AE模板修改文字软件生成器教程特效素材【
    飞机生日视频制作教程AE模板改文字特效广软件告生成器玩法素材怎么如何做的【生日视频制作】教师节中秋节国庆节直升飞机AE模板修改文字软件生成器教程特效素材【AE模板】生日视频制作步骤:安装AE软件下载AE模板把AE模板导入AE软件修改图片或文字渲染出视频......
  • 26:迭代器和生成器
    x='hello'print(dir(x))iter_test=x.__iter__()print(iter_test)print(iter_test.__next__())print(iter_test.__next__())print(iter_test.__next__())print(iter_test.__next__())print(iter_test.__next__())print(iter_test.__next__())l=......
  • 笔灵AI写作工具,一键生成文章,让你的写作速度翻倍提升
    最近AI写作火的一塌糊涂,不仅各路自媒体大神都在用,而且连Science都官宣了允许AI写作,真真是古希腊掌管写作的神。AI时代,不是被工具取代,而是被“会用AI的人”取代。想要尝试用AI写作,又不知道如何找到靠谱工具的朋友可以看这个丝滑的AI写作工具,无需魔法,打开就能直接用,用完保你工......
  • 写作时间紧迫,如何快速完成高质量文章? 笔灵AI高效生成,让教师在短时间内完成高质量写作
    时至今日,暑假已悄然步入后半段,我的教师朋友们频频提及即将重启的备课与教案编写工作,直言其带来的压力与挑战不容小觑。每当我们交流至此,我总免不了提及利用AI工具来优化备课流程的建议。现今,AI技术的迅猛发展已使其能够胜任众多以往由教师手动完成的备课任务,实现了工作效率的......
  • 一文弄懂 LLM 结构化数据生成原理
    前言目前LLM(LargeLanguageModel)从文本补全到内容创作,都展示出了强大的生成能力。然而通过LLM生成结构化的数据如JSON格式的输出,却仍然是一个有挑战性的任务。生成结构化的数据不仅要求模型输出符合特定的语法规则,还需要确保数据的正确性和一致性。虽然通过prompt......
  • Simulink自动生成Park变换模块的C代码过程
    Simulink自动生成Park变换模块的C代码过程第一步:在matlab当前文件夹下,建立simulink模型文件。如下图所示。 第二步:搭建park函数模块。在Simscape工具箱中的transformers子工具箱下找到相应的模块,添加输入输出端口。 第三步:代码生成环境配置。(1)点击modelconfigur......
  • Python3测试mysql插入数据代码(chatgpt生成)
      实现的功能:先连接mysql数据库,然后读取某个目录所有以txt文件命名后缀的json内容文件,解析出对应的key和value,然后插入数据到mysql数据库,最后关闭数据库连接 importosimportjsonimportpymysqlimportre"""尝试插入json文件到MySQL数据库。dbInfo:MySQL数据库......
  • 利用源生成器,在编译阶段生成映射代码,减少运行时反射
    利用源生成器,在编译阶段生成映射代码,减少运行时反射这里有一个Product类和ProductDto类,实现对象自身的拷贝,或者Product映射ProductDtoGenMapperAttribute标注了类型需要生成映射方法,同时要求实现IAutoMap接口(由生成器自动实现)构造函数可选参数为目标类型,默认是自身MaoToAttr......
  • 生成魔咒
    先考虑没有修改操作,如何求不同的子串数量,这是后缀数组的经典应用。所有子串就是所有后缀的所有前缀。先将所有后缀按照字典序排序,然后求出\(height\)数组,从\(1\)循环到\(n\),对于排名为\(i\)的后缀来说,新增的后缀个数就是\(\text{len}[i]-height[i]\)(前者表示排名为\(i\)的后缀的长......
  • 一些关于生成函数的推导
    该文只推导一些特殊序列的生成函数1.$\quad$对于序列{\(a_n\)},\(a_n=1^n\),其生成函数为\(g(x)=\sum_{n=0}^{\infty}{a_nx^n}\)。$\quad$现在推导其封闭形式,先将其乘一个\(x\),可以得到:\[x\cdotg(x)=\sum_{n=0}^{\infty}{a_nx^{n+1}}\]$\quad$两式相减可得......