I don't understand what is going wrong with my code!!, I get error of a matrix singular

1 回表示 (過去 30 日間)
ouahid lakhal
ouahid lakhal 2018 年 12 月 30 日
コメント済み: Stephan 2019 年 1 月 2 日
function dy = rocketequat( t,y )
%UNTITLED6 Summary of this function goes here
g=9.81; % constant of gravity m/s^2
Ve=2800;%celerity of inject gas m/s
m0=500000;%initial mass =500000kg
dmdt=-2300;%kg/s
dy(1)= -g*sin(y(2)) - Ve * dmdt/( m0 - dmdt*t );%dy(1)=dvdt acceleration
dy(2)= ( g/y(1) )*cos( y(2) ); %dy(2)=dbetadt variation in angle of inclination
end
%in a script i wrote
[t,y]=ode23s(@rocketequat,[0 160],[0 pi/2]);
% i gut this message:
In rocket (line 1)
Warning: Matrix is singular, close to singular or badly scaled. Results may be inaccurate. RCOND = NaN.
  3 件のコメント
Stephan
Stephan 2018 年 12 月 30 日
Please accept useful answers.

サインインしてコメントする。

回答 (1 件)

Stephan
Stephan 2018 年 12 月 30 日
編集済み: Stephan 2018 年 12 月 30 日
Hi,
you do a divide by zero at the initial point - use another x0 for y(1) - for example try:
[t,y]=ode45(@rocketequat,[0 160],[0.0001 pi/2]);
plot(t,y(:,1),t,y(:,2))
function dy = rocketequat(t,y)
%UNTITLED6 Summary of this function goes here
g=9.81; % constant of gravity m/s^2
Ve=2800;%celerity of inject gas m/s
m0=500000;%initial mass =500000kg
dmdt=-2300;%kg/s
dy(1)= -g.*sin(y(2)) - Ve .* dmdt./( m0 - dmdt*t );%dy(1)=dvdt acceleration
dy(2)= ( g./y(1) ).*cos( y(2) ); %dy(2)=dbetadt variation in angle of inclination
dy=dy';
end
gives:
There is also no need for the useage of a stiff solver - ode45 will do the job.
Best regards
Stephan
  7 件のコメント
ouahid lakhal
ouahid lakhal 2019 年 1 月 2 日
thinks for your efforts m.stephen
Stephan
Stephan 2019 年 1 月 2 日
what is wrong?

サインインしてコメントする。

カテゴリ

Help Center および File ExchangeProgramming についてさらに検索

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by