matlab 三维图形绘制实例
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
三维图形
一. 三维曲线
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 对应列元素绘制三维曲线,曲线条数等于矩阵列数。 Example1.绘制三维曲线。 程序如下: clf,
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;
所的图形如下:
X
Line in 3-D Space
Y
Z
二. 三维曲面 1. 产生三维数据
在MATLAB 中,利用meshgrid 函数产生平面区域内的网格坐标矩阵。
语句执行后,矩阵X 的每一行都是向量x ,行数等于向量y 的元素的个数,矩阵Y 的每一列都是向量y ,列数等于向量x 的元素的个数。 2. 绘制三维曲面的函数
surf 函数和mesh 函数
example2. 绘制三维曲面图z=sin(x+sin(y))-x/10。 程序如下: clf,
[x,y]=meshgrid(0:0.25:4*pi); %产生平面坐标区域内的网格坐标矩阵 z=sin(x+sin(y))-x./10; surf(x,y,z);
axis([0 4*pi 0 4*pi -2.5 1]); title('surf 函数所产生的曲面'); figure;
mesh(x,y,z);
axis([0 4*pi 0 4*pi -2.5 1]);
title('mesh 函数所产生的曲面');
-2.5
-2-1.5-1-0.500.51surf 函数所产生的曲面
-2.5
-2-1.5-1-0.500.51mesh 函数所产生的曲面
Example3.绘制4种三维曲面图。 clf,
[x,y]=meshgrid(-10:0.8:10);
z=sin(sqrt(x.^2+y.^2))./sqrt(x.^2+y.^2); subplot(2,2,1); mesh(x,y,z);
title('mesh(x,y,z)') subplot(2,2,2); meshc(x,y,z);
title('meshc(x,y,z)') subplot(2,2,3); meshz(x,y,z)
title('meshz(x,y,z)') subplot(2,2,4); surf(x,y,z);
title('surf(x,y,z)')
图像如下:
10
mesh(x,y,z)
10
-101meshc(x,y,z)
10
meshz(x,y,z)
10
-101surf(x,y,z)
3. 标准三维曲面
sphere 函数的调用格式为: [x,y,z]=sphere(n)
cylinder 函数的调用格式为: [x,y,z]= cylinder(R,n)
MATLAB 还有一个peaks 函数,称为多峰函数,常用于三维曲面的演示。 Example4 绘制标准三维曲面图形。 clear all ; t=0:pi/20:2*pi;
[x,y,z]= cylinder(2+sin(t),30); subplot(2,2,1); surf(x,y,z);
title('[x,y,z]= cylinder(2+sin(t),30)') subplot(2,2,2);
[x,y,z]=sphere;%20X20 surf(x,y,z);
title('[x,y,z]=sphere') subplot(2,1,2);
[x,y,z]=peaks(30); %30X30 surf(x,y,z);
title('[x,y,z]=peaks(30)') 图像如下:
5
[x,y,z]= cylinder(2+sin(t),30)1
-10
1[x,y,z]=sphere
[x,y,z]=peaks(30)