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

Fminsearch "Range" festlegen

 

student
Forum-Anfänger

Forum-Anfänger


Beiträge: 25
Anmeldedatum: 10.03.08
Wohnort: ---
Version: 7.0
     Beitrag Verfasst am: 10.03.2008, 18:46     Titel: Fminsearch "Range" festlegen
  Antworten mit Zitat      
Hallo zusammen,

ich habe eine Frage bezüglich der fminsearch.
Ich habe folgende Zeilen geschrieben. Es funktioniert alles tiptop.

Zitat:
...
[par]=fminsearch(@C_error, [C_0 theta_off_0]);
...


Zitat:
function error = C_error(par)
C=par(1);
theta_off=par(2);

global time theta spd;
options = simset('SrcWorkspace','current');
sim('param_est',[],options);
error = error_vec(end);

aber ich habe folgendes Problem.
Die Werte der durch fminsearch gefundenen Parameter sind physikalisch nicht sinnvoll (z.T. negativ).
Kann ich irgendwie Grenzen für die zu findenden Parameter festlegen?

Danke vielmals


p.s.: Ich weiss, dass es fminbnd gibt, aber soweit ich weiss kann ich da keine vektoren zur optimisation übergeben
Private Nachricht senden Benutzer-Profile anzeigen


Bijick
Ehrenmitglied

Ehrenmitglied



Beiträge: 914
Anmeldedatum: 18.06.07
Wohnort: Nürnberg
Version: R2006b, R2008b
     Beitrag Verfasst am: 11.03.2008, 10:59     Titel:
  Antworten mit Zitat      
Hallo student,

ich gehe mal davon aus, dass Du nicht über die Optimization Toolbox verfügen kannst? Die enthält nämlich die genau für diesen Fall passende Funktion fmincon. Man kann einen Vektor hineinstecken und Schranken angeben.

In Deinem Fall kannst Du Dir mit einem kleinen Trick der Optimierer, der sogenannten penalty-Methode helfen: Stecke Deine Schranken in die Zielfunktion hinein. Beispielsweise, wenn Du negative Werte für par(1) und par(2) vermeiden willst, schreibst Du:

Code:
function error = C_error(par)
C=par(1);
theta_off=par(2);
...
penalty_1 = -min(0,C); % ist genau dann positiv, wenn C negativ ist
penalty_2 = -min(0,theta_off);
error = error_vec(end) + penalty_1 + penalty_2;
 


Wenn das nicht genügt, kann man vor die penalty_k noch Faktoren schreiben.

(Eigentlich ist das noch nicht die penalty-Methode, sondern nur eine simple Vorstufe, aber es reicht meistens schon aus und ist unkompliziert.)

Herzliche Grüße
Bijick
_________________

>> why
Private Nachricht senden Benutzer-Profile anzeigen E-Mail senden
 
student
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 25
Anmeldedatum: 10.03.08
Wohnort: ---
Version: 7.0
     Beitrag Verfasst am: 11.03.2008, 16:41     Titel:
  Antworten mit Zitat      
Meci vielmals, das war genau das, was ich gesucht habe

viele Grüsse
student
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 - 2024 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.