matlab用for循环用plot函数标注曲线y1=0.2e^-0.5x×cos(4πx)和y2=1.5e^-0.5x×cos(πx)的所有交点
时间: 2024-05-16 11:12:11 浏览: 13
可以使用以下代码实现:
```
x = 0:0.01:10;
y1 = 0.2*exp(-0.5*x).*cos(4*pi*x);
y2 = 1.5*exp(-0.5*x).*cos(pi*x);
figure;
plot(x, y1, x, y2);
hold on;
for i = 2:length(x)
if sign(y1(i)-y2(i)) ~= sign(y1(i-1)-y2(i-1))
plot(x(i), y1(i), 'ro');
plot(x(i), y2(i), 'ro');
end
end
legend('y1', 'y2');
```
这里使用了 `sign()` 函数来判断两条曲线的交点,然后在交点处绘制红色的圆圈。注意要使用 `hold on` 命令,否则两条曲线会分别显示。
相关问题
matlab用for、if循环用plot函数标注曲线y1=0.2e^-0.5x×cos(4πx)和y2=1.5e^-0.5x×cos(πx)的所有交点
可以使用以下代码:
```
x = 0:0.1:10;
y1 = 0.2*exp(-0.5*x).*cos(4*pi*x);
y2 = 1.5*exp(-0.5*x).*cos(pi*x);
plot(x,y1,x,y2);
hold on;
for i = 2:length(x)
if (y1(i) > y2(i) && y1(i-1) < y2(i-1)) || (y1(i) < y2(i) && y1(i-1) > y2(i-1))
plot(x(i),y1(i),'ro');
end
end
```
这段代码使用了for和if循环来判断两条曲线的交点,并使用plot函数标注交点。
matlab用for、if循环用plot标注曲线y1=0.2e^(-0.5x)×cos(4πx)和y2=1.5e(-0.5x)×cos(πx)的所有交点代码
以下是使用 MATLAB 代码标注曲线 y1=0.2e^(-0.5x)×cos(4πx)和y2=1.5e(-0.5x)×cos(πx)的所有交点的示例代码:
syms x;
y1 = 0.2*exp(-0.5*x)*cos(4*pi*x);
y2 = 1.5*exp(-0.5*x)*cos(pi*x);
% plot the two curves
fplot(y1, [-5, 5]);
hold on;
fplot(y2, [-5, 5]);
% find the intersection points
intersection_points = vpasolve(y1 == y2, x);
% plot the intersection points
for i = 1:length(intersection_points)
plot(intersection_points(i), subs(y1, x, intersection_points(i)), 'r*');
end
这段代码首先定义了符号变量 x,然后分别定义了曲线 y1 和 y2。接着使用 fplot 函数分别绘制了这两条曲线。
然后使用 vpasolve 函数计算了这两条曲线的交点,并将结果保存在 intersection_points 变量中。
最后使用 for 循环遍历交点列表,将每个交点绘制成红色星号。