首页 > 其他 > 详细

matlab学习笔记8 基本绘图命令-三维绘图

时间:2019-10-18 19:49:46      阅读:59      评论:0      收藏:0      [点我收藏+]

一起来学matlab-matlab学习笔记8

基本绘图命令_6 三维绘图

觉得有用的话,欢迎一起讨论相互学习~Follow Me

参考书籍
《matlab 程序设计与综合应用》张德丰等著 感谢张老师的书籍,让我领略到matlab的便捷
《MATLAB技术大全》葛超等编著 感谢葛老师的书籍,让我领略到matlab的高效

三维绘图命令

三维绘图命令plot3

  • plot3命令将绘制二维图形的函数plot的特性扩展到三维空间图形。函数格式除了包括第三维的信息(如Z方向)之外,与二维函数plot相同。其调用格式如下。
    • plot3(x,y,z):当x,y和z是相同的向量时,则绘制以x,y和z元素为坐标的三维曲线;当x,y和z是同型矩阵时,则绘制以x,y和z元素为坐标的三维曲线,且曲线的条数等于矩阵的列数。
    • plot3(x,y,z,‘s‘):s是指定绘制三维曲线的线型、数据点形和颜色的字符串,省略s时,将自动选择线型、数据点形和颜色。
  • 使用plot3绘制三维螺旋曲线图
t=0:pi/50:10*pi;
plot3(sin(t),cos(t),t,'g*')
grid

技术分享图片

绘制空间曲面

  • 三维空间曲面可以绘制出在某一区间内完整的曲面,而不是单根曲线。三维网格图是将邻近的网格顶点(x,Y)对应曲面上的点(X,Y,Z)用线条连接起来形成的。利用mesh和surf绘制三维网线图和曲面图。其中mesh(X,Y,Z)是绘制网格曲面,surf(X,Y,Z)是绘制光滑曲面。
    • mesh(x,y,z,c):绘制由x、y和z指定的参数曲面。x和y必须为向量。若x和y的长度为m和n,则z必须为m×n的矩阵,c是颜色映射数组,决定图形的颜色。
    • mesh(z)和mesh(x,y,z):绘制三维网格图。当只有参数z时,以z矩阵的行下标作为x坐标轴,把z的列下标当作坐标轴;x和y分别为x和y坐标轴的自变量。当有x,y和z参数时,绘制出由坐标(x,y,z)确定的三维网格图形
    • surf(x,y,z,c):完整地画出由c指定用色的曲面图,在完整调用格式中,4个输入量必须是维数相同的矩阵。它们要求x和y是自变量“格点”矩阵;z是格点上的函数矩阵;c是指定各点用色的矩阵,可以默认。默认时,默认着色矩阵是z,即c=z。
  • 画三维函数立体网状图
x=linspace(-2, 2, 20);      % 在x轴上取20点
y=linspace(-2, 2, 20);      %在y轴上取20点
[xx,yy]=meshgrid(x, y);     % xx和yy都是21x21的矩阵
zz=xx.*exp(-xx.^2-yy.^2);   % 计算函数值,zz也是21x21的矩阵
mesh(xx, yy, zz);          % 画出立体网状图

技术分享图片

  • 使用surf命令将以上立体网格图改为三维曲面图
x=linspace(-2, 2, 20);      % 在x轴上取20点
y=linspace(-2, 2, 20);      %在y轴上取20点
[xx,yy]=meshgrid(x, y);     % xx和yy都是21x21的矩阵
zz=xx.*exp(-xx.^2-yy.^2);   % 计算函数值,zz也是21x21的矩阵
surf(xx, yy, zz);          % 画出立体曲面图

技术分享图片

高级三维绘图改进命令

技术分享图片

peaks % 最原始版本图形 F1
[x,y,z]=peaks;
figure;
meshz(x,y,z);  % 画上一个参考平面 F2
figure;
waterfall(x,y,z); % 瀑布流水形状网线图 F3
figure;
meshc(x,y,z); % 网格线和等高线 F4
figure;
surfc(x,y,z); % 同时画出曲面图和等高线图 F5
  • F1
    技术分享图片
  • F2
    技术分享图片
  • F3
    技术分享图片
  • F4
    技术分享图片
  • F5
    技术分享图片

高级三维绘图改进命令

技术分享图片

p=peaks;    %peaks 为系统提供的多峰函数
subplot(2,2,1);
mesh(peaks,p);
view(-37.5,30);  %指定子图 1 的视点
title('azimuth=-37.5,elevation=30');
subplot(2,2,2);
mesh(peaks,p);
view(-17,60);   %指定子图 2的视点
title('azimuth=-17,elevation=60');
subplot(2,2,3);
mesh(peaks,p);
view(-90,0);    %指定子图 3 的视点
title('azimuth=-90,elevation=0');
subplot(2,2,4);
mesh(peaks,p);
view(-7,-10);    %指定子图 4的视点
title('azimuth=-7,elevation=10')

技术分享图片

三维图形的光照控制

技术分享图片

x= -1.5:0.2:1.5;y=-1:0.2:1;
[X,Y]=meshgrid(x,y);
Z=sqrt(4-X.^2/9-Y.^2/4);
view(45,45)
subplot(2,2,1);surfl(X,Y,Z, [0,45],[.1  .6  .4  10]);
shading interp
subplot(2,2,2);surfl(X,Y,Z, [20,45],[.3  .6  .4  10]);
shading interp
subplot(2,2,3);surfl(X,Y,Z, [40,45],[.6  .6  .4  10]);
shading interp
subplot(2,2,4);surfl(X,Y,Z, [60,45],[.9  .6  .4  10]);  
shading interp

技术分享图片

  • matlab提供了灯光设置的函数,其调用格式为: light(‘Color‘,选项1,‘Style‘,选项2,‘Position‘,选项3)
[x,y,z]=sphere(20);
subplot(1,2,1);
surf(x,y,z);

技术分享图片

[x,y,z]=sphere(20);
subplot(1,2,1);
surf(x,y,z);
axis equal; % 横轴纵轴的坐标定标系数设为相同值

技术分享图片

[x,y,z]=sphere(20);
subplot(1,2,1);
surf(x,y,z);
axis equal; % 横轴纵轴的坐标定标系数设为相同值
light('Posi',[1,1,1]);

技术分享图片

[x,y,z]=sphere(20);
subplot(1,2,1);
surf(x,y,z);
axis equal; % 横轴纵轴的坐标定标系数设为相同值
light('Posi',[-1,-1,0]);

技术分享图片

  • 光滑表示
[x,y,z]=sphere(20);
subplot(1,2,1);
surf(x,y,z);
axis equal; % 横轴纵轴的坐标定标系数设为相同值
light('Posi',[-1,-1,0]);
shading interp;

技术分享图片

  • 三维点图
plot3(0,1,1,'*');
text(0,1,1,' light');

技术分享图片

  • 三维图片拼接
    技术分享图片
[x,y,z]=sphere(20);
subplot(1,2,1);
surf(x,y,z);
axis equal; % 横轴纵轴的坐标定标系数设为相同值
light('Posi',[-1,-1,0]); % 灯光位置
shading interp; % 光滑
hold on;
plot3(0,1,1,'p');
text(0,1,1,' light');
subplot(1,2,2);
surf(x,y,z);
axis equal;
light('Posi',[1,0,1]); % 灯光位置
shading interp; % 光滑
hold on;
plot3(1,0,1,'p');
text(1,0,1,' light');

柱面和球面的表达

  1. 绘制柱面的cylinder命令:[X,Y,Z]=cylinder(r,n)表示生成半径为r,高度为1的矩阵x,y,z,利用这三个矩阵可以绘制出半径为r,高度为1的柱体,圆柱体的圆周有指定的n个距离相同的点。
figure
subplot(2,2,1)
[x,y,z]=cylinder(3,2)
surf(x,y,z)
subplot(2,2,2)
[x,y,z]=cylinder(3,3)
surf(x,y,z)
subplot(2,2,3)
[x,y,z]=cylinder(3,4)
surf(x,y,z)
subplot(2,2,4)
t=0:pi/10:2*pi;
[X,Y,Z]=cylinder(2+cos(t),30);
surf(X,Y,Z)

技术分享图片

  1. 绘制球面的sphere命令:[x,y,z]=sphere(n)表示生成三个阶数为(n+1) * (n+1) 的矩阵x,y,z,利用这是三个矩阵可以绘制出圆心位于原点,半径为1的单位球体。
figure
subplot(2,2,1)
[x,y,z]=sphere(100)
surf(x,y,z)
subplot(2,2,2)
[x,y,z]=sphere(100)
plot3(x,y,z)
subplot(2,2,3)
[x,y,z]=sphere(100)
surfl(x,y,z)
subplot(2,2,4)
[x,y,z]=sphere(100)
mesh(x,y,z)

技术分享图片

matlab学习笔记8 基本绘图命令-三维绘图

原文:https://www.cnblogs.com/cloud-ken/p/11699933.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!