0


Matlab绘图(第五节-三维曲面)

具体讲述了三维曲面绘图方法等。

平面网格数据的生成

此时所有点坐标可以表示为:

x=[2 2 2 2 2 2;3 3 3 3 3 3;4 4 4 4 4 4;5 5 5 5 5 5;6 6 6 6 6 6]

y=[3 4 5 6 7 8;3 4 5 6 7 8;3 4 5 6 7 8;3 4 5 6 7 8;3 4 5 6 7 8]

矩阵x,y就是该平面内的网格坐标矩阵。

(1)利用矩阵运算生成

  1. x=2:6;
  2. y=(3:m,8)';
  3. X=ones(size(y))*x;
  4. Y=ones(size(x))*y;%所生成的网格坐标矩阵与上述一致。

(2)利用meshgrid函数生成

[X,Y]=meshgrid(x,y);

其中,参数x,y为向量,存储网格点坐标的X,Y为矩阵。

  1. x=2:6;
  2. y=(3:8)';
  3. [X,Y]=meshgrid(x,y);

当x与y相同时直接简化为[X,Y]=meshgrid(x)

例1:绘制空间曲线。

  1. x=2:6;
  2. y=(3:8)';
  3. [X,Y]=meshgrid(x,y);
  4. Z=randn(size(X));
  5. plot3(X,Y,Z);
  6. grid on;

绘制三维曲面图的函数

mesh(x,y,z,c)

surf(x,y,z,c)

其中,x,y是网格坐标矩阵,z是网格点上的高度矩阵,c用于指定在不同高度下的曲面颜色。c省略时,默认c等于z。

例2:绘制三维曲面图

  1. t=-2:0.2:2;
  2. [X,Y]=meshgrid(t);
  3. Z=X.*exp(-X.^2-Y.^2);
  4. subplot(1,3,1)
  5. mesh(X,Y,Z);
  6. subplot(1,3,2)
  7. surf(X,Y,Z);
  8. subplot(1,3,3)
  9. plot3(X,Y,Z);
  10. grid on

拓展:带等高线的三维网格曲面函数meshc

带底座的三维网格曲面函数meshz

具有等高线的曲面函数surfc

具有光照效果的曲面函数surfl

例3:用四种方式绘制函数的曲面图,其中x的范围为02,y的范围为13。

  1. [x,y]=meshgrid(0:0.1:2,1:0.1:3);
  2. z=(x-1).^2+(y-2).^2-1;
  3. subplot(2,2,1);
  4. meshc(x,y,z)
  5. subplot(2,2,2);
  6. meshz(x,y,z)
  7. subplot(2,2,3);
  8. surfc(x,y,z)
  9. subplot(2,2,4);
  10. surfl(x,y,z)

标准三维曲面

(1)sphere函数

[x,y,z]=sphere(n)

n代表球面的圆滑程度(默认为20),若不带输出参数,则直接绘制球面。

(2)cylinder函数

[x,y,z]=cylinder(R,n)

R代表柱面半径,n表示有多少间隔点(默认为20个)

例4:用cylinder函数分别绘制柱面,花瓶面和圆锥面

  1. subplot (1,3,1);
  2. [x,y,z]=cylinder;
  3. surf(x,y,z);
  4. subplot(1,3,2);
  5. t=linspace(0,2*pi,40);
  6. [x,y,z]=cylinder(2+cos(t),30);
  7. surf(x,y,z);
  8. subplot(1,3,3);
  9. [x,y,z]=cylinder(0:0.2:2,30);
  10. surf(x,y,z);

例5:用cylinder函数绘制两个相互垂直且直径相等的圆柱面的相交图形。

  1. clear;clc
  2. [x,y,z]=cylinder(1,60)
  3. z=[-1*z(2,:);z(2,:)]
  4. surf(x,y,z)
  5. hold on
  6. surf(y,z,x)
  7. axis equal

fsurf函数和fmesh函数

fsurf(funx, funy, funz, uvlims)

fmesh(funx, funy, funz, uvlims)

其中,funx、funy、funz代表定义曲面x、y、z坐标的函数,通常采用函数句柄的形式。uvlims为funx、funy和funz的自变量的取值范围,用4元向量[umin,umax, vmin,vmax]描述。默认为[-5,5,-5,5]。

例5:绘制螺旋曲面

  1. clear;clc
  2. subplot(1,2,1)
  3. fsurf(@(u,v) u.*sin(v),@(u,v) -u.*cos(v),@(u,v) v,[-5,5,-5,2])
  4. subplot(1,2,2)
  5. fmesh(@(u,v) u.*sin(v),@(u,v) -u.*cos(v),@(u,v) v,[-5,5,-5,2])


本文转载自: https://blog.csdn.net/m0_56689906/article/details/128939262
版权归原作者 往事随风piao 所有, 如有侵权,请联系我们删除。

“Matlab绘图(第五节-三维曲面)”的评论:

还没有评论