显示多个数据时出现错误错误

时间:2015-02-17 09:36:53

标签: matlab plot matlab-figure matlab-hg2

所以我需要在图中绘制一些errobar图。具体来说,我需要在每个图中有4个errorbar图,问题是当绘制多个数据时,图形有点不可读。

示例:

clear all
close all
clc



x = 0:pi/10:pi;
y = sin(x);
y2=cos(x);
y3=atan(x);
e = std(y)*ones(size(x));
e2 = std(y2)*ones(size(x));
e3 = std(y3)*ones(size(x));

figure
hold on
errorbar(x,y,e)
errorbar(x,y2,e2)
errorbar(x,y3,e3)

enter image description here

我解决这个问题的想法是填充错误条的角用图表的相同颜色和低alpha划分的区域,这样区域的重叠就可见了。

问题是,我能想象到的唯一方法是在由错误栏角分隔的区域中创建一个网格,然后用patch填充它们。这确实是可能的,但非常烦人,因为绘图不会有凸包,因此我需要迭代地逐个创建三角形。所以问题是:有更优雅的方式吗?

此外,如果有人这样做,我愿意接受更好的可视化数据的建议。

1 个答案:

答案 0 :(得分:5)

方法1

正常绘制图形,然后使用补丁手动绘制错误栏。补丁的数据(坐标和颜色)取自绘制的图形,补丁的alpha可以设置为任何所需的值。

clear all
close all
clc

error_alpha = .4;
error_width_factor = .01;

x = 0:pi/10:pi;
y = sin(x);
y2 = cos(x);
y3 = atan(x);
e = std(y)*ones(size(x));
e2 = std(y2)*ones(size(x));
e3 = std(y3)*ones(size(x));
ee = [e; e2; e3];

figure
hold on
hp(1) = plot(x,y);
hp(2) = plot(x,y2);
hp(3) = plot(x,y3);

w = diff(xlim)*error_width_factor;
for m = 1:numel(hp)
    for n = 1:numel(hp(m).XData)
        patch(hp(m).XData(n)+[-1 1 1 -1]*w, hp(m).YData(n)+[-1 -1 1 1]*ee(m,n), 'w',...
           'FaceColor', hp(m).Color, 'FaceAlpha', error_alpha, 'EdgeColor', 'none');
    end
end

enter image description here

方法2

与之前类似,但使用较窄的补丁并使用依赖于图形的水平移位绘制它们(如@Patrik所建议的那样)。应用alpha值有助于使图形更亮。

代码是方法1的修改版本。此处显示的示例包含101个数据值,并且仍然相当可见。

clear all
close all
clc

error_alpha = .4;
error_width_factor = .003;

x = 0:pi/50:pi;
y = sin(x);
y2 = cos(x);
y3 = atan(x);
e = std(y)*ones(size(x));
e2 = std(y2)*ones(size(x));
e3 = std(y3)*ones(size(x));
ee = [e; e2; e3];

figure
hold on
hp(1) = plot(x,y);
hp(2) = plot(x,y2);
hp(3) = plot(x,y3);

w = diff(xlim)*error_width_factor;
m0 = (numel(hp)+1)/2;
for m = 1:numel(hp)
    for n = 1:numel(hp(m).XData)
        patch(hp(m).XData(n)+[-1 1 1 -1]*w+w*(m-m0),...
        hp(m).YData(n)+[-1 -1 1 1]*ee(m,n), 'w', 'FaceColor', hp(m).Color, ...
        'FaceAlpha', error_alpha, 'EdgeColor', 'none');
    end
end

enter image description here