这里是一个示例数据集。
x = linspace(10,20,50);
y = linspace(10,20,50);
z = cos(linspace(0,2*pi,50));
time = linspace(1,60,50);
sci_temp = randi(100,50,1);x,y,z是位置,sci_temp是温度数据。
我想知道如何用sci_temp数据在xyz位置上绘制轨迹。
我尝试插值数据,所以用sci_temp图得到二维插值时间vs。
S = TriScatteredInterp(time',z',sci_temp);
[t_mesh z_mesh] = meshgrid(time,z);
tz_mesh = S(t_mesh, z_mesh);
pcolor(t_mesh,z_mesh,tz_mesh)

我想要得到的是一个2D (时间vs sci_temp)剖面图上的xyz三维图。就像这张照片。

如何在三维图形中显示sci_temp上的轨迹?
有人能帮我吗?
谢谢
发布于 2016-08-09 13:48:15
首先,你做的插值有点错误,你不想在由
meshgrid(time,z);因为它会复制值。创建的网格上进行插值。
meshgrid(time,linspace(min(z),max(z),50));一旦得到插值值,如下所示:

您可以用surface函数在3D空间中绘制它们,只需确保适当地给出x和y坐标。
surface(repmat(x,50,1),repmat(y,50,1),zmesh,tzmesh)

您甚至可以有更复杂的路径,例如,相同的数据但是y=z。

编辑:另外,我忘了提到,我建议您使用scatteredInterpolant而不是TriScatteredInterp。它让你对插值有更多的控制
https://stackoverflow.com/questions/38850665
复制相似问题