- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[计算机软件及应用]MATLAB与系统仿真9
MATLAB与系统仿真
机电工程学院 勾燕洁
二〇一二年秋
5.4 三维图形
5.4.1 三维曲线
三维图形绘制的基本函数是plot3
plot3函数与plot函数用法十分相似,其调用格式为:
plot3(x1,y1,z1,选项1,x2,y2,z2,选项2,…,xn,yn,zn,选项n)
其中每一组x,y,z组成一组曲线的坐标参数,选项的定
义和plot函数相同。当x,y,z是同维向量时,则x,y,z 对应元
素构成一条三维曲线。当x,y,z是同维矩阵时,则以x,y,z对
应列元素绘制三维曲线,曲线条数等于矩阵列数。
例 绘制三维曲线。
t=0:pi/100:20*pi;
x=sin(t);
y=cos(t);
z=t.*sin(t).*cos(t);
plot3(x,y,z);
title(Line in 3-D Space);
xlabel(X);ylabel(Y);zlabel(Z);
grid on;
5.4.2 三维曲面
产生三维数据
在MATLAB中,利用meshgrid函数产生平面区域
内的网格坐标矩阵。其格式为:
x=a:d1:b;
y=c:d2:d;
[X,Y]=meshgrid(x,y);
语句执行后,矩阵X的每一行都是向量x,行数等于
向量y的元素的个数,矩阵Y的每一列都是向量y,列数
等于向量x的元素的个数。
绘制三维曲面的函数
surf函数和mesh函数的调用格式为:
mesh(x,y,z,c)
surf(x,y,z,c)
一般情况下,x,y,z是维数相同的矩阵。x,y是网格坐
标矩阵,z是网格点上的高度矩阵,c用于指定在不同高度
下的颜色范围。
例 绘制三维曲面图z=sin(x+sin(y))-x/10。
[x,y]=meshgrid(0:0.25:4*pi);
z=sin(x+sin(y))-x/10;
mesh(x,y,z);
surf(x,y,z);
axis([0 4*pi 0 4*pi -2.5 1]);
此外,还有带等高线的三维网格曲面函数meshc和带
底座的三维网格曲面函数meshz。其用法与mesh类似,不
同的是meshc还在xy平面上绘制曲面在z轴方向的等高线,
meshz还在xy平面上绘制曲面的底座。
例 在xy平面内选择区域[-8,8] ×[-8,8],绘制4种三维曲面图。
[x,y]=meshgrid(-8:0.5:8);
z=sin(sqrt(x.^2+y.^2))./sqrt(x.^2+y.^2+eps);
subplot(2,2,1);mesh(x,y,z);
title(mesh);
subplot(2,2,2);meshc(x,y,z);
title(meshc);
subplot(2,2,3);meshz(x,y,z);
title(meshz);
subplot(2,2,4);surf(x,y,z);
title(surf);
标准三维曲面
sphere函数的调用格式为:
[x,y,z]=sphere(n)
cylinder函数的调用格式为:
[x,y,z]= cylinder(R,n)
MATLAB还有一个peaks 函数,称为多峰函数,常用
于三维曲面的演示。
例 绘制标准三维曲面图形。
t=0:pi/20:2*pi;
[x,y,z]= cylinder(2+sin(t),30);
subplot(2,2,1);
surf(x,y,z);
subplot(2,2,2);
[x,y,z]=sphere;
surf(x,y,z);
subplot(2,1,2);
[x,y,z]=peaks(30);
文档评论(0)