Verfasst am: 22.01.2019, 14:43
Titel: Re: Funktion mit Schleifen umbauen in echt rekursive Funktio
Hallo Degonas,
Hast du einen guten Grund das rekursiv zu formulieren? Es würde deutlich langsamer laufen. Deshalb zunächst mal einen Tipp zur Beschleunigung und Vereinfachung:
Code:
function V = Bellmanneu(C,R1,R2,T,P1,P2,P0)
V = zeros(C+1, T+1); % Pre-allocation!!! for t = T:-1:1 for c = 2:C+1
V(c,t) = P1 * (R1 + V(c-1,t+1)) + P2 * (R2 + V(c-1,t+1)) + P0 * V(c,t+1);
end end end
Hieraus könnte man nun künstlich eine Rekursion bauen, indem man den Vektor V(:, t+1) and eine Unterfunktion weiter gibt um V zu berechnen. Ich weiß nur nicht, wozu man das umständlicher machen möchte.
Gruß, Jan
Im Grunde funktioniert noch nicht ganz richtig. Meine Matrix V wird dabei nämlich nicht überschrieben sondern es wird jedes Mal eine neue Matrix mit neuen Dimensionen ausgegeben. Und wie schaffe es Matlab wissen zu lassen, dass er die Funktion Recursive2 solange aufrufen soll, bis t=1? Aufgrund der t-1 der wird der Input gleich 0 im letzten Schritt und den Index 0 gibt es eben nicht.
Für jegliche Hilfe bin ich weiterhin sehr dankbar!
Grüße
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.