Solving system of ODEs

2 visualizzazioni (ultimi 30 giorni)
Ashok Das
Ashok Das il 29 Lug 2019
Risposto: Steven Lord il 29 Lug 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 Commenti
darova
darova il 29 Lug 2019
Can you please attach your script?
Ashok Das
Ashok Das il 29 Lug 2019
Modificato: Ashok Das il 29 Lug 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

Accedi per commentare.

Risposte (2)

darova
darova il 29 Lug 2019
Modificato: darova il 29 Lug 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 Commenti
Ashok Das
Ashok Das il 29 Lug 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 il 29 Lug 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.

Accedi per commentare.


Steven Lord
Steven Lord il 29 Lug 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!

Translated by