Matlab数据与函数的作图a.ppt
《Matlab数据与函数的作图a.ppt》由会员分享,可在线阅读,更多相关《Matlab数据与函数的作图a.ppt(100页珍藏版)》请在三一办公上搜索。
1、第三章 数据与函数的作图,本章导读作图功能是MATLAB的特长之一,MATLAB提供高端和低端作图命令,我们可以非常方便地将数据绘制成二维、三维的图形,而高端命令可以让我们随心所欲地画出各种函数图形。作图分为两大类,一类是数据作图,如给定数组x,y作数据的图形。一类是给一个函数直接作图,如做的图形。事实上图形正在演变成一种语言,它可以用更直观的形式展示问题的内涵。在数学建模竞赛中,我们的论文广泛使用图文并茂的形式,可以更好地说明解决问题的思路。特别是在国际数学建模竞赛MCM、ICM中,由于中国学生的语言表达能力,特别是书面表达能力不如以英语为母语的美国、英国、澳大利亚的等国家,因此在论文中多插
2、图形往往可以收到事半功倍的效果。,MATLAB作图功能十分强大,在三维作图中甚至物体在视角、光线以及材质上都能反映出来。我们将介绍图形的基本概念,以及用构架数组描述图形的机理,一些基本的命令和方法,其他命令可以举一反三。在本章的后半部分介绍图形界面的产生,可视化方法产生图形界面的方法。利用可视化界面可以让我们构造一个实验环境,对研究和探讨问题有一定的帮助。,3.1 作图命令的搜索,在界面上点击help功能,然后进行plot关键字的搜索见图,在这里列出了几乎所有和plot有关的图形命令,单击任何你需要的命令,在右边的窗口中可以看到该命令的语法、使用方法和一些示例。例如打开plot,下面的例子初步
3、展示MATLAB作离散图和连续图的例子。,【例3.1.1】打开plot,我们可以看到有关plot的语法说明,实例等。见图,根据帮助功能我们就可以方便地编程,例如作函数的图形,这里用数据作图。x=-pi:pi/10:pi;%产生自变量数组x(-pi,pi)y=tan(sin(x)-sin(tan(x);%产生相应因变量点的数组yplot(x,y,-rs,LineWidth,2,MarkerEdgeColor,k,.MarkerFaceColor,g,.MarkerSize,10)%作数据x,y的图形,并定义线的颜色、点的形状等。,【例3.1.2】用图形表示连续调制波形。t1=(0:11)/11*
4、pi;%产生12个自变量的点y1=sin(t1).*sin(9*t1);t2=(0:100)/100*pi;产生101个自变量的点y2=sin(t2).*sin(9*t2);subplot(2,2,1),plot(t1,y1,r.),axis(0,pi,-1,1),title(子图(1)subplot(2,2,2),plot(t2,y2,r.),axis(0,pi,-1,1),title(子图(2)subplot(2,2,3),plot(t1,y1,t1,y1,r.)axis(0,pi,-1,1),title(子图(3)subplot(2,2,4),plot(t2,y2),axis(0,pi,
5、-1,1)title(子图(4),【例3.1.4】用曲面图表现函数。首先取x,y轴的点,利用meshgrid命令产生x-y平面的网格点,在每个网格点上计算函数的值。x=-4:4;y=x;X,Y=meshgrid(x,y);%生成 x-y 坐标网格点矩阵Z=X.2+Y.2;%计算格点上的函数值surf(X,Y,Z);hold on,colormap(hot)stem3(X,Y,Z,bo)%用来表现在格点上计算函数值,3.2 图形基本概念和图形设置命令,3.2.1 图形基本概念 图形事实上是我们使用计算机命令在计算机屏幕(root)上绘制的各种对象(object)的组合,这些对象包括图形显示框及其
6、子对象,如各种菜单、各种工具图标和正方形的空白绘图显示区,以及在这个区域中用plot、surf等命令作出的图形对象、颜色对象、光线对象、注释对象等等。众多的对象组成的有机体形成了特色鲜明的计算机图形。下面我们列出主要的对象及其注释,见表,对象是分层次的,在一个图形中有父对象、子对象、兄妹对象等。如Root是Fiugre的父对象,Image是Figure的孙对象,而Axes和Uicontrol等是同辈对象。此图形结构可以用构架数组来表示,如MATLAB特有的句柄构架数组(handle structure)。典型的层次见图,在一个图形中除了图形本身外还有各种修饰命令,例如图形的标题、坐标的名称、线
7、条的颜色和粗细,在三维图形中还要考虑立体光线等等。合理地使用这些修饰命令将使我们的图形更好看,更具说服力。下例是由多个对象组成的图形。,3.2.2 图形各目标的设置命令set和信息传递命令get当我们用高端作图命令如plot、surf进行作图时,实际是调用个图形的构架数组。包括图形框架、菜单、工具图标、坐标、图形背景颜色以及图形等等各种层次对象(objects)。有关这些对象的设置都是系统内定的值,如果想改变某一个对象的属性的值,使用set命令来重新设置。在一个图形界面上对各对象之间进行信息传递,可以用get命令获取某窗口中的信息。先介绍图形句柄的概念。我们来看几个术语:gcf:为当前图形句柄
8、(current figure handle),即获得由作图命令产生的图的图形层次结构。gca:为图形当前的坐标系统(the handle to the current axes)。设置图形参数命令set的语法和获取属性信息的命令get:,set(H,PropertyName,PropertyValue,.)%对句柄H各种属性重新设置,set(H,a)%和上面命令等价,而将参数全部放入构架数组a,set(H,pn,pv.)%和上面命令等价,而将参数全部放入元胞数组pn和pv,set(H,pn,)%对多个句柄进行同时设置,a=set(h)%对象h的属性和值放到构架数组a中,a=get(0,Fac
9、tory)%将当前整个句柄所有属性的值放到构架数组a中,a=get(0,FactoryObjectTypePropertyName)%将当前句柄的某个属性和值放入a中,a=set(h,Default)%将对象h的内定值放到构架数组中,a=set(h,DefaultObjectTypePropertyName)%将某个属性放到构架数组中,=set(h,PropertyName)%将某个属性值放到元胞数组中,H:为句柄,如gcf、gca等等。PropertyName:为该句柄下的属性名,如线型、点的颜色等。PropertyValue:一个属性名的值,如线型实线或虚线等,点可以取红、蓝等等。a:为一
10、个构架数组,用于存放参数PropertyName,PropertyValue,.,当参数很多时用构架数组进行说明较为方便。pn:为元胞数组,存放各种属性名PropertyName1,PropertyName2,vp:为元胞数组,存放各种属性名相应的值PropertyValue1,PropertyValue2,,【例3.2.1】作两幅图,并用set命令重设一些属性,用get显示属性的改变。x=linspace(-pi,pi,10);y=sin(x)subplot(1,2,1),h=plot(x,y)%用系统内定的参数作图a=get(h)%显示图形的每种特性的参数subplot(1,2,2),h=
11、plot(x,y)set(h,LineStyle,-,LineWidth,1,Marker,d)b=get(h)%显示修改过的特性的参数,属性参数为:b=BeingDeleted:off BusyAction:queue ButtonDownFcn:Children:0 x1 double Clipping:onColor:0 0 1 CreateFcn:DeleteFcn:EraseMode:normal HandleVisibility:on HitTest:on Interruptible:on,LineStyle:-%已改变 LineWidth:1%已改变 Marker:diamond
12、%已改变 MarkerEdgeColor:auto MarkerFaceColor:none MarkerSize:6 Parent:150.0005 Selected:off SelectionHighlight:on Tag:Type:line UIContextMenu:UserData:Visible:on XData:1x10 double YData:1x10 double ZData:1x0 double,【例3.2.2】对于例可以用构架数组来改变特性的参数,以下程序可以获得一样的结果。x=linspace(-pi,pi,10);y=sin(x)subplot(1,2,1),h=
13、plot(x,y)%用系统内定的参数作图a=get(h)subplot(1,2,2),h=plot(x,y)b=get(h)act.LineStyle=-;%定义构架数组中线形的参数act.LineWidth=1;%定义构架数组中线宽的参数act.Marker=d;%定义构架数组中点型的参数set(h,act)set和get命令在作图,特别是以后介绍的界面设计中起着关键性的作用,在后面的部分还有介绍。进一步的学习可查阅help中的set和get的关键字。,3.3 数据二维作图和图形编辑,3.3.1 二维作图 表列出了作图的大概步骤,【例3.3.1】以我国国民生产总值的数据为例,进行作图和拟合研
14、究,首先作出数据的图形,然后我们进行拟合的各种实验,从中找出满意的结果。A=load(e:datazggdp.txt)%定义n行两列的时间序列数组x=A(:,1)%将时间定义为数组xy=A(:,2)%将gdp(国民生产总值)定义为yplot(x,y,r*)%将数据点用红色,*形绘制图形结果我们可以看界面图,打开界面菜单Tools,并点击Basic Fitting 我们就可以看到以下界面。见图,在Basic Fitting栏下我们可以选择各种拟合方法,选择线性linear和7阶多项式进行拟合。对作残差图Plot residuals进行勾选,表示要做残差分析。我们可以明显地看出7阶多项式拟合明显好
15、与线性拟合。在第二张图形上显示了两种拟合的残差,残差图更证明了我们的判断。见图,二维图形的编辑与完善 另一方法是直接在图形窗口上对图形进行编辑。一、用图形修饰命令对图形进行编辑用命令来完整地修饰图形,事实上是编一套程序,其具体格式为:作图命令(数据,子命令,子命令,子命令)修饰命令1修饰命令2 修饰命令n以下将二维作图的曲线线型选择和颜色选择命令罗列为表,点的颜色、点边界的颜色、点的大小设置等见表3.3.3,点型的选择见表,图形标注辅助修饰命令与图形子命令不同,它不在图形命令内,而是作为独立的命令紧跟在图形命令后面。主要的图形辅助修饰命令见表,【例3.3.2】利用上面的修饰命令作一个完的整修饰
16、图形,图形标题为“我的完善图”。x=-pi:pi/10:pi;y=tan(sin(x)-sin(tan(x);%准备数据%作曲线图,曲线设为虚线,线宽为2,红颜色。点的边界为黑色,点面色为绿色,%点的大小设为10。plot(x,y,-rs,LineWidth,2,.MarkerEdgeColor,k,.MarkerFaceColor,g,.MarkerSize,10);legend(tan(sin(x)-sin(tan(x),1)%在图内标注公式xlabel(时间)%坐标x标为时间ylabel(函数)%坐标y标为函数 title(我的完善图)%图形标题注为“我的完善图”,clf;t=0:pi/
17、50:2*pi;y=sin(t);plot(t,y);axis(0,2*pi,-1.2,1.2)text(pi/2,1,fontsize16leftarrowitsin(t)fontname隶书极大值),二、在窗口界面上对图形进行直接修饰 利用命令进行修饰的大部分功能可以更方便、更直观地利用窗口编辑功能进行。免去了编程步骤。我们以下面的例子来说明。,【例3.3.4】用窗口编辑功能对图形进行修饰。首先仅将图形简单绘出。t=0:pi/50:2*pi;y=sin(t);plot(t,y),进入编辑状态,对图形加文字,在图形中加箭头,在编辑状态下我们选定曲线,即用鼠标单击曲线的任何部位,这时我们可以看
18、见该曲线对象变为当前状态。见图,双击该曲线,我们就可以看到设置曲线的界面,如图,在这里我们可以设置曲线的类型如实线、各类虚线,线宽,颜色等,还可以设置点的类型、大小、边界颜色和点的颜色等等。现在我们来设置一下,同时加入一些注释,其效果图见图,3.4 数据三维图形绘制和各种修饰,三维图形为立体图形,和二维图形有了本质的不同。(1)三维图形有了视角的概念,不同的视角对于同一物体会产生不同的视觉效果,因此必须有刻画视角的view修饰命令。(2)光线的照射角度也会对物体的视觉效果产生影响,因此必须有刻画光线照射角度的命令。(3)颜色的设置也会对视觉产生影响,因此要有刻画颜色的命令。(4)对于一个空间的
19、物体,我们不但需要从外观上了解它的性状,同时需要对它的横截面进行了解。例如利用磁共振方法我们可以得到人的大脑的数据,我们可以利用解剖图来检查脑部是否有病变,因此我们还需要有能够进行切片的命令slice来描述这样的情况。MATLAB为我们提供了丰富的立体修饰命令,因此三维作图的内容多也较二维图形复杂的多。,3.4.1 三维图形的绘制,MATLAB为我们提供了各种三维数据的曲面作图命令,它们可以作空间的曲线、空间的曲面、等高线图、各种方向上的投影图、空间的散点图等等。这些命令都是高端命令,既可以根据数据矩阵作图,又可以根据函数进行作图。现将主要命令列表如下:,尽管三维图形的修饰命令比较多,然而其基
20、本步骤和二维图形还是差不多的。表列出了三维作图的基本步骤。,MATLAB中提供了很多实际例子的数据,这些例子都是广泛流行的教材中的实例,为我们理解和学习提供了方便。如美国人口从1900年到1970的普查数据,peaks(峰函数数据)、wind(风向数据)、mri(脑部磁共振数据)等。下面我们来看一些实例。,【例3.4.1】利用plot3命令,对极坐标三维数据作空间曲线图。t=0:pi/50:10*pi;plot3(t.*sin(t),t.*cos(t),t,LineWidth,2)%作空间曲线图,线宽为2axis square;grid on%x,y,x坐标的比例是相等的,peaks是MATL
21、AB提供的一个产生peaks函数数据的命令,它可以根据用户的要求产生peaks数据点的稀密程度,从而产生精确度不同视觉效果的图形。【例3.4.2】利用MATLAB给定的数据矩阵peaks作立体图。X,Y,Z=peaks(50);%用peaks函数产生5050的X-Y面上的点,并计算Zsurfc(X,Y,Z)%用数据X,Y,Z产生曲面图形和等高线图colormap hsv%对图形着色 axis(-3 3-3 3-10 5)%给出作图的坐标范围,注意,有关图形的其他修饰上面的程序没有写出,如图形的视角、光线的设置、曲面表面的性质、曲面的材质等等,这时计算机对这些对象有一个系统内定值或者称为缺省。,
22、【例3.4.3】人体头部磁共振数据mri为MATLAB提供的案例数据,它是大脑内部结构的影像数据。数据结构为四维(128128127)数组,其中最后的维数是按z轴对脑部切片的27幅横截面映像图。我们可以从各个角度、内部和外部来窥视这批数据。本例只是观看该多维数据的外表,并显示对数据的平滑和光线的处理并作图。load mri%读入脑磁共振数据并放如数组D中D=squeeze(D);%抽去D中第三维,数据变为立体数据(12812827)Ds=smooth3(D);%对数据进行平滑处理hcap=patch(isocaps(D,5),.%对脑上部用一片横截面盖住,对颜色进行插值平滑。FaceColor
23、,interp,.EdgeColor,none);hiso=patch(isosurface(Ds,5),.%对脑周围数据建立外表面,并着色。FaceColor,1,.75,.65,.EdgeColor,none);view(45,30)%建立视角axis tight%设置坐标为紧凑参数值daspect(1,1,.4)%对坐标设置适当的比率lightangle(45,30);%定义光源的角度set(gcf,Renderer,zbuffer);lighting phong%对当前图形句柄进行设置isonormals(Ds,hiso)%计算数据边缘的模 set(hcap,AmbientStreng
24、th,.6)%设置头顶部参数set(hiso,SpecularColorReflectance,0,SpecularExponent,50);%设置表面的参数,3.4.2 图形颜色命令colormap,现在我们开始学习图形修饰命令,三维图形修饰命令十分丰富,包括对图形上色、设置图形的视角、对图形进行平滑处理、设置图形目标的材质等等。我们面对的是一个平面的屏幕,何以能显示一个立体的图形呢?例如我们在纸上画一个球。首先用圆规画一个圆,然后根据光学和透视原理在圆中画上深浅不同的色彩,这时我们就可以在平面的纸上看出一个逼真的球形了。同样的道理,计算机显示一个立体物,除了给定的数据点组成的图形框架外,还
25、对每一数据点映射一个颜色,或者说在作图时每个数据矩阵对应一个颜色矩阵,我们就可以作出形象逼真的立体彩色图形了。颜色矩阵是3列n行的,它对应n个数据点。colormap就是对数据点加载某种颜色矩阵的函数,其示意图如下:,数据矩阵DM 颜色矩阵CM,colormap(CM),这里,颜色矩阵的元素为界于0和1之间的实数,因此颜色矩阵CM的每一行都是由红、绿、蓝调成的某种颜色。例如:表列出了部分颜色数据的调色结果。,【例3.4.4】利用colormap命令选择颜色趋势。读入液体流出的数据(1)取灰色load flujetimage(X)colormap(gray),(2)colormap选择参数为je
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Matlab 数据 函数 作图
链接地址:https://www.31ppt.com/p-5439134.html