loop in a loop
显示 更早的评论
Hello!
I want to repeat the inner loop 10 times but it doesn't work. How do I solve that?
(Part of a bigger project)
hold on;
for k=1:10
for i=1:n-1
y(i+1)=y(i)+f(y(i))*dt+g(y(i)).*(B(i+1)-B(i));
end
plot(t,y)
end
10 个评论
Voss
2022-2-25
When you say "it doesn't work", what does it do? That is, what is the behavior you see vs the behavior you expect? Do you get an error message? If so, please copy and paste it here.
Also, it may be helpful if you tell us the initial values of your variables n, y, f, dt, g, B and t.
Hugo B
2022-2-25
Image Analyst
2022-2-25
@Hugo B I think you overlooked his last sentence. If you want the inner loop repeated 10 times, then n must be 11.
If you get only one plot, not one for each k, then all your plots must be identical and they're simmply overlapping each other. If you do this do you see multiple plots
subplot(3, 4, k)
plot(t, y, '-', 'LineWidth', 2);
grid on;
Hugo B
2022-2-25
Image Analyst
2022-2-25
But when you did it like I showed (just humor me for a moment), were all the plots different? Or did they look the same. If they looked different, then when you did it your way, did the plot look just like the final one? If so, then somehow hold got turned off.
Hugo B
2022-2-25
Hugo B
2022-2-25
Torsten
2022-2-25
B = sqrt(dt)*randn(n,1)
instead of
for i=2:n
b = b + sqrt(dt)*randn(1);
B = [B;b];
end
Otherwise, the B in the inner loop will still be unchanged.
回答(2 个)
The outer loop is superfluous - so I deleted it.
dt = ...;
B = ...;
f = @(y) ...;
g = @(y) ...;
t = ...;
y = zeros(size(t));
y(1) = ...;
for i = 2:numel(t)
y(i) = y(i-1) + f(y(i-1))*dt + g(y(i-1))*(B(i)-B(i-1));
end
plot(t,y)
figure();
n = 100;
t = linspace(0,1,n);
dt = t(2);
f = @some_function;
g = @some_function;
B = randn(1,100);
hold on;
for k=1:10
y = zeros(1,n); % (re-)initialize y to be all zeros for each plot
for i=1:n-1
y(i+1)=y(i)+f(y(i))*dt+g(y(i)).*(B(i+1)-B(i));
end
plot(t,y);
end
function out = some_function(in);
out = in+randn(size(in));
end
类别
在 帮助中心 和 File Exchange 中查找有关 Loops and Conditional Statements 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!
