首先先分析对象。将数据利用matlab画出图,最开始是导入数据,然后处理数据,最后将处理的数据画出来。

所以我将它分为三个步骤。

第一步:导入数据

* 如果是mat数据。可以直接load
* 如果是txt数据。可以用txtread
* 如果是excel数据。可以用xlsread
详细的,可以参考https://blog.csdn.net/blueskyjian/article/details/72832449
<https://blog.csdn.net/blueskyjian/article/details/72832449>

代码如下:
%% 导入数据 clear all;clc;close all; load xyzdata.mat;%导入的的数据应当去除NaN值
这是我的数据截图:



注:需要注意的是,要将数据的NaN(空值)去掉。可以在matlab工作去查看,并去除。

第二步:数据处理

由于我们的x、y轴数据,并不是1 、 2 、3等这样的整数排列的,所以必须利用原有的数据,重新构造三维数据。

重构三维数据主要有两步:

* 第一步:栅格化,用到meshgrid()函数
* 第二步:插值,用到griddata()函数
栅格化原理、效果可以参考https://blog.csdn.net/shanchuan2012/article/details/72772191
<https://blog.csdn.net/shanchuan2012/article/details/72772191>

简单来时就是绘制网格

插值原理、效果可以参考https://blog.csdn.net/pingmin2014/article/details/47298947
<https://blog.csdn.net/pingmin2014/article/details/47298947>

简单来说就是估计绘制网格格点的z的数据

代码如下:
%% 相关计算 [a,~]=size(xRow);%x轴数据总共*******行; xmax=max(xRow);%x轴数据最大值为********
xmin=min(xRow);%x轴数据最小值为********* %下面两行是测试用的,便于设置间隔值
%delta_x=xmax-xmin;%x轴范围宽度值为*****
%delta_x/a;%z轴间隔大约为1.4796e-04,可以设置为0.01,如果想要更为精确,可以设置为0.001、0.0001
[b,~]=size(yCol);%y轴数据为******** ymax=max(yCol);%y轴数据最大值为********
ymin=min(yCol);%y轴数据最小值为******** %下面两行是测试用的,便于设置间隔值
%delta_y=ymax-ymin;%轴范围宽度值为为*********
%delta_y/b;%y轴间隔大约为9.9876e-05,可以设置为0.01,如果想要根为精确,可以设置为0.001、0.0001
第三步:画图

这一步需要注意的是:选好网格间隔,网格间隔越小,精确度越高,相对应的,计算量越大,电脑性能要求越高。

电脑性能不高的,可以跳大间隔,同时优化代码,清除画图用不了的变量。

代码如下:
%% 重构三维数据,画图 %间隔为 0.05的时候,X Y数据为 *****×****, 电脑一般的,将间隔调大 %间隔为 1的时候,X Y数据为
***×****, 电脑 好的,将间隔调小
[X,Y]=meshgrid(xmin:1:xmax,ymin:1:ymax);%将x、y轴网格化,重构用于画图x、y轴数据
Z=griddata(xRow,yCol,z,X,Y);%插值,重构用于画图的Z轴数据 clear a b xmax xmin ymin ymax xRow
yCol z; mesh(X,Y,Z)
实验结果:



由于保密需要吗,图像结果打上马赛克,数据也不能提供。

完整代码:
%利用txt excel等大量x y z数据,化三维立体图 %% 导入数据 clear all;clc;close all; load
xyzdata.mat;%导入的的数据应当去除NaN值 %% 相关计算 [a,~]=size(xRow);%x轴数据总共********行;
xmax=max(xRow);%x轴数据最大值为********** xmin=min(xRow);%x轴数据最小值为********
%下面两行是测试用的,便于设置间隔值 %delta_x=xmax-xmin;%x轴范围宽度值为*****
%delta_x/a;%z轴间隔大约为1.4796e-04,可以设置为0.01,如果想要更为精确,可以设置为0.001、0.0001
[b,~]=size(yCol);%y轴数据为****** ymax=max(yCol);%y轴数据最大值为******
ymin=min(yCol);%y轴数据最小值为******** %下面两行是测试用的,便于设置间隔值
%delta_y=ymax-ymin;%轴范围宽度值为为******
%delta_y/b;%y轴间隔大约为9.9876e-05,可以设置为0.01,如果想要根为精确,可以设置为0.001、0.0001 %% 重构三维数据,画图
%间隔为 0.05的时候,X Y数据为 *****×****, 电脑一般的,将间隔调大 %间隔为 1的时候,X Y数据为 ***×***, 电脑
好的,将间隔调小 [X,Y]=meshgrid(xmin:1:xmax,ymin:1:ymax);%将x、y轴网格化,重构用于画图x、y轴数据
Z=griddata(xRow,yCol,z,X,Y);%插值,重构用于画图的Z轴数据 clear a b xmax xmin ymin ymax xRow
yCol z; mesh(X,Y,Z)
给学matlab的人,包括我自己一个勉励:路漫漫其修远兮,吾将上下而求索。

友情链接
KaDraw流程图
API参考文档
OK工具箱
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:ixiaoyang8@qq.com
QQ群:637538335
关注微信