如何处理此问题
clear all; close all; clc;
r = 0:5;
zeta = 0:0.1:1;
for i = 1:size(zeta(:))
for j = 1:size(r(:))
X(i,j) = sqrt((1+(2*zeta(i)*r(j))^2)/((1-r(j)^2)^2+ (2*zeta(i)*r(j))^2));
end
plot(r,X);
xlabel('r = \omega/\omega_n');
ylabel('M = \frac{X}{Y}');
hold all
grid
[~,~,~,current_entries] = legend;
legend([current_entries {sprintf('\zeta = %i',zeta(i))}]);
end
figure
plot(r,X)
grid
hold all
命令似乎无法正常工作。我该怎么做才能解决这个问题?
答案 0 :(得分:2)
您需要设置绘图的DisplayName
属性。然后,当您创建legend
时,将自动填充标签。
plot(r, X, 'DisplayName', 'name')
此外,您传递给sprintf
的字符串的字符串需要转义,因为sprintf
认为\z
是控制字符。
plot(r, X, 'DisplayName', sprintf('\\zeta = %0.1f',zeta(k)))
此外,建议hold on
优先于hold all
。此外,最佳做法是在调用hold
时指定轴句柄,以确保将其应用于当前轴。
hold(hax, 'on')
因此,如果我们将这些更改纳入您的绘图代码(以及@R.Falque使用semilogy
的想法)
r = 0:0.001:5;
zeta = 0:0.1:1;
hax = axes();
colors = hsv(numel(zeta));
for k = 1:numel(zeta)
X = sqrt((1 + (2 * zeta(k) * r).^2) ./ ((1-r.^2).^2+ (2*zeta(k)*r).^2));
semilogy(r, X, ...
'DisplayName', sprintf('\\zeta = %0.1f',zeta(k)), ...
'Color', colors(k,:));
hold(hax, 'on')
end
grid(hax, 'on')
xlabel(hax, 'r = \omega/\omega_n', 'Interpreter', 'tex');
ylabel(hax, 'M = $\displaystyle\frac{X}{Y}$', 'Interpreter', 'latex');
L = legend('show');
答案 1 :(得分:1)
您还可以使用单元格数组,如下所示:
clear all; close all; clc;
r = 0:0.001:5;
zeta = 0:0.1:1;
figure;
for i = 1:length(zeta)
for j = 1:length(r)
X(j) = sqrt((1+(2*zeta(i)*r(j))^2)/((1-r(j)^2)^2+ (2*zeta(i)*r(j))^2));
end
semilogy(r,X);
hold on
legend_string{i} = ['\zeta = ', num2str(zeta(i))];
end
hold off
grid
xlabel('r = \omega/\omega_n');
ylabel('M = $\frac{X}{Y}$','Interpreter', 'Latex');
legend(legend_string);
请注意,X
定义中存在错误(已从X(i,j)
更正为X(j)
)。