Repeating for loop until getting a list of solution
Mostrar comentarios más antiguos
Hi to all
I'm not that good in Matlab and I tried to learn it. I used for loop to create a solution for each value of (n) and repeating the for loop. The for-loop is from 1 to 8760 while n is from 0 to 1 with increament of 0.1.
I want to repeat the for-loop for each (n) and finally make a vecto of [n, solution from for-loop]. Attached flow chart may explain more about what I want.

6 comentarios
Abdullah Al Shereiqi
el 17 de Mzo. de 2020
Sriram Tadavarty
el 17 de Mzo. de 2020
Can you place the code you tried so far and the issue that came up?
Rik
el 17 de Mzo. de 2020
Abdullah Al Shereiqi
el 17 de Mzo. de 2020
Editada: Rik
el 17 de Mzo. de 2020
Rik
el 17 de Mzo. de 2020
Apart from the suggestion from Guillaume; I forgot to account for floating point rounding errors.
s=0;
for k=1:10
s=s+0.1;
end
clc
fprintf('%.53f\n',s) %not quite equal to 1
The solution in this case is to use a tolerance:
s==1 %returns false, because s is 0.99999999999999988897769753748434595763683319091796875
abs(s-1)<=2*eps %returns true
Sriram Tadavarty
el 17 de Mzo. de 2020
You could even break when s is greater than 1, example, the condition of if s > 1, can be placed, rather than s == 1 to deal with tolerance issues.
Or it can be directly placed a loop for 100 times, in each time 0.01 can be added.
Respuestas (2)
Guillaume
el 17 de Mzo. de 2020
If it's a flow chart you've been given, then you are entitled to complain loudly. That flow chart is very misleading. The layout is a more representative of a while loop than a for loop.
This is what you're meant to do:
for n = 0:0.1:1 %represented by 4 boxes on the flow chart! (n = 0, for-loop, n=1?, increment by 0.1)
%do calculation inside the loop (1 box on the chart)
end
%get a vector of solution (1 box on the chart)
Abdullah Al Shereiqi
el 17 de Mzo. de 2020
0 votos
Categorías
Más información sobre Logical en Centro de ayuda y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!