WICHTIG: Der Betrieb von goMatlab.de wird privat finanziert fortgesetzt. - Mehr Infos...

Mein MATLAB Forum - goMatlab.de

Mein MATLAB Forum

 
Gast > Registrieren       Autologin?   

Partner:




Forum
      Option
[Erweitert]
  • Diese Seite per Mail weiterempfehlen
     


Gehe zu:  
Neues Thema eröffnen Neue Antwort erstellen

Problem mit Code zum plotten

 

Gast



Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 26.02.2009, 22:56     Titel: Problem mit Code zum plotten
  Antworten mit Zitat      
Hey,

muss mich derzeitig mit Matlab auseinander setzen und stoße dabei immer auf folgenden Code:
Code:

[T,Z]=ode45('Modell',t,AB,[], ... % (hier sind ein paar Variablen aufgezählt...);

for i=1:length(T)
     zp=Modell(T(i), Z(i,:)', [], ... % (wieder Variablen);
     theta_pp(i)=zp(2);
end

plot(T,Z(:,1), 'r', T,Z(:,2), 'b', T, theta_pp, 'g')

function zp=Modell(t,z,flag, ... Variablen...)
theta=z(1);
thetap=z(2);
.
.

zp=[thetap; thetapp];
 


Kann mir jemand helfen? Habe folgende Fragen:

1.) Was macht ode45 genau. Was wird gelöst bzw numerisch integriert?
2.) Warum brauche ich zum plotten eine if-schleife???
3.) Was besagt mir der Befehl "theta_pp(i)=zp(2);"?
4.) Wie greift mein "zp=Modell(T(i), Z(i,Smile', [], ... (wieder Variablen);" auf die function zu und was wird dabei ausgegeben? Was stellt zp am Ende dar?

Vielen Dank schon mal für eure Hilfe. Bin echt gerade am Verzweifeln...

eidt by steve: Code-Umgebung ergänzt! Bitte zukünftig selbständig formatieren!


steve
Ehrenmitglied

Ehrenmitglied



Beiträge: 2.029
Anmeldedatum: 03.09.07
Wohnort: Wien
Version: R2024a
     Beitrag Verfasst am: 27.02.2009, 08:32     Titel:
  Antworten mit Zitat      
Moin,

ich versuche mal ein paar Antworten nach meinem derzeitigen Verständnis deines Codes zu geben:

1. ode45 ist ein ODE-Solver, der die in "Modell" (hoffentlich) stehenden Differentialgleichungen in Abhängigkeit der Veränderung der Zustandsvariablen zu selbstgewählten Zeitpunkten auswertet. (Wenn es jmd. besser erklären kann, nur zu Wink)

2. Die for-Schleife dient dazu, zu jedem Zeitpunkt der numerischen Lösung ein theta_pp zu berechnen. (Eigentlich müsste es auch ohne gehen, da in Z ja schon thetapp zurückgegeben wurde, müsste man sich nochmal genauer anschauen.)

3. Diese Zeile schreibt in den Vektor theta_pp für jeden Zeit- oder Datenpunkt i den entsprechend berechneten Wert, der sich im Vektor zp an zweiter Position befindet.

4. Der Funktion "Modell" werden die Variablen und Zeitpunkte übergeben und dann werden wahrscheinlich in der Funktion ein paar Berechnungen durchgeführt und am Ende die berechneten Werte in den Rückgabevektor zp geschrieben. Dieser stellt wahrscheinlich die Zustandsvariablen des Systems dar!? (Für eine genauere Aussage fehlt der entsprechende Code)

Ich hoffe du kannst mit diesen Aussagen etwas anfangen!

Gruß
Alex


PS: Mein 1100. Beitrag - Krieg ich nen Keks?! Rolling Eyes
_________________

>> I told me to.

____________________________________
Matlab Cheat Sheet
goMatlab-Knigge - dran gehalten?!
Schon in den FAQ gesucht?
Ist vielleicht bei den Skripten oder den Tutorials was für dich dabei?
Private Nachricht senden Benutzer-Profile anzeigen
 
Thadeus2

Gast


Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 28.02.2009, 18:39     Titel: Noch ein Frage
  Antworten mit Zitat      
Vielen Dank Alex,

das hat mir schon mal sehr weiter geholfen. Noch eine Frage hätte ich zum Code: Was genau stellt [T, Z] dar? Muss ich mir das als Vektor vorstellen? Wenn ja, was wird drin stehen?
 
Neues Thema eröffnen Neue Antwort erstellen



Einstellungen und Berechtigungen
Beiträge der letzten Zeit anzeigen:

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
.





 Impressum  | Nutzungsbedingungen  | Datenschutz | FAQ | goMatlab RSS Button RSS

Hosted by:


Copyright © 2007 - 2025 goMatlab.de | Dies ist keine offizielle Website der Firma The Mathworks

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.