在同一图表中绘制多个相似数据

时间:2018-06-07 03:47:46

标签: matlab plot

我想生成一个图(X对Y),Z值取决于Y.示例如下图所示。 X的矩阵大小与Z相同但不是Y.我可以将Z绘制成X,但我想将所有绘图组合成单个绘图并且对X成为Y.我可以将多个绘图绘制成单个绘图但是绘图彼此重叠。

我的问题是,我可以将多个图合并为一个图而不重叠每个图,因为每个图之间的差异非常小(例如Z1 = 1,2,3,4,5和Z2 = 1.0001,2.0002) ,3.0001,4.0002,5.0001)。所以,我想将每个Z图设置在不同的Y轴上。 (例如,Z = Y = 0,Z2,Y = 2 ......)

enter image description here enter image description here

有没有人有任何建议或想法?

谢谢

2 个答案:

答案 0 :(得分:4)

我将澄清我在评论中写下的想法。 首先,让我们获取一些数据:

x = 470:0.1:484;
z1 = cos(x)/2;
z2 = sin(x)/3;
z3 = cos(x+0.2)/2.3;

我只会绘制三个数据集,所有这些都可以扩展到任意数量的数据集。

想法1:多轴

这里的想法只是使用subplot创建一个小型多重类型的情节:

ytick = [-0.5,0.0,0.5];
ylim = [-0.9,0.9]);
figure

h1 = subplot(3,1,1);
plot(x,z1);
set(h1,'ylim',ylim,'ytick',ytick);
title('z1')

h2 = subplot(3,1,2);
plot(x,z2);
set(h2,'ylim',ylim,'ytick',ytick);
title('z2')

h3 = subplot(3,1,3);
plot(x,z3);
set(h3,'ylim',ylim,'ytick',ytick);
title('z3')

enter image description here

请注意,例如,可以从顶部的两个图中删除刻度标签,只留下底部的标签。然后你也可以移动轴,使它们更靠近在一起(如果在同一个图中有很多这些线,这可能是必要的):

set(h1,'xticklabel',[],'box','off')
set(h2,'xticklabel',[],'box','off')
set(h3,'box','off')
set(h1,'position',[0.13,0.71,0.8,0.24])
set(h2,'position',[0.13,0.41,0.8,0.24])
set(h3,'position',[0.13,0.11,0.8,0.24])
axes(h1)
title('')
ylabel('z1')
axes(h2)
title('')
ylabel('z2')
axes(h3)
title('')
ylabel('z3')

enter image description here

构思2:相同的轴,带偏移的图

这是一种更简单的方法,因为您只处理单个轴。 @Zizy Archer已经表明,如果将数据全部放在单个2D矩阵Z中,那么移位数据是多么容易。在这里,我只是简单地绘制z1z2+2z3+4。根据自己的喜好调整偏移量。接下来,我设置'ytick'属性以创建单独图形的错觉,并设置'yticklabel'属性,以便沿y轴的数字与绘制的实际数据相匹配。最终结果类似于上面的多轴图,但它们都在一个轴上:

figure
plot(x,z1);
hold on
plot(x,z2+2);
plot(x,z3+4);
ytick = [-0.5,0.0,0.5];
set(gca,'ytick',[ytick,ytick+2,ytick+4]);
set(gca,'yticklabel',[ytick,ytick,ytick]);
text(484.5,0,'z1')
text(484.5,2,'z2')
text(484.5,4,'z3')

enter image description here

答案 1 :(得分:2)

最简单的方法是移动Z数据。但请注意,Z2看起来像是在1左右摆动 - 所以这是一个整洁的视觉表现,但可能会误导。

% Simple version - shift Z curves by 0, 1, ... (as recommended by @Cris Luengo)
shiftMat = repmat(0 : size(Z, 2)-1, size(Z,1), 1);
Z = Z + shiftMat;

%Min shift up to have non-overlapping - curves touching
for i = 2 : size(Z, 2)
   Zdif = (Z(:, i-1) - Z(:, i));
   Z(:, i) = Z(:, i) + max(Zdif); % + 0.01 to separate them a little bit.
end

%Bigger shift up, to have all points of Z(2) equal or above all points of z1.
for i = 2 : numZ
    Zdif = max(Z(:, i-1))-min(Z(:, i));
    Z(:, i) = Z(:, i) + Zdif;
end

另一种可能性是使多个Y轴和每个Z曲线相对于其自己的Y轴绘制。这可能是更加漂亮的,不应该误导,但即使在你抓住这个功能之后,它仍然需要更多的工作,因为你仍然需要定位所有这些轴。默认情况下,MATLAB允许您只使用2个轴,因此从fileexchange中获取一个函数以添加更多:https://www.mathworks.com/matlabcentral/fileexchange/9016-addaxis