How to solve coupled first order ODE using something other than ODE45?

2 次查看(过去 30 天)
I have 6 coupled equations:
  1. m1'=-m1+a/(1+p3)^n+a0
  2. m2'=-m2+a/(1+p1)^n+a0
  3. m3'=-m3+a/(1+p2)^n+a0
  4. p1'=-b(p1-m1)
  5. p2'=-b(p2-m2)
  6. p3'=-b(p3-m3)
{a, a0, b and n are parameters. m1' is showing derivative of m1 with respect to t (time).}
I know these equations can easily be solved using ODE45 but I want to solve them using something more basic like Euler method. I can solve uncoupled ODEs using Euler method but for coupled equation I am little confused. Someone please give me or give me some ideas and hints to solve these equations. Thank you.

回答(1 个)

John D'Errico
John D'Errico 2017-4-22
编辑:John D'Errico 2017-4-22
What is the problem? If you understand how to solve an ODE using Euler's method, all you need to do is use the current value of your variables to predict ahead. If you have two or more variables, it still works the same. WTP?
Thus, if you have
y' = f(t,y)
then you predict ahead at time step t(k) to step t(k+1) as:
y(k+1) = y(k) + f(t(k),y(k))*dt
If you have multiple coupled equations, then each of them is still of the same form. Euler's method is about as simple as you can make it. It is not very good, since it is just Euler's method! But then, you are the one who wants to use it instead of something better. (This is rarely a good idea, unless you know enough to fully understand the problems and how to recognize them, as well as to know if you can afford to use a poor method. If you can't figure out how to code Euler's method, then you don't understand the issues.)
  2 个评论
Luqman Saleem
Luqman Saleem 2017-4-22
编辑:Luqman Saleem 2017-4-22
Thanks. I was too stupid to ask this question. I have written following code but it's not giving me expected results (all the variables (m1,m2,m3,p1,p2,p3) are expected to oscillate but this code is showing that most of them are just becoming zero after some repetition in for loop). where am I going wrong? Thanks again.
dt=0.1; %step
N=10; %total size
gridd=0:dt:N; %diving them
%---------allocating memeory to variables----
m1=zeros(1,length(gridd));
m2=zeros(1,length(gridd));
m3=zeros(1,length(gridd));
p1=zeros(1,length(gridd));
p2=zeros(1,length(gridd));
p3=zeros(1,length(gridd));
%---------intial conditions-------
m1(1)=0;
m2(1)=0;
m3(1)=0;
p1(1)=5;
p2(1)=2;
p3(1)=3;
%-----------parameters--------
a=1000;
a0=1;
n=1.75;
b=5;
%------euler method------
for i=1:length(gridd)-1
m1(i+1)=(-m1(i)+a/(1-p3(i)^n)+a0)*dt+m1(i);
m2(i+1)=(-m2(i)+a/(1-p1(i)^n)+a0)*dt+m2(i);
m2(i+1)=(-m2(i)+a/(1-p2(i)^n)+a0)*dt+m3(i);
p1(i+1)=(-b*(p1(i)-m1(i))*dt)+p1(i);
p2(i+1)=(-b*(p2(i)-m2(i))*dt)+p2(i);
p3(i+1)=(-b*(p3(i)-m3(i))*dt)+p3(i);
end
shireesha myadari
shireesha myadari 2021-2-25
I am not understanding ,how to make coupling between the given equations.
Thanks in advance.

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 Ordinary Differential Equations 的更多信息

产品

Community Treasure Hunt

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

Start Hunting!

Translated by