我在八度创建另一个直方图。
hold on;
hist(normalData(:, column), 10, 1, "facecolor", "g");
hist(anomalousData(:, column), 10, 1, "facecolor", "r");
hold off;
如您所见,有重叠部分,红色数据遮盖了一些绿色数据。有没有解决的办法?也许通过在重叠部分上混合颜色?
最佳答案
解决您的问题还有很长的路要走。不幸的是,透明度“ facealpha”的plotting属性不适用于hist()函数。
下面的代码显示了我的解决方法。
默认的图形工具包可能是fltk,因此将其更改为gnuplot。
clear all
graphics_toolkit("gnuplot")
A = randn(1000,1);
B = randn(1000,1)+2;
仍使用hist来计算分布
[y1 x1] = hist(A,10);
[y2 x2] = hist(B,10);
现在,我们将把历史数据转换为允许透明的绘图格式。
[ys1 xs1] = stairs(y1, x1);
[ys2 xs2] = stairs(y2, x2);
xs1 = [xs1(1); xs1; xs1(end)]; xs2 = [xs2(1); xs2; xs2(end)];
ys1 = [0; ys1; 0]; ys2 = [0; ys2; 0];
用填充功能绘制数据
clf
hold on;
h1=fill(xs1,ys1,"red");
h2=fill(xs2,ys2,"green");
将透明度更改为所需的级别。
set(h1,'facealpha',0.5);
set(h2,'facealpha',0.5);
hold off;
如果我有更高的声誉,我会发布一张图片。