function dVdt=modell(t,V)
T = interp1(trs, Trs, t, 'linear'); %Zu beachten ist, dass T von t abhängt und aus einer Tabelle interpoliert wird
k = A*exp(-E/(R*T));
dVdt = k*exp(integral(@(t) k,0,t));
function dVdt=modell(t,V, trs, Trs, E, A, R)
T = @(t)interp1(trs, Trs, t, 'linear'); %Zu beachten ist, dass T von t abhängt und aus einer Tabelle interpoliert wird
k = @(t) A*exp(-E/(R*T(t)));
dVdt = k*exp(integral(k,0,t));
Probleme kann es bei der Genauigkeit geben: ode45 nimmt in der Schrittweitenkontrolle ja an, dass die Funktionsauswertungen exakt sind, und ebenso integral. Im Zweifelsfall also die Toleranzen deutlich unter die eigentlich gewünschte Toleranz legen.
Grüße,
Harald
Andre_
Gast
Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
Verfasst am: 27.04.2018, 06:47
Titel:
Vielen Dank für die Antwort.
Konnte deine Lösung jetzt nicht prüfen, weil ich das Problem auf 2 DGL verändert habe. Dann klappt es auch...
Einstellungen und Berechtigungen
Du kannst Beiträge in dieses Forum schreiben. Du kannst auf Beiträge in diesem Forum antworten. Du kannst deine Beiträge in diesem Forum nicht bearbeiten. Du kannst deine Beiträge in diesem Forum nicht löschen. Du kannst an Umfragen in diesem Forum nicht mitmachen. Du kannst Dateien in diesem Forum posten Du kannst Dateien in diesem Forum herunterladen
MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.