matlab绘制三维图形

原文地址:matlab制三维图形 作者:hotinko1

三维曲线
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');

三维曲面
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]);
此外,还有带等高线的三维网格曲面函数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(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)')
3
.标准三维曲面
sphere
函数的调用格式为:
[x,y,z]=sphere(n)
generates three (N+1)-by-(N+1)   matrices so that SURF(X,Y,Z) produces a unit sphere.
cylinder
函数的调用格式为:
[x,y,z]= cylinder(R,n)
,其中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);
surf(x,y,z);


其他三维图形

在介绍二维图形时,曾提到条形图、杆图、饼图和填充图等特殊图形,它们还可以以三维形式出现,使用的函数分别是bar3stem3pie3 fill3
bar3
函数绘制三维条形图,常用格式为:
bar3(y)
bar3(x,y)
stem3
函数绘制离散序列数据的三维杆图,常用格式为:
stem3(z)
stem3(x,y,z)
pie3
函数绘制三维饼图,常用格式为:
pie3(x)
fill3
函数等效于三维函数fill,可在三维空间内绘制出填充过的多边形,常用格式为:
fill3(x,y,z,c)
 
  绘制三维图形:
(1)
绘制魔方阵的三维条形图。
(2)
以三维杆图形式绘制曲线y=2sin(x)
(3)
已知x=[2347,1827,2043,3025],绘制饼图。
(4)
用随机的顶点坐标值画出五个黄色三角形。
程序如下:
subplot(2,2,1);
bar3(magic(4))
subplot(2,2,2);
y=2*sin(0:pi/10:2*pi);
stem3(y);
subplot(2,2,3);
pie3([2347,1827,2043,3025]);
subplot(2,2,4);
fill3(rand(3,5),rand(3,5),rand(3,5), 'y' )

   绘制多峰函数的瀑布图和等高线图。
程序如下:
subplot(1,2,1);
[X,Y,Z]=peaks(30);
waterfall(X,Y,Z)
xlabel('X-axis'),ylabel('Y-axis'),zlabel('Z-axis');
subplot(1,2,2);
contour3(X,Y,Z,12,'k');     %
其中12代表高度的等级数
xlabel('X-axis'),ylabel('Y-axis'),zlabel('Z-axis');

 

图形修饰处理

视点处理
MATLAB
提供了设置视点的函数view,其调用格式为:
view(az,el)
其中az为方位角,el为仰角,它们均以度为单位。系统缺省的视点定义为方位角-37.5°,仰角30°
  从不同视点绘制多峰函数曲面。
   
程序如下:
    subplot(2,2,1);mesh(peaks);
    view(-37.5,30);          %
指定子图1的视点
    title('azimuth=-37.5,elevation=30')
    subplot(2,2,2);mesh(peaks);
    view(0,90);            %
指定子图2的视点
    title('azimuth=0,elevation=90')
    subplot(2,2,3);mesh(peaks);
    view(90,0);             %
指定子图3的视点
    title('azimuth=90,elevation=0')
    subplot(2,2,4);mesh(peaks);
    view(-7,-10);            %
指定子图4的视点
    title('azimuth=-7,elevation=-10')

色彩处理
1
.颜色的向量表示
MATLAB
除用字符表示颜色外,还可以用含有3个元素的向量表示颜色。向量元素在[0,1]范围取值,3个元素分别表示红、绿、蓝3种颜色的相对亮度,称为RGB三元组。
2
.色图
色图(Color map)MATLAB系统引入的概念。在MATLAB中,每个图形窗口只能有一个色图。色图是m×3 的数值矩阵,它的每一行是RGB三元组。色图矩阵可以人为地生成,也可以调用MATLAB提供的函数来定义色图矩阵。
3
.三维表面图形的着色
三维表面图实际上就是在网格图的每一个网格片上涂上颜色。surf函数用缺省的着色方式对网格片着色。除此之外,还可以用shading命令来改变着色方式。
shading faceted
命令将每个网格片用其高度对应的颜色进行着色,但网格线仍保留着,其shading flat命令将每个网格片用同一个颜色进行着色,且网格线也用相应的颜色,从而使得图形表面显得更加光滑。
shading interp
命令在网格片内采用颜色插值处理,得出的表面图显得最光滑。
颜色是黑色。这是系统的缺省着色方式

   3种图形着色方式的效果展示。
程序如下:
[x,y,z]=sphere(20);
colormap(copper);
subplot(1,3,1);
surf(x,y,z);
axis equal
subplot(1,3,2);
surf(x,y,z);shading flat;
axis equal
subplot(1,3,3);
surf(x,y,z);shading interp;
axis equal
  
光照处理
MATLAB
提供了灯光设置的函数,其调用格式为:
light('Color',
选项1,'Style',选项2,'Position',选项3)

光照处理后的球面。
程序如下:
[x,y,z]=sphere(20);
subplot(1,2,1);
surf(x,y,z);axis equal;
light('Posi',[0,1,1]);
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');
   
图形的裁剪处理
4-22  绘制三维曲面图,并进行插值着色处理,裁掉图中xy都小于0部分。
程序如下:
[x,y]=meshgrid(-5:0.1:5);
z=cos(x).*cos(y).*exp(-sqrt(x.^2+y.^2)/4);
surf(x,y,z);shading interp;
pause                 %
程序暂停
i=find(x<=0&y<=0);
z1=z;z1(i)=NaN;
surf(x,y,z1);shading interp;
为了展示裁剪效果,第一个曲面绘制完成后暂停,然后显示裁剪后的曲面。

图像处理与动画制作
图像处理
1
imreadimwrite函数
imread
imwrite函数分别用于将图像文件读入MATLAB工作空间,以及将图像数据和色图数据一起写入一定格式的图像文件。MATLAB支持多种图像文件格式,如.bmp.jpg.jpeg.tif等。
2
imageimagesc函数
这两个函数用于图像显示。为了保证图像的显示效果,一般还应使用colormap函数设置图像色图。
5-23  有一图像文件flower.jpg,在图形窗口显示该图像。
程序如下:
[x,cmap]=imread('flower.jpg');  %
读取图像的数据阵和色图阵
image(x);colormap(cmap);
axis image off    %
保持宽高比并取消坐标轴

动画制作
MATLAB
提供getframemovieinmovie函数进行动画制作。
1
getframe函数
getframe
函数可截取一幅画面信息(称为动画中的一帧),一幅画面信息形成一个很大的列向量。显然,保存n幅图面就需一个大矩阵。

2moviein函数
moviein(n)
函数用来建立一个足够大的n列矩阵。该矩阵用来保存n幅画面的数据,以备播放。之所以要事先建立一个大矩阵,是为了提高程序运行速度。
3
movie函数
movie(m,n)
函数播放由矩阵m所定义的画面n次,缺省时播放一次。
   绘制了peaks函数曲面并且将它绕z轴旋转。
程序如下
[X,Y,Z]=peaks(30);
surf(X,Y,Z)
axis([-3,3,-3,3,-10,10])
axis off;
shading interp;
colormap(hot);
m=moviein(20);            %
建立一个20列大矩阵
for i=1:20
view(-37.5+24*(i-1),30)      %
改变视点
m(:,i)=getframe;            %
将图形保存到m矩阵
end
movie(m,2);                 %
播放画面2

转载于:https://www.cnblogs.com/AI-Algorithms/p/3672126.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/423678.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java面试题 21 下列说法正确的有()

下列说法正确的有&#xff08;&#xff09; A 能被java.exe成功运行的java class文件必须有main()方法 B J2SDK就是Java API C:Appletviewer.exe可利用jar选项运行.jar文件 D能被Appletviewer成功运行的java class文件必须有main()方法 蒙蔽树上蒙蔽果&#xff0c;蒙蔽树下…

not enough arguments for format string

如果想要在格式化中显示百分号%, 需要写成%%,因此正确的写法是&#xff1a;item_add (%s test%%) % i

IIS 崩溃的后的感受

我的IIS 崩溃后&#xff0c;从控制面板中 重新安装也没有办法&#xff0c;系统在安装时仍然不能正确安装在控制面板中卸载掉&#xff0c;也是停在那里&#xff0c;无法删除。郁闷啊。找到下面的脚本&#xff0c;算是帮了自己的大忙。IIS.txt [Components] iis_commonon iis_ine…

[翻译]SQL Server 未公开的两个存储过程sp_MSforeachtable 和 sp_MSforeachdb

SQL Server 未公开的两个存储过程sp_MSforeachtable 和 sp_MSforeachdb 您是否曾经写过代码来处理数据库中的所有表&#xff1f;处理一个 SQL Server实例中的所有数据库的代码又该如何写&#xff1f;然则&#xff0c;您是否知道有多种方法可以解决这问题&#xff1f;您可以创建…

Java面试题 22 牛客 Java是一门支持反射的语言,基于反射为Java提供了丰富的动态性支持

Java面试题 22 牛客 Java是一门支持反射的语言,基于反射为Java提供了丰富的动态性支持&#xff0c;下面关于Java反射的描述&#xff0c;哪些是错误的&#xff1a;( ) A Java反射主要涉及的类如Class, Method, Filed,等&#xff0c;他们都在java.lang.reflet包下 B 通…

sqlserver关键字

ROWCOUNT Transact-SQL 语句可以通过下列方式设置 ROWCOUNT 的值&#xff1a; 将 ROWCOUNT 设置为受影响或被读取的行的数目。可以将行发送到客户端&#xff0c;也可以不发送。 保留前一个语句执行中的 ROWCOUNT。将 ROWCOUNT 重置为 0 但不将该值返回到客户端。 执行简单分配的…

linux 执行sh 文件是遇到找不到cd '目录'

在linux中将多个php命令写到同一个sh文件中执行 #!/bin/bash/ cd /www/sf/ /usr/local/bin/php xxx.php /usr/local/bin/php xxx1.php /usr/local/bin/php xxx2.php 然后执行命令 sh xxx.sh 有的时候会出现 找不到/www/sf/目录 为什么呢&#xff0c;找了下资料&#xff0c;是…

Asp.Net Session 丢失的奇怪问题,求救!

Asp.Net Session 丢失的奇怪问题&#xff0c;求救我遇到一个很奇怪的 asp.net 问题&#xff0c;我有三个页面&#xff1a;login.aspx &#xff1a;实现输入帐号密码&#xff0c;将帐号&#xff08;yh &#xff1a;用户&#xff09;及权限 ( js_id &#xff1a;角色ID) 保存为 s…

java面试题23 牛客ArrayLists和LinkedList的区别,下述说法正确的有?

java面试题23 牛客ArrayLists和LinkedList的区别&#xff0c;下述说法正确的有&#xff1f; A ArrayList是实现了基于动态数组的数据结构&#xff0c;LinkedList基于链表的数据结构。 B 对于随机访问get和set&#xff0c;ArrayList觉得优于LinkedList&#xff0c;因为LinkedL…

制作特殊字的脚本

<html> <head> <title>特殊文字的制作</title> <meta http-equiv"Content-Type" content"text/html; charsetgb2312"> </head> <body text#00ff00 bgColorblack οnlοade(d.q)> <center>特殊文字的制作…

cursor.execute(sql) 执行结果集是有记录的 但是num=cursor.rownumber 返回值为0

开始cursor.execute(.join(str(sql).strip())) #count cursor.rowcount; numcursor.rownumber修改后&#xff1a;cursor.execute(.join(str(sql).strip())) cursor.fetchall(); #count cursor.rowcount; numcursor.rownumber print(---------------) print (cursor.rownumber) …

Java Web 应用概述

1、java Web 应用是建立在java语言基础上的企业web应用系统&#xff0c;oracle公司根据行业发展和便于开发制定了一套规范&#xff1a;Java EE规范&#xff0c;截至到当前&#xff08;2016.3.11&#xff09;是java EE7规范&#xff0c;其中包括大家常见的Java Servlet 、JavaSe…

java面试题24 关于Java中的数组,

java面试题24 关于Java中的数组&#xff0c;下面的一些描述&#xff0c;哪些描述是准确的&#xff1a;&#xff08; &#xff09; A 数组是一个对象&#xff0c;不同类型的数组具有不同的类 B 数组长度是可以动态调整的 C 数组是一个连续的存储结构 D:一个固定长度的…

[开发技巧3]不显示报表直接打印

水晶报表9.2VB6 使用Application可以进行打印 在将数据赋给报表模板后&#xff0c;调用PrintOut方法 赋给报表数据objCRReport.Database.SetDataSource rst 此句打印&#xff0c;会出现打印提示框objCRReport.PrintOut 不提示&#xff0c;直接打印到默认打印机CallobjCRReport.…

python中cursor操作数据库(转)

原文出处&#xff1a;http://doudouclever.blog.163.com/blog/static/175112310201284115340663/python 操作数据库&#xff0c;要安装一个Python和数据库交互的包MySQL-python-1.2.2.win32-py2.5.exe&#xff0c;然后我们就可以使用MySQLdb这个包进行数据库操作了。 操作步…

java面试题25 在程序代码中写的注释太多,会使编译后的程序尺寸变大。

java面试题25 在程序代码中写的注释太多&#xff0c;会使编译后的程序尺寸变大。 A:正确 B:错误 蒙蔽树上蒙蔽果&#xff0c;蒙蔽树下你和我 拿到这道题&#xff0c;我觉得说的贼有道理&#xff0c;注释太多&#xff0c;尺寸变大。无疑与就和驾考 一样&#xff0c;遇到路人…

implicit request ?

不了解或不會Action在play framework很難再深入下去, 這是http request的點 以下這段代碼困擾我很久, 如今我才剛了解 Action { implicit request >Ok("Got request [" request "]") } 原文這麼說 It is often useful to mark the request parameter …

SQL开发中容易忽视的一些小地方( 三)

目的&#xff1a;这篇文章我想说说我在工作中关于in和union all 的用法. 索引定义 &#xff1a; 微软的SQL SERVER提供了两种索引&#xff1a;聚集索引(clustered index&#xff0c;也称聚类索引、簇集索引)和非聚集索引(nonclustered index&#xff0c;也称非聚类索引、非簇集…

java面试题26 java语言的下面几种数组复制方法中,哪个效率最高?

java面试题26 java语言的下面几种数组复制方法中&#xff0c;哪个效率最高&#xff1f; A for 循环逐一复制 B System.arraycopy C Array.copyOf D 使用clone方法 效率&#xff1a;System.arraycopy > clone > Arrays.copyOf > for循环 1、System.arraycopy的用法…

pycharm使用笔记2-远程连接(转)

原文地址:https://blog.csdn.net/jinxiaonian11/article/details/70208920 随着科技的发展&#xff0c;远程办公已经是一种趋势&#xff0c;远程开发能力对于每一个程序员来说都是必不可少的。有时候就算在公司&#xff0c;在进行开发的时候有许多的数据都是储存在服务器上的&a…