How to solve delay differential equations with computed history (not constant)
2 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
Greetings!
I'm trying to solve some delay differential equations. The classic example, the Lotka-Volterra predation model illustrates the problem. This is solved in many places around the web*, always using a constant history (as far as I can tell). Usually, the ode system is solved for comparison, then the delayed system, using a constant history, like the last computed point of the ode system. I'd like to use that computed (approximated by, say, ode45, not analytical) solution of the non-delayed system as history, but can't figure out how. Help would be much appreciated.
* e.g., https://www.mathworks.com/matlabcentral/fileexchange/3899-tutorial-on-solving-ddes-with-dde23
0 Commenti
Risposta accettata
Torsten
il 19 Giu 2023
Spostato: Torsten
il 19 Giu 2023
Save the results of the non-delayed ode in arrays T and Y, create an interpolation function
fun_history = @(t) interp1(T,Y,t)
pass this function to the history function of the delay ode solver (e.g. dde23) and evaluate it at the given time instants passed to the history function.
Più risposte (0)
Vedere anche
Categorie
Scopri di più su Ordinary Differential Equations in Help Center e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!