Solving system of ODEs

2 views (last 30 days)
Ashok Das
Ashok Das on 29 Jul 2019
Answered: Steven Lord on 29 Jul 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 Comments
darova
darova on 29 Jul 2019
Can you please attach your script?
Ashok Das
Ashok Das on 29 Jul 2019
Edited: Ashok Das on 29 Jul 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

Sign in to comment.

Answers (2)

darova
darova on 29 Jul 2019
Edited: darova on 29 Jul 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 Comments
Ashok Das
Ashok Das on 29 Jul 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 on 29 Jul 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.

Sign in to comment.


Steven Lord
Steven Lord on 29 Jul 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.

Community Treasure Hunt

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

Start Hunting!