matlab 三维图形绘制实例

合集下载

Matlab三维立体画图

Matlab三维立体画图

atlab 三维画图(2011-04-12 21:11:26) 转载▼标签: matlab 三维图分类: 课程学习今天被matlab 画三维图给整疯掉了,想通过三角形两边的变化求一边对角的变化函数图,但是matlab 中说这是complex ,无法画图,我就想限制值域,这样就是一对一的函数了,但是matlab 不知道怎么实现,网上查了查也没找到。

就先放一放再说吧。

不过过程中发现matlab 画出的图还是很强大且漂亮的。

附上两张: 1、mesh 函数[x, y]=meshgrid(-4:.2:4); R=sqrt(x.^2+y.^2); z=-cos(R); mesh(x,y,z)xlabel('x\in[-4,4]','fontweight','bold'); ylabel('y\in[-4,4]','fontweight','bold');zlabel('z=-cos(sqrt(x^2+y^2))','fontweight','bold');title('旋转曲面','fontsize',15,'fontweight','bold','fontname','隶书');二、meshc 函数其他不变,把上面代码中的mash 换成mashc ,得到的图如下,在网孔线下方绘制了轮廓线。

三、mashz函数Matlab 三维作图1 画一个可透视的椭球figurea = 15;b = 10;c = 5;k = 5;n = 2^k-1;theta = pi*(-n:2:n)/n;phi = (pi/2)*(-n:2:n)'/n;X = a*cos(phi)*cos(theta);Y = b*cos(phi)*sin(theta);Z = c*sin(phi)*ones(size(theta));surf(X,Y,Z,'FaceColor','interp',...'EdgeColor','none',...'FaceLighting','phong')axis tightcamlight leftalpha(.33) % 产生透视效果这是在7.1.上画的图:....................建立空间等高线[X,Y] = meshgrid([-2:.25:2]); Z = X.*exp(-X.^2-Y.^2);contour3(X,Y,Z,30)h = findobj('Type','patch');set(h,'LineWidth',2)title(' 空间等高线')..................§4.2 三维作图§4.2.1 mesh(Z)语句mesh(Z)语句可以给出矩阵Z元素的三维消隐图,网络表面由Z坐标点定义,与前面叙述的x-y平面的线格相同,图形由邻近的点连接而成.它可用来显示用其它方式难以输出的包含大量数据的大型矩阵,也可用来绘制Z变量函数.显示两变量的函数Z=f(x,y),第一步需产生特定的行和列的x-y矩阵.然后计算函数在各网格点上的值.最后用mesh函数输出.下面我们绘制sin(r)/r函数的图形.建立图形用以下方法:x=-8:.5:8;y=x';x=ones(size(y))*x;y=y*ones(size(y))';R=sqrt(x.^2+y.^2)+eps;z=sin(R)./R;mesh(z) %% 试运行mesh(x,y,z),看看与mesh(z)有什么不同之处?各语句的意义是:首先建立行向量x,列向量y;然后按向量的长度建立1-矩阵;用向量乘以产生的1-矩阵,生成网格矩阵,它们的值对应于x-y坐标平面;接下来计算各网格点的半径;最后计算函数值矩阵Z.用mesh函数即可以得到图形.图4.2.1三维消隐图第一条语句x的赋值为定义域,在其上估计函数;第三条语句建立一个重复行的x矩阵,第四条语句产生y的响应,第五条语句产生矩阵R(其元素为各网格点到原点的距离).用mesh方法结果如上.另外,上述命令系列中的前4行可用以下一条命令替代:[x, y]=meshgrid(-8:0.5:8)§4.2.2与mesh相关的几个函数(1) meshc与函数mesh的调用方式相同,只是该函数在mesh的基础上又增加了绘制相应等高线的功能.下面来看一个meshc的例子:[x,y]=meshgrid([-4:.5:4]);z=sqrt(x.^2+y.^2);meshc(z) %% 试运行meshc(x,y,z),看看与meshc(z)有什么不同之处?我们可以得到图形:图4.2.2.1 meshc图地面上的圆圈就是上面图形的等高线.(2)函数meshz与mesh的调用方式也相同,不同的是该函数在mesh函数的作用之上增加了屏蔽作用,即增加了边界面屏蔽.例如:[x,y]=meshgrid([-4:.5:4]);z=sqrt(x.^2+y.^2);meshz(z) %% 试运行meshz(x,y,z),看看与meshz(z)有什么不同之处?我们得到图形:图4.2.2.2 meshz图§4.2.3其它的几个三维绘图函数(1)在Matlab中有一个专门绘制圆球体的函数sphere,其调用格式如下:[x,y,z]=sphere(n)此函数生成三个(n+1)×(n+1)阶的矩阵,再利用函数surf(x,y,z)可生成单位球面.[x,y,z]=sphere 此形式使用了默认值n=20sphere(n) 只绘制球面图,不返回值.运行下面程序:sphere(30);axis square;我们得到球体图形:图4.2.3.1 球面图若只输入sphere画图,则是默认了n=20的情况.(2) surf函数也是Matlab中常用的三维绘图函数.其调用格式如下:surf(x,y,z,c)输入参数的设置与mesh相同,不同的是mesh函数绘制的是一网格图,而surf绘制的是着色的三维表面.Matlab语言对表面进行着色的方法是,在得到相应网格后,对每一网格依据该网格所代表的节点的色值(由变量c控制),来定义这一网格的颜色.若不输入c,则默认为c=z.我们看下面的例子:%绘制地球表面的气温分布示意图.[a,b,c]=sphere(40);t=abs(c); %求绝对值surf(a,b,c,t);axis equalcolormap('hot')我们可以得到图形如下:图4.2.3.2 等温线示意图§4.2.4图形的控制与修饰(1)坐标轴的控制函数axis,调用格式如下:axis([xmin,xmax,ymin,ymax,zmin,zmax])用此命令可以控制坐标轴的范围.与axis相关的几条常用命令还有:axis auto 自动模式,使得图形的坐标范围满足图中一切图元素axis equal 严格控制各坐标的分度使其相等axis square 使绘图区为正方形axis on 恢复对坐标轴的一切设置axis off 取消对坐标轴的一切设置axis manual 以当前的坐标限制图形的绘制(2)grid on 在图形中绘制坐标网格.grid off 取消坐标网格.(3)xlabel, ylabel, zlabel分别为x轴, y轴, z轴添加标注.title为图形添加标题.以上函数的调用格式大同小异,我们以xlabel为例进行介绍:xlabel('标注文本','属性1','属性值1','属性2','属性值2',…)这里的属性是标注文本的属性,包括字体大小、字体名、字体粗细等.例如:[x, y]=meshgrid(-4:.2:4);R=sqrt(x.^2+y.^2);z=-cos(R);mesh(x,y,z)xlabel('x\in[-4,4]','fontweight','bold');ylabel('y\in[-4,4]','fontweight','bold');zlabel('z=-cos(sqrt(x^2+y^2))','fontweight','bold');title('旋转曲面','fontsize',15,'fontweight','bold','fontname','隶书');图4.2.4.1添加标注。

MATLAB-图像处理之三维绘图

MATLAB-图像处理之三维绘图

(2)颜色映象使用
• 语句colormap(M)将矩阵M作为当前图形 窗口所用的颜色映象。
• 例如,colormap(cool)装入了一个有64 个输入项的cool颜色映象。
• colormap default装入了缺省的颜色映象 (hsv)。
• 函数plot、plot3、contour(等高线图) 和contour3不使用颜色映象,它们使用列 在plot颜色和线形表中的颜色。而大多数其 它绘图函数,比如mesh、surf、fill、 pcolor和它们的各种变形函数,使用当前 的颜色映象。

MMSHOW(pink(30))
• 函数mmshow取和colormap同样的输入参 量,但在这种情况下它用自己的伪彩色显 示而不是把颜色映象施加到当前图形。
• 另一种途径是使用MATLAB的函数rgbplot, 它可以把颜色映象的各列分别画成红、绿 和蓝色。
例如rgbplot(hot)
• 图中显示红色分量首先增加,然后是绿色, 最后是蓝色。
2.三维曲面/网线图
三维图形较二维图形复杂:表现在: 1. 数据的准备 2. 三维图形色彩的使用 3. 明暗处理、 4. 光照处理、 5. 视点处理等
(1)数据准备(很重要)
• 画函数 z f (x, y)所代表的三维空间曲面,需 要做以下数据准备: :
• (1)确定自变量的取值范围和取值间隔; • (2)构成自变量x,y的自变量“格点”矩阵; • (3)计算在自变量采样“格点”上的函数
• MATLAB的预定义色图矩阵CM
CM
含义
CM
含义
autumn 红、黄浓淡色
jet
蓝头红尾饱和值色
bone
蓝色调浓淡色

MATLAB 13三维图形

MATLAB 13三维图形

13.6 改变视角
三维图形的缺省视点是:以30度俯视z=0平面,以37.5度仰视x=0 平面。与z=0平面所成的方向角叫仰角,与x=0平面的夹角叫做方位 角。这样,缺省的三维视角方向仰角为30,方位角为-37.5。而缺省 的二维视角仰角为90,方位角为0。 view: 改变所有类型的二维和三维图形的图形视角。 view(az,el)和view([az,el ] ):将视角改变到所指定的方位角az和 仰角el。 [例13—18] 链接 Example06。
Pcolor函数把高度映射为一组颜色并以相同的比例显示与等值线一样 的信息,
13
pcolor 伪彩色图。 pcolor(C) 画一伪彩色图。从C 映射到当前的色图是由命令 colormap和axis定义的。 pcolor(X,Y,C) 在参数x和y指定的位置上画一由C 确定的伪彩色图。 [例13—21] 链接 Example07_1。 [例13—22] 链接 Example07_2。 contourf 填充二维等高线图。即先画出不同等高线,然后相邻的 等高线之间用同一颜色进行填充。填充用的颜色决定于当前的色图 颜色。 contourf(Z) 矩阵z的等高线图,其中z理解成距平面的高度。Z至 少为2*2 阶的。等高线的条数与高度是自动选择的。 contourf(Z,n) 画出矩阵z的n条高度不同的等高线。 contourf(Z,v) 画出矩阵z的、由v指定的高度的等高线图。
[例13—13] 链接 Example04_3。
8
MATLAB的surf也有两个同种函数:surfc,它画出具有基础等 值线的曲面图;surfl,它画出一个有亮度的曲面图。 [例13—14] 链接 Example04_4。 surfnorm(X,Y,Z)函数: 计算由X,Y,Z所定义曲面的曲面法线,绘制 曲面图,并在曲面的数据点上绘制向量法线。 [Nx,Ny,Nz]=surfnorm(X,Y,Z): 计算三维曲面的法线并返回其分量, 但不绘制曲面图。 [例13—15] 链接 Example04_5。

matlab三维绘图

matlab三维绘图

三维线图函数
● 例 题 : 绘 制 三 维 的 螺 旋 曲 线 图 , 其 中 x=sint, y=cos(2t),z=sint+cost,t的区间为[0,2π]。 程序如下: t=0:pi/50:2*pi; plot3(sin(t),cos(2*t),sin(t)+cos(t),'r','Linewidth',2) xlabel('X轴') ylabel('Y轴') zlabel('Z轴')
●例题:绘制多个球体,各球的中心离原点的距离由x、y、z 值决定。 程序如下: [x,y,z]=sphere; surf(x,y,z) hold on surf(x+3,y-2,z) surf(x,y+1,z-3) daspect([1 1 1]) xlabel('X轴') ylabel('Y轴') zlabel('Z轴')
三维网格图
●所谓的网格图,是指把相邻的数据点连接起来形 成的网状曲面。利用在x-y平面的矩形网格点上的 z轴坐标值,MATLAB定义了一个网格曲面。三维 网格图的形成原理为:在x-y平面上指定一个长方 形区域,采用与坐标轴平行的直线将其分格;计 算矩形网格点上的函数值,即z轴的值,得到三 维空间的数据点;将这些数据点分别用于x-z或者 平行面内的曲线和处于y-z或者平行面内的曲线连 接起来,即形成网格图。网格图对显示大型的数 值矩阵很有用处。
模块十 三维图形绘制
◆三维线图 ◆三维多边形 ◆三维网格图 ◆三维曲面图 ◆三维柱面绘图函数
三维线图函数
● plot3():主要用于绘制三维曲线,该函数的 调用格式同plot()函数类似。 ● 调用格式为: plot3(X, Y, Z, LineSpec,’ PropertyName’, Property Value) 调用该函数,绘制出通过一系列坐标为X, Y, Z 指定点的一条曲线。其中,X, Y, Z为第一到第 三维数据,可以是向量,也可以是矩阵,但必 须尺寸相等。

使用matlab绘制三维图形的方法

使用matlab绘制三维图形的方法

matlab 绘制三维图形的方法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);gridtitle('Line in 3-D Space');xlabel('X');ylabel('Y');zlabel('Z'); 如下图:XLine in 3-D SpaceYZ三维曲面1.产生三维数据在MATLAB 中,利用meshgrid 函数产生平面区域内的网格坐标矩阵。

其格式为: x=a:d1:b; y=c:d2:d; [X,Y]=meshgrid(x,y);语句执行后,矩阵X 的每一行都是向量x ,行数等于向量y 的元素的个数,矩阵Y 的每一列都是向量y ,列数等于向量x 的元素的个数。

2.绘制三维曲面的函数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); %在[0,4pi]×[0,4pi]区域生成网格坐标 z=sin(x+sin(y))-x/10; mesh(x,y,z);axis([0 4*pi 0 4*pi -2.5 1]); 如下图:-2.5-2-1.5-1-0.500.51此外,还有带等高线的三维网格曲面函数meshc 和带底座的三维网格曲面函数meshz 。

MATLAB三维图

MATLAB三维图

注意符号,随着t 的增大,观察图 像的变化
空间三维作图
1、三维折线及曲线条
先画点连线
plot3(X,Y,Z,'s') plot3(X1,Y1,Z1,'s1',X2,Y2,Z2,'s2',...) (1) X、Y、Z是同维向量时,则绘制以X、Y、Z元素 为x、y、z坐标的三维曲线; (2) X、Y、Z是同维矩阵时,则以X、Y、Z对应列元 素为x、y、z坐标绘制多条曲线,曲线条数等于矩阵 的列数; (3) s、s1、s2的意义与二维相同。
空间曲面 mesh, meshc, meshz
meshc 调用方式与 mesh 相同,在 mesh 基础上增加等高线 meshz 调用方式与 mesh 相同,在 mesh 基础上屏蔽边界面
例:“墨西哥帽子”
由函数 z sin( r ) / r, 其中 r x 2 y 2 确定的曲面
Matlab 符号作图
空间曲面绘图: ezmesh、ezsurf

ezmesh(z(x,y),[a,b,c,d])
z z( x, y ), a x b, c y d

ezmesh(z(x,y),[a,b])
z z( x, y ), a x, y b
ezmesh(z(x,y))
>> [B,A]=meshgrid(b,a) B= 3 4 5 3 4 5 A= 1 2
1 2
1 2
3 4 5(转置再增加一列)
示例:绘制二元函数图形
画出函数 z
x2 y2
的图形,其中(x,y)属于[-3,3]*[-3,3]
绘制的步骤是?
绘制的步骤是?

Matlab 三维立体绘图

Matlab 三维立体绘图
1 0 Z2 1 2 3 0 2 1 1 1 2 1 2 2 3 2 3 3 3 4 4 4 5 5 6
– 請劃出其網狀圖形,並標示x座標、y座標以及給定的 點座標。 – 請劃出其曲面圖形,並標示x座標、y座標以及給定的 點座標。
8
4-1 基本立體繪圖指令
1 2 3 4
0 3 4 7
2 2 4 6
% 標示曲面高度
set(h, 'hori', 'center', 'vertical', 'bottom', 'color', 'r'); % 改變位置及顏色
5
3
1 4 4 8
4-1 基本立體繪圖指令
– 範例4-2 :plotxyz002.m
8
8 7 6
6 4 4 4 4
– 範例4-5 :plotxyz02.m surf 和 mesh 指令的用法類似
x = linspace(-2, 2, 25); y = linspace(-2, 2, 25); % 在 x 軸 [-2,2] 之間取 25 點 % 在 y 軸 [-2,2] 之間取 25 點
[xx,yy] = meshgrid(x, y);
2
Matrix Indexing Coordinate
• Conversion from matrix indexing to x-y coordinates
– Jx – Iy
1
j (= x)
2
1 2 3 4
0 3 4 7
2 2 4 6
3
1 4 4 8
(i, j) = (3, 2)
A(4,3)=8 A(3,2)=4

matlab三维绘图命令和演示

matlab三维绘图命令和演示

三维绘图1三维绘图指令2基本XYZ 立体绘图命令●mesh 和plot 是三度空间立体绘图的基本命令,mesh 可画出立体网状图,plot 则可画出立体曲面图,两者产生的图形都会依高度而有不同颜色。

下列命令可画出由函数形成的立体网状图:x=linspace(-2,2,25);%在x 轴上取25点 y=linspace(-2,2,25);%在y 轴上取25点[xx,yy]=meshgrid(x,y);%xx 和yy 都是25x25的矩阵zz=xx.*exp(-xx.^2-yy.^2);%计算函数值,zz 也是21x21的矩阵 mesh(xx,yy,zz);%画出立体网状图● surf 和mesh 的用法类似:x=linspace(-2,2,25);%在x 轴上取25点y=linspace(-2,2,25);%在y轴上取25点[xx,yy]=meshgrid(x,y);%xx和yy都是25x25的矩阵zz=xx.*exp(-xx.^2-yy.^2);%计算函数值,zz也是25x25的矩阵surf(xx,yy,zz);%画出立体曲面图●peaks为了方便测试立体绘图,MATLAB提供了一个peaks函数,可产生一个凹凸有致的曲面,包含了三个局部极大点及三个局部极小点,其方程式为:要画出此函数的最快方法即是直接键入peaks:peaksz=3*(1-x).^2.*exp(-(x.^2)-(y+1).^2)-10*(x/5-x.^3-y.^5).*exp(-x.^2-y.^2)-1/3*exp(-(x+1).^2-y.^2)●我们亦可对peaks函数取点,再以各种不同方法进行绘图。

meshz可将曲面加上围裙:[x,y,z]=peaks;meshz(x,y,z);●waterfall可在x方向或y方向产生水流效果:[x,y,z]=peaks;waterfall(x,y,z);●下列命令产生在y方向的水流效果:[x,y,z]=peaks;waterfall(x',y',z');●meshc同时画出网状图与等高线:[x,y,z]=peaks;meshc(x,y,z);●surfc同时画出曲面图与等高线:[x,y,z]=peaks;surfc(x,y,z);●contour3画出曲面在三度空间中的等高线:contour3(peaks,20);●contour画出曲面等高线在XY平面的投影:contour(peaks,20);●plot3可画出三度空间中的曲线:t=linspace(0,20*pi,501);plot3(t.*sin(t),t.*cos(t),t);亦可同时画出两条三度空间中的曲线:t=linspace(0,10*pi,501);plot3(t.*sin(t),t.*cos(t),t,t.*sin(t),t.*cos(t),-t);3三维绘图的主要功能绘制三维线图绘制等高线图绘制伪彩色图绘制三维网线图?绘制三维曲面图、柱面图和球面图?绘制三维多面体并填充颜色(一)三维线图plot3?——?基本的三维图形指令调用格式:plot3(x,y,z)?——?x,y,z是长度相同的向量plot3(X,Y,Z)?——?X,Y,Z是维数相同的矩阵plot3(x,y,z,s)?——?带开关量plot3(x1,y1,z1,’s1’,?x2,y2,z2,’s2’,?…)二维图形的所有基本特性对三维图形全都适用。

matlab实验 三维画图

matlab实验  三维画图

实验(六)项目名称:三维绘图一、实验目的:熟悉MATLAB中几个常用的绘图命令,掌握集中常见三维图形的画法。

二、实验原理三维绘图命令:Plot(X,Y,Z)//曲线;mesh(X,Y,Z)//网状;surf(X,Y,Z)//表面;contour(X,Y,Z)//等高线。

三、实验环境1.硬件:PC机2. 软件:Windows操作系统、matlab2015四、实验内容、步骤以及结果4.1.1实验要求:用plot函数画出的三维曲线。

4.1.2实验步骤(1)启动matlab,新建一个M文件;(2)输入程序,如图1;(3)保存文件;(4)编译源程序,观察屏幕上显示的编译信息,修改出现的错误,直到编译成功;图1:plot函数画三维曲线4.1.3运行结果如下:图2:三维曲线4.2.1实验要求:用mesh函数画出的三维网状图。

4.2.2实验步骤(5)启动matlab,新建一个M文件;(6)输入程序,如图3;(7)保存文件;(8)编译源程序,查看运行结果,如图4。

图3:mesh函数画三维网状图图4:运行结果4.3.1实验要求:用surf函数画出的三维表面图。

4.3.2实验步骤(9)启动matlab,新建一个M文件;(10)输入程序,如图5;(11)保存文件;(12)编译源程序,查看运行结果,如图6。

图5:surf函数画三维表面图图6:运行结果4.3.1实验要求:用contour函数画出的等高线图。

4.3.2实验步骤(13)启动matlab,新建一个M文件;(14)输入程序,如图7;(15)保存文件;(16)编译源程序,查看运行结果,如图8。

图7:contour函数画等高线图8:运行结果五、实验总结MATLAB具有强大的图形功能,能够将它们直观的表现出来,解决很多的问题。

matlab三维绘图命令和演示

matlab三维绘图命令和演示

三维绘图2 基本XYZ立体绘图命令●mesh和plot是三度空间立体绘图的基本命令,mesh可画出立体网状图,plot则可画出立体曲面图,两者产生的图形都会依高度而有不同颜色。

下列命令可画出由函数形成的立体网状图:x=linspace(-2, 2, 25); % 在x轴上取25点y=linspace(-2, 2, 25); % 在y轴上取25点[xx,yy]=meshgrid(x, y); % xx和yy都是25x25的矩阵zz=xx.*exp(-xx.^2-yy.^2); % 计算函数值,zz也是21x21的矩阵mesh(xx, yy, zz); % 画出立体网状图●surf和mesh的用法类似:x=linspace(-2, 2, 25); % 在x轴上取25点y=linspace(-2, 2, 25); % 在y轴上取25点[xx,yy]=meshgrid(x, y); % xx和yy都是25x25的矩阵zz=xx.*exp(-xx.^2-yy.^2); % 计算函数值,zz也是25x25的矩阵surf(xx, yy, zz); % 画出立体曲面图●peaks为了方便测试立体绘图,MATLAB提供了一个peaks函数,可产生一个凹凸有致的曲面,包含了三个局部极大点及三个局部极小点,其方程式为:要画出此函数的最快方法即是直接键入peaks:peaksz = 3*(1-x).^2.*exp(-(x.^2) - (y+1).^2) - 10*(x/5 - x.^3 - y.^5).*exp(-x.^2-y.^2) - 1/3*exp(-(x+1).^2 - y.^2)●我们亦可对peaks函数取点,再以各种不同方法进行绘图。

meshz可将曲面加上围裙:[x,y,z]=peaks;meshz(x,y,z);●waterfall可在x方向或y方向产生水流效果:[x,y,z]=peaks;waterfall(x,y,z);●下列命令产生在y方向的水流效果:[x,y,z]=peaks;waterfall(x',y',z');●meshc同时画出网状图与等高线:[x,y,z]=peaks;meshc(x,y,z);●surfc同时画出曲面图与等高线:[x,y,z]=peaks;surfc(x,y,z);●contour3画出曲面在三度空间中的等高线:contour3(peaks, 20);●contour画出曲面等高线在XY平面的投影:contour(peaks, 20);plot3可画出三度空间中的曲线:t=linspace(0,20*pi, 501);plot3(t.*sin(t), t.*cos(t), t);亦可同时画出两条三度空间中的曲线:t=linspace(0, 10*pi, 501);plot3(t.*sin(t), t.*cos(t), t, t.*sin(t), t.*cos(t), -t);三维绘图的主要功能:绘制三维线图绘制等高线图绘制伪彩色图绘制三维网线图绘制三维曲面图、柱面图和球面图绘制三维多面体并填充颜色(一)三维线图plot3 ——基本的三维图形指令调用格式:plot3(x,y,z) —— x,y,z是长度相同的向量plot3(X,Y,Z) —— X,Y,Z是维数相同的矩阵plot3(x,y,z,s) ——带开关量plot3(x1,y1,z1,’s1’,x2,y2,z2,’s2’,…)二维图形的所有基本特性对三维图形全都适用。

matlab三维绘图ppt课件

matlab三维绘图ppt课件
MATLAB 绘图
xx
1
三维曲线绘图 三维曲面绘图
2
xx
二、MATLAB三维曲线绘图
plot3——三维曲线绘制指令 plot3的调用格式:
plot3(X,Y,Z) plot3(X,Y,Z,’String’) plot3(X1,Y1,Z1,’ String1’,X2,Y2,Z2,’ String2’,…) plot3与plot的 用法相同
➢ shading faceted
以平面为单位进行着色,在flat用色基础上,在贴片的 四周勾出黑色网线。
23
subplot(131),surf(peaks(40)); subplot(132),surf(peaks(40));shading flat subplot(133),surf(peaks(40));shading interp
subplot(122),h = surf(ones(10,10));rotate(h,[0 0 1],i,[1 0 0]) end
➢ rotate3d
动态旋转命令,可以让用户使用鼠标来旋转视角
19
背景颜色控制命令colordef
➢ colordef white 将图形的背景颜色设置为白色 ➢ colordef black ➢ colordef none 将图形背景和图形窗口的颜色设置
28
对象和句柄
MATLAB把构成图形的各个基本要素称为图形对象, 包括图形窗口、坐标轴、线条、曲面、文本和其它对 象。
每一个对象都有一个数字来标识,叫做句柄。当每次 创建一个对象时,MATLAB就为它建立一个唯一的句 柄。
29
作业ห้องสมุดไป่ตู้P79
5,7,8,9
30
22

MATLAB三维图形绘制

MATLAB三维图形绘制

%绘制极坐标图
说明:theta为相角,radius为离原点的距离。
• 【】求传递函数为
G(s) s(0的.51s对1)数幅频特性曲线,
横坐标为w,按对数坐标。
Aw=1./(w.*sqrt((0.5*w).^2+1)); Lw=20*log10(Aw); semilogx(w,Lw) title('对数幅频特性曲线')
• colormap 色图函数—— 色图设定函数
• colormap 色图函数(m)——产生m×3的色图矩阵 缺省64×3。
颜色
Black(黑) White(白) Red(红) Green(绿) Blue(蓝) Yellow(黄) Magenta(品红) Cyan(青) Gray(灰) Dark red(暗红) Copper(铜色) Aquamarine(碧绿)
【上例续】使用消息框显示当阻尼系数大于1时的警告信 息,如下图。
>>msgbox('阻尼系数输入范围出错','警告','warn')
〔2〕其它对话框
【例续】使用警告对话框显示当阻尼系数大于1时的警告 信息。 >>warndlg('阻尼系数输入范围出错','警告')
【例续】使用出错提示框显示当阻尼系数小于0时出错 信息。 >>errordlg('阻尼系数输入出错','出错')
说明:az表示方位角(azimuth),el表示俯仰角(elevation)
°,el=30°
五、色彩的控制
1.色图(colormap)
(1) RGB三元组
RGB三元数组每行表示一种色彩,数组元素R、G、B在 0~1之间取值,分别表示红、绿、蓝基色的相对亮度,如 下表所示。

matlab 三维图形绘制实例(完整资料).doc

matlab  三维图形绘制实例(完整资料).doc

【最新整理,下载后即可编辑】三维图形一.三维曲线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;所的图形如下:XLine in 3-D SpaceYZ二. 三维曲面 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种三维曲面图。

MATLAB教程三维图形

MATLAB教程三维图形

x=sin(t); y=cos(t); z=t;
plot3(x,y,z) ,
axis square; grid on
Kjqx.m
x1=[0.5, 0.5, 0, 0.5]; y1=[0.5, 0.5, 0, 0.5]; z1=[ 1, 0, 0, 1 ]; x2=[0.5, 0.5, 1, 0.5]; y2=[0.5, 0.5, 0, 0.5]; z2=[ 1, 0, 0, 1 ]; x3=[0,1]; y3=[0,0]; z3=[0,0]; plot3(x1,y1,z1,x2,y2,z2,x3,y3,z3)
三.网线和表面图
1、三维绘图数据的产生
在matlab中,曲面是用x y平面上各个格点的 Z坐标 来定义的。画曲面前先要生成三维绘图数据。
(1)利用meshgrid函数生成平面网格坐标矩阵。再 利用函数关系求Z.
x=a:△x:b; y=c:△y:d; [X,Y]=meshgrid(x,y); Z=f (x,y) (2)利用双峰函数peaks [x,y,z]=peaks(n) 分别创建x,y,z三个均为n×n阶的方阵 peaks(n)直接使用peaks函数所创建的矩阵绘制表面图
色图矩阵是m×3 的数值矩阵,它的每一行是RGB三元组。 [0 0 0] 黑色 [1 0 0] 红色 [0 1 0]蓝色 [0 0 1]绿色
色图函数 pink 粉色 copper 铜色 hot 暖色 cool 冷色 flag 四色旗 prism光谱色
setu.m spring summer autumn winter
ys.m ys02.m
1.5.4 动画
1、彗星轨迹图
Comet(x,y,p)
彗长为p*length(y)的二维彗星轨迹,p的默认值为0y)的三维彗星轨迹,p的默认值为0.1 ddqxn.m huixing.m

Matlab绘图教程大量实例

Matlab绘图教程大量实例
图形上添加希腊字母、数学符号及公式等内容。 例如,text(0.3,0.5,‘sin({\omega}t+{\beta})’)将得到 标注效果sin(ωt+β)。
例7 在0≤x≤2区间内,绘制曲线y1=2e-0.5x和 y2=cos(4πx),并给图形添加图形标注。
程序如下:
x=0:pi/100:2*pi;
极坐标图
polar函数用来绘制极坐标图,其调用格式为: polar(theta,rho,选项) 其中theta为极坐标极角,rho为极坐标矢径,选项
旳内容与plot函数相同。 例12 绘制r=sin(t)cos(t)旳极坐标图,并标识数据点。 程序如下: t=0:pi/50:2*pi; r=sin(t).*cos(t); polar(t,r,'-*');
plot(x1,y1,选项1,x2,y2,选项2,…,xn,yn,选项n)
例6 在同一坐标内,分别用不同线型和颜色绘制曲 线y1=0.2e-0.5xcos(4πx) 和y2=2e-0.5xcos(πx),标识两 曲线交叉点。
程序如下:
x=linspace(0,2*pi,1000);
y1=0.2*exp(-0.5*x).*cos(4*pi*x);
(2) 当输入参数有矩阵形式时,配正确x,y按相应列 元素为横、纵坐标分别绘制曲线,曲线条数等于 矩阵旳列数。
例3 分析下列程序绘制旳曲线。 x1=linspace(0,2*pi,100); x2=linspace(0,3*pi,100); x3=linspace(0,4*pi,100); y1=sin(x1); y2=1+sin(x2); y3=2+sin(x3); x=[x1;x2;x3]'; y=[y1;y2;y3]'; plot(x,y,x1,y1-1)

matlab 三维图形绘制实例

matlab  三维图形绘制实例

三维图形一. 三维曲线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;所的图形如下:XLine in 3-D SpaceYZ二. 三维曲面 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种三维曲面图。

Matlab——图形绘制——三维立体图形剔透玲珑球动态图——彗星状轨迹图

Matlab——图形绘制——三维立体图形剔透玲珑球动态图——彗星状轨迹图

Matlab——图形绘制——三维⽴体图形剔透玲珑球动态图——彗星状轨迹图三维绘图函数三维绘制⼯具函数view实例:三维螺旋线>> t=0:pi/50:10*pi;plot3(sin(t),cos(t),t)grid %添加⽹格plot3可以画出空间中的曲线>> t=linspace(0,20*pi, 501);plot3(t.*sin(t), t.*cos(t), t); %注意⽤点乘 .*也可以同时画出两条空间中的曲线>> t=linspace(0,10*pi,501);>> plot3(t.*sin(t),t.*cos(t),t,t.*sin(t),t.*cos(t),-t);正弦曲线图x=linspace(0,3*pi); % 0到 3pi 间100 个数据点z1=sin(x);z2=sin(2*x);z3=sin(3*x);y1=zeros(100); % 含有100 个数据的0数组y3=zeros(100);y2=y3/2;plot3(x,y1,z1,x,y2,z2,x,y3,z3);⽴体⽹状图实例:>> x=linspace(-2, 2, 25); %在x轴上取25点y=linspace(-2, 2, 25); %在y轴上取25点[xx,yy]=meshgrid(x, y); % xx和yy都是21x21的矩阵zz=xx.*exp(-xx.^2-yy.^2); %计算函数值,zz也是21x21的矩阵mesh(xx, yy, zz); %画出⽴体⽹状图曲⾯图>> x=linspace(-2, 2, 25); %在x轴上取25点y=linspace(-2, 2, 25); %在y轴上取25点[xx,yy]=meshgrid(x, y); % xx和yy都是21x21的矩阵zz=xx.*exp(-xx.^2-yy.^2); %计算函数值,zz也是21x21的矩阵surf(xx, yy, zz);%画出⽴体曲⾯图peaks函数>> z = 3*(1-x).^2.*exp(-(x.^2) - (y+1).^2) ...- 10*(x/5 - x.^3 - y.^5).*exp(-x.^2-y.^2) ...- 1/3*exp(-(x+1).^2 - y.^2);>> peaks z也可以对peaks函数取点,再以各种不同的⽅法进⾏绘图meshz 可将曲⾯加上围裙[x,y,z]=peaks;meshz(x,y,z);waterfall 可在x ⽅向或y ⽅向产⽣⽔流效果:[x,y,z]=peaks;waterfall(x,y,z);产⽣在y⽅向的⽔流效果:[x,y,z]=peaks;waterfall(x',y',z');meshc 同时画出⽹状图与等⾼线:[x,y,z]=peaks;meshc(x,y,z);surfc 同时画出曲⾯图与等⾼线:[x,y,z]=peaks;surfc(x,y,z);contour3 画出曲⾯在三度空间中的等⾼线contour3(peaks, 20);contour 画出曲⾯等⾼线在XY 平⾯的投影contour(peaks, 20);剔透玲珑球[X0,Y0,Z0]=sphere(30); %产⽣单位球⾯的三维坐标X=2*X0;Y=2*Y0;Z=2*Z0; %产⽣半径为2 的球⾯的三维坐标surf(X0,Y0,Z0); %画单位球⾯shading interp %采⽤插补明暗处理hold on; mesh(X,Y,Z);hold off %画外球⾯hidden off %产⽣透视效果axis off %不显⽰坐标轴动态图形动画效果——彗星状轨迹图R0=1; %以地球半径为⼀个单位a=12*R0;b=9*R0;T0=2*pi; %T0是轨道周期T=5*T0;dt=pi/100;t=[0:dt:T]';f=sqrt(a^2-b^2); %地球与另⼀焦点的距离th=12.5*pi/180; %卫星轨道与x-y平⾯的倾⾓E=exp(-t/20); %轨道收缩率x=E.*(a*cos(t)-f);y=E.*(b*cos(th)*sin(t));z=E.*(b*sin(th)*sin(t)); plot3(x,y,z,'g') %画全程轨线[X,Y,Z]=sphere(30);X=R0*X;Y=R0*Y;Z=R0*Z; %获得单位球坐标grid on,hold on,surf(X,Y,Z),shading interp %画地球x1=-18*R0;x2=6*R0;y1=-12*R0;y2=12*R0;z1=-6*R0;z2=6*R0; axis([x1 x2 y1 y2 z1 z2]) %确定坐标范围view([11737]),comet3(x,y,z,0.02),hold off %设视⾓、画运动轨线。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 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)。

相关文档
最新文档