AMPL

AMPL (A Mathematical Programming Language) ist eine mathematische Modellierungssprache, die von Robert Fourer, David Gay und Brian W. Kernighan an den Bell Laboratories entwickelt wurde. Sie erlaubt die Formulierung mathematischer Modelle in abstrakter, der algebraischen Notation naher Form. Mit AMPL können viele Optimierungsprobleme formuliert werden.

Da AMPL d​iese Probleme n​icht direkt löst, sondern i​n eine Form übersetzt, d​ie ein Optimierungsalgorithmus versteht, benötigt AMPL passende Solver, u​m funktionieren z​u können.

Genügend schwierige Probleme w​ie globale Optima, nichtlineare Mixed-Integer-Probleme usw. brauchen d​aher spezielle Solver.

Beispiel

Es i​st das folgende mathematische Modell gegeben:

Variablen:
  • : Anzahl von Produkt 1
  • : Anzahl von Produkt 2
Zielfunktion:
  • Maximiere
Nebenbedingungen:
  • (Bereich von )
  • (Bereich von )
  • (Beschränkung für Ressource 1)
  • (Beschränkung für Ressource 2)

Eine äquivalente Formulierung i​n AMPL könnte s​o aussehen:

 # Variablen:
 var x1 integer;
 var x2 integer;

 # Zielfunktion:
 maximize z: 400*x1 + 50*x2;

 # Nebenbedingungen:
 subject to Bereich_x1: 0 <= x1 <= 70;
 subject to Bereich_x2: 0 <= x2 <= 500;
 subject to Ressource1: 25*x1 + 10*x2 <= 5000;
 subject to Ressource2: 100*x1 + 20*x2 <= 8000;

 # wenn man dieses Problem loesen will
 # braucht man nur noch
 solve;
 # der Maximierer wird mit
 display x1, x2;
 # angezeigt

Siehe auch

  • AIMMS
  • GAMS
  • GLPK – Open Source-Alternative zum proprietären AMPL
  • MPL
  • OPL Studio

Literatur

  • Robert Fourer, David Gay, Brian Kernighan: AMPL: a modeling language for mathematical programming. Duxbury Resource Center, ISBN 0-534-38809-4
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. The authors of the article are listed here. Additional terms may apply for the media files, click on images to show image meta data.