Optimisation non linéaire
En optimisation, vue comme branche des mathématiques, l'optimisation non linéaire (en anglais : nonlinear programming – NLP) s'occupe principalement des problèmes d'optimisation dont les données, i.e., les fonctions et ensembles définissant ces problèmes, sont non linéaires, mais sont aussi différentiables autant de fois que nécessaire pour l'établissement des outils théoriques, comme les conditions d'optimalité, ou pour la bonne marche des algorithmes de résolution qui y sont introduits et analysés. Cette sous-discipline de l'optimisation, à la frontière mal définie et l'introduction un peu artificielle, Modèle:Refsou
Elle complémente l'optimisation non lisse (ou non différentiable), Modèle:Refsou Ces deux disciplines se rassemblent pour former ce que l'on appelle l'optimisation continue, qui jouxte, quant à elle, d'autres sous-disciplines telles que l'optimisation combinatoire (ou discrète), l'optimisation stochastique, etc.
Formulation mathématique
On a une fonction , avec . L'objectif est de déterminer le vecteur x défini par :
- .
De façon équivalente, on peut rechercher la valeur pour laquelle f est maximale :
- .
Méthodes de résolution
Si la fonction est convexe ou concave, et l'ensemble des contraintes est convexe, alors il existe des méthodes spécialisées, appelées méthodes d'optimisation convexe.
Sinon, il existe plusieurs solutions. Par exemple, utilisant le principe de séparation et évaluation pour diviser et traiter séparément plusieurs paramètres.
L'algorithme peut également être arrêté avant d'aboutir, si on peut prouver qu'aucune solution ultérieure ne sera meilleure à un certain seuil de tolérance près. Les conditions de Karush-Kuhn-Tucker (KKT) garantissent qu'une solution ainsi obtenue est optimale.
On utilise des algorithmes de résolution tels que :
- la méthode de Newton,
- la méthode de quasi-Newton,
- la méthode du gradient conjugué,
- la recherche linéaire,
- les régions de confiance,
- la méthode de Nelder-Mead,
- …
Contraintes
Si les contraintes s'expriment sous la forme d'inégalités
on peut utiliser la méthode de la « barrière logarithmique »[1]. Si ƒ est la fonction à minimiser, alors on définit la fonction
ainsi, lorsque Modèle:Mvar se rapproche de la frontière, la valeur de Modèle:Math tend vers Modèle:Math, ce qui pénalise la zone. On effectue plusieurs recherches en faisant tendre Modèle:Mvar vers 0.
Exemples
En dimension 2

Un problème simple peut être posé ainsi :
- xModèle:Ind ≥ 0
- xModèle:Ind ≥ 0
- xModèle:IndModèle:Exp + xModèle:IndModèle:Exp ≥ 1
- xModèle:IndModèle:Exp + xModèle:IndModèle:Exp ≤ 2
où l'on cherche à maximiser la fonction
- f (xModèle:Ind, xModèle:Ind) = xModèle:Ind + xModèle:Ind
En dimension 3

On peut formuler un problème ainsi :
- xModèle:IndModèle:Exp − xModèle:IndModèle:Exp + xModèle:IndModèle:Exp ≤ 2
- xModèle:IndModèle:Exp + xModèle:IndModèle:Exp + xModèle:IndModèle:Exp ≤ 10
où l'on cherche à maximiser la fonction :
- f(xModèle:Ind, xModèle:Ind, xModèle:Ind) = xModèle:IndxModèle:Ind + xModèle:IndxModèle:Ind
Notes et références
Voir aussi
Articles connexes
Bibliographie
- Modèle:En Avriel, Mordecai (2003), Nonlinear Programming: Analysis and Methods. Dover Publishing. Modèle:ISBN.
- Modèle:En Bazaraa, Mokhtar et Shetty (1979), Nonlinear programming. Theory and algorithms. John Wiley & Sons. Modèle:ISBN.
- Modèle:En Bertsekas, Dimitri (1999), Nonlinear Programming: Modèle:2nd Edition. Athena Scientific. Modèle:ISBN.
- Modèle:En J. F. Bonnans, J. Ch. Gilbert, C. Lemaréchal, C. Sagastizábal (2006), Numerical Optimization - Theoretical and Numerical Aspects Modèle:Détail des éditions
- Modèle:En Bonnans, J. F et Shapiro, A. (2000), Perturbation analysis of optimization problems. Springer. Modèle:ISBN.
- Modèle:En Nocedal, Jorge et Wright, Stephen (1999), Numerical Optimization. Springer. Modèle:ISBN.
Liens externes
Documentation
- Modèle:En Nonlinear programming FAQ
- Modèle:En Mathematical Programming Glossary
- Modèle:En Nonlinear Programming Survey OR/MS Today
Implémentations
- Modèle:En AIMMS Optimization Modeling AIMMS — include nonlinear programming in industry solutions ;
- Modèle:En AMPL solver software ;
- Modèle:En Artelys Knitro - solveur spécialisé dans la résolution de problèmes d'optimisation non linéaire de grande dimension (version d'essai disponible);
- Modèle:En GAMS General Algebraic Modeling System.
- ↑ Numerical optimization, Mark S. Gockenbach, Michigan Tech