how to solve this coupled ODE problem using ode solvers ?
1 回表示 (過去 30 日間)
古いコメントを表示
Sravan Kumar Putta
2021 年 1 月 19 日
編集済み: Sravan Kumar Putta
2021 年 1 月 20 日
I have two ODEs
within time interval [0 1] with initial conditions
values for F_x and F_y are calculated from function
data:image/s3,"s3://crabby-images/3e8d9/3e8d9eea06dbf6aab382fe4727ccad09749eb851" alt=""
data:image/s3,"s3://crabby-images/3e413/3e413ba443af4450e1d76855daa285ef95fd17dc" alt=""
0 件のコメント
採用された回答
Bjorn Gustavsson
2021 年 1 月 20 日
編集済み: Bjorn Gustavsson
2021 年 1 月 20 日
If you want to use the odeNN functions you need to rewrite your 2 2nd-order ODEs into 4 1st-order ODEs, something like this:
function dxdydvxdvydt = your_eqs_of_motion(t,xyvxvy,other,parameters)
x = xyvxvy(1); % If my ode-equations are complicated
y = xyvxvy(2); % I prefer to explicitly extract the
vx = xyvxvy(3); % variables into something that's
vy = xyvxvy(4); % easily human-readable
m = other;
Fx = force_functionx(t,x,y,vx,vy,other,parameters); % Adjust inputs as necessary
Fy = force_functiony(t,x,y,vx,vy,other,parameters);
% or possibly preferable:
% [Fx,Fy] = force_function_xny(t,x,y,vx,vy,other,parameters);
dxdydvxdvydt = [vx;vy;Fx/m;Fy/m];
end
Then you can integrate the equations of motion something like this:
m = 12; % you know what to set for this one
x0y0vx0vy0 = [1e-10,5.08e-5,0,0]; % Your initial conditions
t_span = [0,2*pi]; % a time-span of interest
[t_out,xyvxvy] = ode45(@(t,xyvxvy) your_eqs_of_motion(t,xyvxvy,m,[]),t_span,x0y0vx0vy0);
When integrating equations of motion you typically also have to carefully check that the constants of motion we know should be conserved (total energy, angular momentum, etc.) are reasonably conserved - the general ODE-integrating functions are not guaranteed to do this.
HTH
0 件のコメント
その他の回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Ordinary Differential Equations についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!