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

binary integer programming (BIP) - eine Frage

 

petris
Forum-Newbie

Forum-Newbie


Beiträge: 2
Anmeldedatum: 19.10.08
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 19.10.2008, 14:12     Titel: binary integer programming (BIP) - eine Frage
  Antworten mit Zitat      
Hallo Zusammen, ich hätte folgende Frage:

Ich hab ein BI-Programm (sehe jpg beigefügt), das ich in matlab lösen möchte..mein Problem ist, dass es Tausende von Variablen und Ungleichungen gibt und ich kann nicht es nicht machen, indem ich wie in den Tutorials-Βeispielen die Funktion bintprog benutze..

hat jemand eine Ahnung, wie das zu machen ist, ohne explizit die Tausende Variablen und Constraints zu definieren ?

ich wäre dankbar.

bip.JPG
 Beschreibung:

Download
 Dateiname:  bip.JPG
 Dateigröße:  44.99 KB
 Heruntergeladen:  622 mal
Private Nachricht senden Benutzer-Profile anzeigen


Schrank
Forum-Century

Forum-Century


Beiträge: 203
Anmeldedatum: 10.07.08
Wohnort: Berlin
Version: ---
     Beitrag Verfasst am: 21.10.2008, 17:25     Titel:
  Antworten mit Zitat      
Hallo petris,
ich habe dein Problem leider nicht verstanden. Könntest du es vielleicht nochmal anders erklären. Insbesondere wäre es hilfreich, wenn du den Mathe-Teil der Aufgabe erledigst und es schaffst eine klar definierte Programmierfrage zu stellen.
Gruß Schrank
Private Nachricht senden Benutzer-Profile anzeigen
 
petris
Themenstarter

Forum-Newbie

Forum-Newbie


Beiträge: 2
Anmeldedatum: 19.10.08
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 21.10.2008, 18:28     Titel:
  Antworten mit Zitat      
Hallo Schrank,

vielen Dank für deine Antwort.

wenn man zB f(x) = –9x1 – 5x2 minimieren will

subject to the constraints
6x1 + 3x2 <=9
x1-x2<=3

dann macht man folgendes im Matlab:

f = [-9; -5;];
A = [6 3; 1 -1];
b = [9; 3; ];
x = bintprog(f,A,b) ..

mein Problem ist, dass ich 100000000constraints und variablen habe und die Matrixen A,b nicht expilizit wie im obigen Beispil definieren will.

ich wollte zB so etwas eingeben koennen (wie in attached file) :

Summe_über_j (Summe_über_i ( Summe_uber_k ( x(ijk) ) ) ) <= 5 fur alle k,

und nicht alle milliionen constraints:

x111+x121 + x131+ x141 + ........................ <=5
x112+x122 + x132+ x142 + ........................ <=5
.......
.....

Grusse
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: 21.10.2008, 18:56     Titel:
  Antworten mit Zitat      
Hallo petris,

ich habe schon einiges mit Matlab optimiert und ich denke, um die explizite Formulierung kommt man nicht herum.

Allerdings ist es wohl nicht so aufwändig, wie Du denkst. Denn, da alle Deine Variablen einen Vektor bilden (kein dreidimensionales array), musst Du ja nicht

x111+x121 + x131+ x141 + ........................ <=5

eingeben, sondern

Code:
% Summieren über den mittleren Index
vars1 = sub2ind([AnzVa,AnzVa,AnzK],ones(1,AnzVa),1:AnzVa,ones(1,AnzVa));
% Vektor, der Einsen an den erwünschten Stellen hat
b1 = zeros(AnzVa^2*AnzK,1);
b(vars1)=1;
% rechte Seite
A1 = 5;


Dabei ist AnzVa die Anzahl der Elemente von V_a, genauso AnzK. Es sieht vielleicht jetzt noch komplizierter aus als Deine Zeile, aber es lässt sich für die anderen Nebenbedingungen leicht anpassen oder sogar in wenigen Schritten zusammenfassen.

Vielleicht solltest Du Dir aber insgesamt überlegen, ob für eine so riesige Anzahl von Variablen und Nebenbedingungen nicht eher CPLEX oder so statt Matlab das geeignete Instrument ist.

Herzliche Grüße
Bijick
_________________

>> why
Private Nachricht senden Benutzer-Profile anzeigen E-Mail senden
 
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.