4

我正在使用 BNT 的 plotgauss2d 函数来可视化当在网络的其他地方观察到证据时 2D 高斯节点的响应如何变化。

eng = jtree_inf_engine(bnet);
evidence = cell(1, 2)
eng = enter_evidence(eng, evidence);
marginals = marginal_nodes(eng, 1); p_1 = marginals.T
marginals = marginal_nodes(eng, 2); p_2 = marginals.T
marginals
clf; plotgauss2d(marginals.mu, marginals.Sigma);
hold all;
evidence{1} = 1;
marginals = marginal_nodes(enter_evidence(eng, evidence), 2);
p = plotgauss2d(marginals.mu, marginals.Sigma);
set(p, 'Color', 'green');
evidence{1} = 2;
marginals = marginal_nodes(enter_evidence(eng, evidence), 2);
p = plotgauss2d(marginals.mu, marginals.Sigma);
set(p, 'Color', 'red');
legend({'Unknown', 'Class 1', 'Class 2'});
hold off;

在此处输入图像描述

如您所见,图例没有选择我必须手动设置的更改的绘图颜色。(遗憾的是,plotgauss2d 不会像您希望的那样自动循环颜色。)

有没有办法设置图例中使用的线条颜色?

4

2 回答 2

7

PLOTGAUSS2D函数返回一个由三个手柄组成的向量,分别对应于短轴、长轴和椭圆。所以这里是一个如何存储句柄并在最后调用 LEGEND 的示例:

figure, hold on
h = zeros(3,3);
h(:,1) = plotgauss2d(rand(2,1), [1 0.5; 0.5 2]);
h(:,2) = plotgauss2d(rand(2,1), [2 -0.5; -0.5 1]);
h(:,3) = plotgauss2d(rand(2,1), [1 0; 0 2]);
hold off
set(h(:,1), 'Color','r')
set(h(:,2), 'Color','g')
set(h(:,3), 'Color','c')
legend(h(1,:), {'1','2','3'})

截屏

于 2012-06-09T01:50:17.960 回答
2

图例确实选择了线条颜色、样式、标记等。

您必须plot在每个 中至少包含三个 s plotgauss2d plot。因此,您的legend命令将 应用于legend前三个plots,所有从第一次调用到plotgauss2d.

跳过您的一些代码,您可以通过执行以下操作使您的图例正确:

p = plotgauss2d(marginals.mu, marginals.Sigma);
h = p(1);
hold all;
evidence{1} = 1;
marginals = marginal_nodes(enter_evidence(eng, evidence), 2);
p = plotgauss2d(marginals.mu, marginals.Sigma);
h(end+1) = p(1);
set(p, 'Color', 'green');
evidence{1} = 2;
marginals = marginal_nodes(enter_evidence(eng, evidence), 2);
p = plotgauss2d(marginals.mu, marginals.Sigma);
h(end+1) = p(1);
set(p, 'Color', 'red');
legend(h,{'Unknown', 'Class 1', 'Class 2'});

现在,您正在将每个呼叫legend应用legend到一个。plotplotgauss2d

另外,我建议在最后添加一行:

axis equal;

我想你会喜欢它的功能。

于 2012-06-09T01:23:27.990 回答