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

Vektorfeld plotten

 

shalec
Forum-Anfänger

Forum-Anfänger


Beiträge: 34
Anmeldedatum: 11.07.10
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 23.11.2015, 21:04     Titel: Vektorfeld plotten
  Antworten mit Zitat      
Hallo allerseits,

ich habe zunächst folgenden Code:

Die Funktion:
Code:
function [ dy ] = f( t,y )
    dy = 9.*y - y.^3;
end


und den Code zum Plotten:

Code:

function [  ] = PlotF(  )
    %% Intervalle
    % Deklariere das intervall -3 <= t <= 3
    t_min = -3;
    t_max = 3;
    t_interval = [t_min, t_max];
   
    % Lege fest, dass die Vektoren in t-Richtung von t_min bis t_max
    % insgesamt 15 Stück darstellt
    t = linspace(t_min, t_max, 15);
   
    % Intervall: -3 <= x <= 3
    x_min = -3;
    x_max = 3;
   
    x = linspace(x_min, x_max, 12);
   
    [ti, xi] = meshgrid(t,x);
   

    dx = f(ti,xi);

    dt = ones( size(ti) );
   
    quiver(ti, xi, dt, dx, 1);
   
    axis( [t_min-1, t_max+1, x_min-1, x_max+1] );
   
    %AWP: x(0) = -3
    [t1,x1] = ode45(@f, t_interval, x_min)
   
    hold on;
    plot(t1, x1, '-' ,'LineWidth', 2);
    hold off;
   
    xlabel('t');
    ylabel('x');
end


 


Ich dachte erst, da ja Vektorpfeile auftauchen, dass alles soweit korrekt ist, dann habe ich aber versucht diese zu interpretieren und gemerkt, dass der Graph konstant -3 ist. Dies kann aber nicht sein. Daher vermute ich, dass ein Fehler in meiner Eingabe an die ode45 besteht.

Könnte mir hier jemand etwas weiter helfen?

Viele Grüße und vielen Dank
Private Nachricht senden Benutzer-Profile anzeigen


Harald
Forum-Meister

Forum-Meister


Beiträge: 24.495
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 23.11.2015, 21:29     Titel:
  Antworten mit Zitat      
Hallo,

die Frage ist: welche DGL willst du lösen?

Beim Startwert -3 ist die Ableitung konstant 0.
Code:
f(0, -3)
f(1, -3)
...


... und wenn die Ableitung 0 ist, kommt eben eine Konstante heraus.

Vielleicht hast du dir auch einfach nur einen ungünstigen Startwert ausgesucht?

Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen
 
shalec
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 34
Anmeldedatum: 11.07.10
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 23.11.2015, 22:07     Titel:
  Antworten mit Zitat      
Hallo Harald und vielen Dank für die schnelle Antwort.
Die DGL sieht wie folgt aus:

x' = 9x - x^3

angegeben ist diese mit dem AWP x(0)= x0. Wir sollen den Graphen im Bereich [x0, xf] plotten und dieses Intervall wird dann im Aufgabenverlauf als [-3, 3] definiert. Daher soll der Anfangswert x(0)=-3 sein.

Wenn ich das nachrechne(n lasse: http://www.wolframalpha.com/share/c.....9800998ecf8427eh2bf7tuj4t ) kommt da tatsächlich bei dem Startwert konstant -3 raus.

Die Aufgabe sieht nun weiter vor, dass wir das Verhalten der Funktion für t -> infinity in Abhängigkeit von x0 interpretieren sollen, allein durch die Vektordarstellung. Hier ist aber keine Veränderung in x0 vorgesehen.

Ich habe das nun über eine For-Schleife gelöst. Danke Smile
Private Nachricht senden Benutzer-Profile anzeigen
 
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.