why is this "if" statement is never true?
4 ビュー (過去 30 日間)
古いコメントを表示
Can someone please explain why this "if" statement is never true? It is supposed to allow me to take the elements at every even integer of Time (i.e. 2 4 6...) while Time is increasing by 0.1 every time through the while statement.
I have gone through the program step by step and have actually viewed my j = 2, and Time = to 2.0000 and it still goes to the "else" command. I've also written the same if statement outside of this script and it works.
Any ideas? Your help is appreciated!
dt = 0.1;
i = 1;
j = 0;
Time = 0;
TimeMax = 20000;
while Time < TimeMax
Mass0 = ...
Altitude0 = ...
Velocity0 = ...
Gamma0 = ...
Radius0 =...
Nu0 = ...
Time = Time + dt;
j = 2+j;
if j == Time
i = i+1;
Mass(i)= Mass0;
Altitude(i) = Altitude0;
Velocity(i) = Velocity0;
Gamma(i) = Gamma0;
Radius(i)=Radius0;
Nu(i) = Nu0;
else
j = j-2;
end
end
1 件のコメント
Youssef Khmou
2013 年 2 月 13 日
is the variables Mass, Velocity... are constant then make them outside the "while" loop to gain memory .
回答 (3 件)
Brooke
2013 年 2 月 13 日
1 件のコメント
Youssef Khmou
2013 年 2 月 13 日
how is the equivalence you want? if my answer is not the right one, delete it to get better solution !
Youssef Khmou
2013 年 2 月 13 日
編集済み: Youssef Khmou
2013 年 2 月 13 日
Hi, i saw that the answer is not satisfactory, because we evaluate for 20000 points in Time and get only 20 values in Mass, Veloc... the reason is because i made mistake putting Mod(j,Time) while i should put " Mod(Time,j)" or Mod(Time,2) , with this alteration we get the logical lenght for Mass perxample which is 10001, and also changing dt to 1 :
dt = 1;
i = 1;
j = 0;
Time = 0;
TimeMax = 20000;
Mass0 =2;
Altitude0 =58;
Velocity0 = pi;
Gamma0 =77;
Radius0 =7.25;
Nu0 = 77;
while Time < TimeMax
Time = Time + dt;
j = 2+j;
if mod(Time,2)==0 % if mod(time,j)==0
i = i+1;
Mass(i)= Mass0;
Altitude(i) = Altitude0;
Velocity(i) = Velocity0;
Gamma(i) = Gamma0;
Radius(i)=Radius0;
Nu(i) = Nu0;
else
j = j-2;
end
end
Is that the equivalence you talked about ?
0 件のコメント
参考
カテゴリ
Help Center および File Exchange で Creating and Concatenating Matrices についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!