Solving system of ODEs

2 visualizaciones (últimos 30 días)
Ashok Das
Ashok Das el 29 de Jul. de 2019
Respondida: Steven Lord el 29 de Jul. de 2019
I have a system of DEs similar to the following:
If the variable Z is not present (i.e. eq (3) also), then I can solve it using ode45 command.
But the availability of Z is creating problem for me. To get the value of Z at time t, we have to solve the ODE (3) from time 0 to \tau, then we have to put that value of Z in equation (2), for evey instance 't'.
The main problem is, while solving DE using ode45, at any instance t, MATLAB uses the values of variables at that instance only. But here we require values of variables at time (t-\tau) to use at time t.
Please help me to solve the problem. Thanks in advance.
MTLB-page.jpg
  2 comentarios
darova
darova el 29 de Jul. de 2019
Can you please attach your script?
Ashok Das
Ashok Das el 29 de Jul. de 2019
Editada: Ashok Das el 29 de Jul. de 2019
Main function is:
X_0 = 1; Y_0 = 1; % Initial condition
t = linspace(0,10); %TIme
[t, Var] = ode45(@myfun, t, [X_0 Y_0]); % ODE solve
X= Var(:,1);
Y= Var(:,2);
Create myfun :
function [dX dY] = myfun(t, IC)
X= IC(1); Y=IC(2);
a=1; b=2; c=3; d=4; % Values
dX = a*X + b*Y;
% Now here before this line I need to solve the DE
% (3) upto time t= \tau to get the value of Z
% (which I am not able to do).
dY = c*X+ d*Y + Z;
end

Iniciar sesión para comentar.

Respuestas (2)

darova
darova el 29 de Jul. de 2019
Editada: darova el 29 de Jul. de 2019
What if just solve 2 systems?
First one (t <= tau) with initial conditions: X(0) = X0, Y(0) = Y0
[t, Var] = ode45(...); % ODE solve
X= Var(:,1);
Y= Var(:,2);
x0 = X(end); % initial conditions for 2d system
y0 = Y(end);
Second (t >= tau) with Z(tau) = Z0 (X and Y initial conditions give from the first solution)
What do you think about my idea?
  4 comentarios
Ashok Das
Ashok Das el 29 de Jul. de 2019
In equation (3), t' is the only independent variable. t and \tau are constant regarding to equation (3). We have to solve (3) for t' =0 to t' = \tau, and fit that value in eqaution (2)
Ashok Das
Ashok Das el 29 de Jul. de 2019
If t = tau+0.5, then (t' +t -tau)= t' +0.5 .
The value of \tau is fixed throughout the simulation.
We have to find Z at t' = \tau for each value of t.

Iniciar sesión para comentar.


Steven Lord
Steven Lord el 29 de Jul. de 2019
I only skimmed your problem but it looks like when Z is not present, you have a set of ordinary differential equations. Once Z comes into the picture, you no longer have a set of ordinary differential equations. Your equations are now delay differential equations. Use the ODE solvers to solve the system until t reaches tau, then use the DDE solvers (like dde23 or ddesd) to solve the system using the results from the ODE solvers as the history.

Categorías

Más información sobre Ordinary Differential Equations en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by