matlab 三个向量数据绘制曲面图

假设数据是a,b,c三个列如果使用plot3(a,b,c),将得到



使用

[X,Y] = meshgrid(b,c);
[~,Z] = meshgrid(a);
figure;surf(Z,X,Y);

得到



使用插值的话

[X,Y]=meshgrid(linspace(min(b),max(b),100),linspace(min(c),max(c),100)) ;
Z=griddata(b,c,a,X,Y);
figure;
surf(Z,X,Y,'FaceColor','interp',...
   'EdgeColor','none',...
   'FaceLighting','phong')
axis tight




以上程序使用了b,c,a的顺序 ,顺序不同  结果不同 

  • 6
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实验三 MATLAB绘图 一、实验目的 1.掌握二维形的绘制。 2.掌握形的标注 3.了解三维曲线和曲面形的绘制。 二、实验的设备及条件 计算机一台(带有MATLAB7.0以上的软件环境)。 设计提示 1.Matlab 允许在一个形中多条曲线:plot(x1,y1,x2,y2,……)指令绘制y1 = f1(x1), y2 = f2 (x2 )等多条曲线。Matlab自动给这些曲线以不同颜色。标注可用text 函数。 2.绘图时可以考虑极坐标和直角坐标的转换。 3.三维曲线绘图函数为plot3,注意参考帮助中的示例。 三、实验内容 1.生成1×10 维的随机数向量a,分别用红、黄、蓝、绿色绘出其连线、杆、阶梯和条形,并 分别标出标题"连线"、"杆"、"阶梯"、"条形"。 2、绘制函数曲线,要求写出程序代码。 (1) 在区间[0:2π]均匀的取50个点,构成向量t (2) 在同一窗口绘制曲线y1=sin(2*t-0.3); y2=3cos(t+0.5);要求y1曲线为红色点划线,标记点为圆圈;y2为蓝色虚线,标记点为 星号。 (3) 分别在靠近相应的曲线处标注其函数表达式。 3.将形窗口分成两个绘图区域,分别绘制出函数: 在[0,3]区间上的曲线,并利用axis调整轴刻度纵坐标刻度,使在[0,12]区间 上,在[-2,1.5]区间上。 4.用mesh或surf函数,绘制下面方程所表示的三维空间曲面,x和y的取值范围设为 [-3,3]。 思考题: 1. 编写一个mcircle(r)函数,调用该函数时,根据给定的半径r,以原点为圆心, 一个如所示的红色空心圆。(例半径r=5);左参考polar函数的用法 ,右绘制圆形的参数方程为x=sin(t),y=cos(t)。其中,t的区间为0~ 2*pi,步长为0.1。 2.(1)绘一个圆柱螺旋线(形似弹簧)。圆柱截面直径为10,高度为5,每圈上 升高度为1。如左所示。 (2)利用(1)的结果,对程序做少许修改,得到如右所示形。 四、实验报告要求(包含预习报告要求和最终报告要求) 1.实验名称 2.实验目的 3.实验设备及条件 4.实验内容及要求 5.实验程序设计 指程序代码。 6.实验结果及结果分析 实验结果要求必须客观,有数据的可以记录数据,没有数据的简单描述实验现象。结果分 析是对实验结果的理论评判。 7.实验中出现的问题及解决方法 8. 思考题的回答 1. 实验报告的提交方式 Word文档,命名方式:实验号_你的学号_姓名!!! 例如本次实验:实验一_000000001_张三.doc (信息101提交报告邮箱):E_mail: matlab[email protected] (网络工程101提交作业邮箱):E_mail: Matlab[email protected](注意网络班的M是大写的) 下一次课前提交,过期不收! 2. 参考文献 参考教材和Matlab帮助文件。 实验名称 MATLAB绘图 实验目的 1.掌握二维形的绘制。 2.掌握形的标注 3.了解三维曲线和曲面形的绘制。 实验设备及条件 计算机一台(带有MATLAB7.0以上的软件环境) 实验内容及要求 完成所给实验题以及思考题,题与题之间用相应注释分割。注意对实验中出现的相关函 数或变量,请使用help或doc查询相关帮助文档,学习函数的用法。 5.实验程序设计 "第一题: " "a=rand(1,10); " "subplot(2,2,1); " "plot(a,'r'); " "axis('equal'); " "title('连线'); " "subplot(2,2,2) " "stem(a,'y'); " "axis('equal'); " "title('杆'); " "subplot(2,2,3); " "stairs(a,'b'); " "axis('equal'); " "title('阶梯'); " "subplot(2,2,4); " "bar(a,'g') " "axis('equal'); " "title('条形'); " " " " " "第二题: " " " "t=linspace(0,2*pi,50); " "y1=sin(2*t-0.3); " "y2=3*cos(t+0.5); " "k=find(abs(y1-y2)<1e-2); " "t1=t(k); " "y3=sin(2*t1-0.3); " "t2=t(k); " "y4=3*cos(t2+0.5); " "plot(t,y1,'r-.',t,y2,'b:',t1,y3,'rO',t2,y4,'r*') " "xlabel('t'); " "ylabel('y'); " "text(0
MATLAB绘制3D隐函数曲面的方法总结-MarchingCubes.zip 本帖最后由 winner245 于 2013-10-28 00:45 编辑 背景介绍 Matlab提供了一系列绘图函数,常见的包括绘制2D曲线的plot函数、绘制2D隐函数曲线的ezplot函数、绘制3D曲面的mesh和surf函数、绘制3D显函数曲面的ezmesh和ezsurf函数。值得注意的是,ez系列的绘图函数里只有ezplot是绘制隐函数曲线的,ezmesh和ezsurf都是显函数曲面的(不要被ez的名字误解了)。遗憾的是,matlab里并没有提供直接绘制3D隐函数曲面的函数。本帖的目的就是归纳总结几种方便易用的绘制隐函数曲面的办法。 问题描述 如何绘制3元方程f = 0确立的隐函数曲面z = g?其中,方程f = 0无法求解z关于x、y的表达式,即g的显式表达式无法获取。 准备工作——基础函数介绍 为了解决上述问题,我们需要先对几个重要的形函数isosurface、patch、isonormals取得初步的了解,如果您已经对这三个函数很熟悉,可以直接跳过这一步。 l.  isosurface 等值面函数 调用格式:fv = isosurface作用:返回某个等值面(由isovalue指定)的表面(faces)和顶点(vertices)数据,存放在结构体fv中(fv由vertices、faces两个域构成)。如果是隐函数 v = f = 0 的三维形,那么等值面的数值为isovalue = 0。 2.  patch函数 调用格式:patch 以平面坐标为顶点,构造平面多边形,C是RGB颜色向量                    patch以空间3-D坐标为顶点,构造空间3D曲面,C是RGB颜色向量                    patch 通过包含vertices、faces两个域的结构体fv来构造3D曲面,fv可以直接由等值面函数isosurface得到 例如:patch) 3.  isonormals等值面法线函数 调用格式:isonormals实现功能:计算等值面V的顶点法线,将patch曲面p的法线设置为计算得到的法线(p是patch返回得到的句柄)。如果不设置法线的话,得到曲面在过渡地带看起来可能不是很光滑 有了上述三个函数后,我们已经具备间接绘制3D隐函数曲面的能力了。下面以方程 f = x.*y.*z.*log-10 = 0为例,讲解如何3D隐函数曲面。 解决办法一:isosurface patch isonormals实现原理:先定义3元显函数v =f, 则 v = 0 定义的等值面就是z = g的3D曲面。利用isosurface函数获取v= 0 的等值面,将得到的等值面直接输入给patch函数,得出patch句柄p,并出patch曲面的平面视角形。对p用isonormals函数设置曲面顶点数据的法线,最后设置颜色、亮度、3D视角,得到3D曲面。 代码如下: f = @ x.*y.*z.*log-10;      % 函数表达式 [x,y,z] = meshgrid;       % 范围 v = f; h = patch); isonormals               set; xlabel;ylabel;zlabel; alpha    grid on; view; axis equal; camlight; lighting gouraud 复制代码 代码说明: alpha函数用于设置patch曲面的透明度(可以是0~1任意数值),1 表示不透明,0 表示最大透明度。如果想设置透明度为0.7,可以修改alpha为alpha。 使用此代码解决特定问题时,只需将第1行的函数表达式替换为特定问题的函数表达式,将第2行数据(x、y、z)范围换成合适的范围,后续代码无需任何变动。 得到形: 1.png 解决办法二:Mupad Mupad符号引擎里提供了现成的三维隐函数函数:Implicit3d 在matlab里开启Mupad的方法是:在commandwindow 里输入mupad 来启动一个notebook。在启动的notebook里再输入如下代码: plot-10, x = -10..10, y = -10..10, z = -10..10), Scaling = Constrained)复制代码 回车后得到如下形: 1.png 解决办法三:第三方工具包ezimplot3 在matlab central 的 file exchange 上有一个非常优秀的绘制3维隐函数的绘图函数,叫ezimplot3。感兴趣的可以在如下链接下载:http://www.mathworks.com/matlabcentral/fileexchange/23623-ezimplot3-implicit-3d-functions-plotter也可以直接从本帖下载: ezimplot3.zip ezimplot3一共有三种参数调用方式: ezimplot3 函数f= 0 在-2*pi< X < 2* pi, -2* pi < Y < 2* pi, -2* pi < Z < 2* pi上的形ezimplot3函数f= 0 在A< X < B, A < Y < B, A < Z < B上的形ezimplot3函数f= 0 在XMIN< X < XMAX, YMIN < Y < YMAX, ZMIN < Z < ZMAX上的形 ezimplot3使用方法:解压ezimplot3.zip,将解压得到的ezimplot3.m 添加到matlab当前搜索路径后就可以使用了。然后,可以直接在command window 输入代码:f = @ x*y*z*log-10; ezimplot3;  % [-10, 10] 表示形范围x、y、z都在区间[-10, 10] 复制代码 即得到如下形: 1.png 若干说明: ezimplot3和方法一本质上完全相同。即ezimplot3实际上也是基于isosurface patch isonormals的实现ezimplot3与方法一的形视觉效果相同,唯一的区别是,ezimplot3的使用了0.7的透明度:alphaezimplot3在方法一基础上增加了一些外包功能,如:允许函数句柄f是非向量化的函数(即函数定义无需.*  ./  .^),这在ezimplot3内部会自动调用vectorize实现函数向量化。另外,ezimplot3可以在调用的时候方便的设定坐标范围。 常见问题和解决办法: 常见问题:很多人在使用以上方法后,经常出现的问题是代码没有任何错误,程序可以运行,就是出来的形只有一个空坐标轴,看不到形。 问题分析:出现这种问题的原因是形的显示区域没设对。比如,我们上述三种方法都是在x为-10到10的范围内,如果你设的范围内本身就没有形,那当然就看不到形了。解决办法:把形显示范围重新设置对即可,如果不知道形的大致范围,就手工多改几次,直到看到形为止 方法一,形范围是在第2句的meshgrid函数决定的,meshgrid里给出的x、y、z范围就是最终范围,修改meshgrid语句即可。方法二(Mupad),x =-10..10, y = -10..10, z = -10..10是表示显示范围,修改这里即可。方法三,用ezimplot3 ezimplot3两种方式控制形显示范围。 后记:slice切片函数 matlab还提供一种切片形的函数slice,slice做出的是在切片上用颜色表示v的值。有时,我们切片形也有助于我们理解一个4维形。以  v= f = x*y*z*exp)  为例,假设我们希望看 v =f 在 x =0, y = 1, z = 1 这些平面切片的形,我们可以用以下代码: [x,y,z] = meshgrid); v = x.*y.*z.*exp); xslice = 0; yslice = 1; zslice = 1; slice xlabel; ylabel; zlabel; colormap hsv 复制代码 得到形为: 1.png 经常听有人说想 “4D形”,前3维数据[x,y,z]表示空间位置,第4维数据v表示颜色(温度等),这类形可以方便地通过slice切片实现: slice,这里就是在指定的切片上在空间坐标[x,y,z]处,用v值指定颜色。关于这类 “4D形”的法的一个典型例子:https://www.ilovematlab.cn/thread-265517-1-1.html 另外,我在 23 楼提供了一个slice 函数应用的生动例子:slice 3D 动形。感兴趣的朋友可以看看 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% 欢迎大家踊跃讨论,给出更多更好的办法
要在Matlab绘制三维曲面像,可以使用以下几种函数命令: - 使用plot3(x, y, z)函数可以绘制数据三维曲线。 - 使用mesh(x, y, z)函数可以绘制数据三维网格面。 - 使用surf(x, y, z)函数可以绘制数据三维网面。 - 使用meshc(x, y, z)函数可以绘制数据三维网格面,并添加等值线。 - 使用surfc(x, y, z)函数可以绘制数据三维网面,并添加等值线。 - 使用meshz(x, y, z)函数可以绘制数据三维网格面,并添加等值线。 - 使用[X, Y] = meshgrid(x, y)函数可以产生两个矩阵X和Y,其中X的行数等于向量x的长度,列数等于向量y的长度,而Y的行数等于向量y的长度,列数等于向量x的长度。这些矩阵可以用来生成曲面的坐标网格。 根据具体需求和数据形式,你可以根据上述函数命令选择适合的方式来绘制三维曲面像。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [【MATLABMATLAB三维曲面绘制【详细教程】](https://blog.csdn.net/xy_z_H/article/details/124833664)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [MATLAB三维绘图---三维曲面](https://blog.csdn.net/zhangkaikai36/article/details/123403633)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值