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

Beste Konvexkombination, um Vektor zu fitten

 

Nras
Forum-Meister

Forum-Meister


Beiträge: 608
Anmeldedatum: 21.02.12
Wohnort: ---
Version: 7.12.0.635 (R2011a)
     Beitrag Verfasst am: 05.11.2013, 09:30     Titel: Beste Konvexkombination, um Vektor zu fitten
  Antworten mit Zitat      
Hallo,

ich habe ein Problem, bei dem ich gerne etwas Hilfe in Anspruch nehmen würde. Ich habe N Vektoren der Länge T gegeben (ein Ensemble) und weiterhin einen weiteren Vektor, den ich nun gerne bestmöglichst durch eine Linearkombination der ersten N Vektoren erzeugen möchte. Dazu folgendes kleine Beispiel.

Code:

% ----- generate data (N vectors of length T) -----
T = 500; N = 5;
time = (1:T)';
ensemble = cumsum(2*rand(T,N) - 1);
observation =  cumsum(2*rand(T,1) - 1);

% ----- plot ensemble and observation -----
figure
plot(ensemble,':')
hold on
plot(observation,'k-','LineWidth',2)

% ----- best linear combination to fit observation from ensemble data -----
X = [zeros(size(time)), ensemble];
a = regress(observation,X);
Y = ensemble*a(2:end);
plot(time,Y,'r--','LineWidth',2)
 


Das sieht ja schon ganz vielversprechend aus. Nun möchte ich aber gerne noch 2 Constraints einführen, sodass ich eine Konvexkombination (de.wikipedia.org/wiki/Linearkombination#Konvexkombination) bekomme. Soll heißen: Die Summe der Koeffizienten a_i soll 1 ergeben und alle a_i sollen >= 0 sein. Möglicherweise will ich sogar echt größer Null, da muss ich noch mal nachdenken. Im Wesentlichen möchte ich also ein gewichtetes Mittel des Ensembles, um eine Observation gut zu beschreiben.

Leider gibt es hier weder die Curve-Fitting, noch die Optimization Toolbox. Fällt jemandem etwas ein?

Viele Grüße, Nras.
Private Nachricht senden Benutzer-Profile anzeigen


Nras
Themenstarter

Forum-Meister

Forum-Meister


Beiträge: 608
Anmeldedatum: 21.02.12
Wohnort: ---
Version: 7.12.0.635 (R2011a)
     Beitrag Verfasst am: 05.11.2013, 21:13     Titel:
  Antworten mit Zitat      
Hallo,

ich würde das gerne noch mal genauer erklären. Im Prinzip tut der unten stehende Code (grüne Kurve) genau das, was ich möchte. Leider habe ich allerdings nur privat eine Lizenz für die Optimization Toolbox und kann diese zur Lösung des Problems in Wirklichkeit nicht nutzen.

Kennt jemand Hinweise zu einer Alternative, die nur mit der Statistics-Toolbox auskommt? Im Fileexchange habe ich zwar dieses hier gefunden http://www.mathworks.com/matlabcent.....insearchbnd-fminsearchcon, aber das kann leider den Constraint, dass die Summe der Koeffizienten 1 ergibt, nicht erfüllen, sondern das bietet nur einen Constraint für Ungleichungen.

Code:
% ----- generate data (N vectors of length T) -----
T = 500; N = 5;
time = (1:T)';
ensemble = cumsum(2*rand(T,N) - 1);
observation =  cumsum(2*rand(T,1) - 1);

% objective function to minimize: least squares:
objFun = @(a) sum((observation - ensemble*a').^2);
a0 = ones(1,N)/N;     % valid initial guess

% ----- Using fminsearch (no constraints) -----
aFminSearch = fminsearch(objFun, a0);

% ----- Using fmincon with two constraints for convexcombination
% 1) sum a_i = 1 (in matrix notation ones(1,N)*a' = 1)
% 2) a_i > 0  f.a. i = 1:N.
lb = zeros(1,N);        % lower boundary
ub = ones(1,N);         % upper boundary -- not expicitely needed
aFminCon = fmincon(objFun, a0, [], [], ones(1,N), 1, lb, ub);

% ----- plot observation, linear models and ensemble -----
figure
plot(time,observation,'k-','LineWidth',2)
hold on
plot(time, ensemble*aFminSearch','r--','LineWidth',2)
plot(time,ensemble*aFminCon','g--','LineWidth',2)
plot(time,ensemble,'b:')
legend('location','northwest','observation','unconstrained combination',...
    'convex combination','ensemble data')
 



Für Tipps wäre ich sehr dankbar.

Viele Grüße,
Nras.

convexcombination.png
 Beschreibung:

Download
 Dateiname:  convexcombination.png
 Dateigröße:  13.47 KB
 Heruntergeladen:  658 mal
Private Nachricht senden Benutzer-Profile anzeigen
 
Thomas84
Forum-Meister

Forum-Meister


Beiträge: 546
Anmeldedatum: 10.02.10
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 06.11.2013, 14:50     Titel:
  Antworten mit Zitat      
das geht mit folgender Funktion:

http://www.mathworks.com/matlabcentral/fileexchange/13835-lse

der Aufruf ist ähnlich wie bei lsqlin (Optimization Toolbox):

Code:

% ----- generate data (N vectors of length T) -----
T = 500; N = 5;
time = (1:T)';
ensemble = cumsum(2*rand(T,N) - 1);
observation =  cumsum(2*rand(T,1) - 1);

% ----- plot ensemble and observation -----
figure
plot(ensemble,'b:')
hold on
plot(observation,'k-','LineWidth',2)

% ----- best linear combination to fit observation from ensemble data -----
X = [zeros(size(time)), ensemble];
a_unconstrained = ensemble\observation;
Y_unconstrained = ensemble*a_unconstrained;

a_constrained = lsqlin(ensemble,observation,ones(1,N),1,[],[],zeros(N,1),[]);
Y_constrained = ensemble*a_constrained;

plot(time,Y_unconstrained,'r--','LineWidth',2)
plot(time,Y_constrained,'m--','LineWidth',2)
 


viele Grüße
Thomas
Private Nachricht senden Benutzer-Profile anzeigen
 
Nras
Themenstarter

Forum-Meister

Forum-Meister


Beiträge: 608
Anmeldedatum: 21.02.12
Wohnort: ---
Version: 7.12.0.635 (R2011a)
     Beitrag Verfasst am: 06.11.2013, 15:04     Titel:
  Antworten mit Zitat      
Hallo Thomas,

danke für die Info, damit kann ich die Summe auf 1 als Constraint setzen aber leider sind dann auch wieder negative Werte für die einzelen a_i möglich, da keine untere Grenze gesetzt werden kann.

Code:
>> a_constrained = lse(ensemble,observation,ones(1,N),1)
sum(a_constrained)

a_constrained =

    0.1642
   -0.0895
    0.4580
    0.1207
    0.3465


ans =

     1


Ich brauche aber beide Constraints gleichzeitig - mit fmincon als Einzeiler möglich, ohne fmincon habe ich da bisher noch keine freie Alternative gefunden.

Viele Grüße,
Nras.
Private Nachricht senden Benutzer-Profile anzeigen
 
Thomas84
Forum-Meister

Forum-Meister


Beiträge: 546
Anmeldedatum: 10.02.10
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 07.11.2013, 16:27     Titel:
  Antworten mit Zitat      
mit lsqlin ist es wie gesagt auch möglich. Und da dein Problem linear ist, ist dies in deinem Fall auch zu empfehlen. Außerhalb der optimization toolbox weiß ich allerdings auch keine Alternative.

viele Grüße
Thomas
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 - 2026 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.