Jump to content

Mathematical optimization: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Shepworth (talk | contribs)
 
Line 1: Line 1:
{{short description|Study of mathematical algorithms for optimization problems}}
In [[mathematics]], the simplest case of '''optimization''', or '''mathematical programming''', refers to the study of problems in which one seeks to [[maxima and minima|minimize]] or [[maxima and minima|maximize]] a [[Function of a real variable|real function]] by systematically choosing the values of [[Real number|real]] or [[integer]] variables from within an allowed set. This (a scalar real valued objective function) is actually a small subset of this field which comprises a large area of [[applied mathematics]] and generalizes to study of means to obtain "best available" values of some objective function given a defined domain where the elaboration is on the types of functions and the conditions and nature of the objects in the problem domain.
{{redirect|Mathematical programming|the peer-reviewed journal|Mathematical Programming}}
{{redirect-multi|2|Optimization|Optimum}}
[[File:Max paraboloid.svg|right|thumb|Graph of a
surface given by ''z'' = f(''x'', ''y'') = −(''x''² + ''y''²) + 4. The global [[maximum (mathematics)|maximum]] at (''x, y, z'') = (0, 0, 4) is indicated by a blue dot.]]

[[File:Nelder-Mead Simionescu.gif|thumb|Nelder-Mead minimum search of [[Test functions for optimization|Simionescu's function]]. Simplex vertices are ordered by their values, with 1 having the lowest (<math>f(x)</math> best) value.|alt=]]

'''Mathematical optimization''' (alternatively spelled ''optimisation'') or '''mathematical programming''' is the selection of a best element, with regard to some criteria, from some set of available alternatives.<ref>"[http://glossary.computing.society.informs.org/index.php?page=nature.html The Nature of Mathematical Programming] {{webarchive|url=https://web.archive.org/web/20140305080324/http://glossary.computing.society.informs.org/index.php?page=nature.html |date=2014-03-05 }}," ''Mathematical Programming Glossary'', INFORMS Computing Society.</ref><ref>{{Cite web |title=Mathematical Programming: An Overview |url=https://web.mit.edu/15.053/www/AppliedMathematicalProgramming.pdf |access-date=26 April 2024}}</ref> It is generally divided into two subfields: [[discrete optimization]] and [[continuous optimization]]. Optimization problems arise in all quantitative disciplines from [[computer science]] and [[engineering]]<ref name="edo2021">{{Cite book|url=https://www.researchgate.net/publication/352413464|title=Engineering Design Optimization|last1=Martins|first1=Joaquim R. R. A.|last2=Ning|first2=Andrew|date=2021-10-01|publisher=Cambridge University Press|isbn=978-1108833417|language=en}}</ref> to [[operations research]] and [[economics]], and the development of solution methods has been of interest in [[mathematics]] for centuries.<ref>{{cite book |last1=Du |first1=D. Z. |last2=Pardalos |first2=P. M. |last3=Wu |first3=W. |year=2008 |chapter=History of Optimization |editor-link=Christodoulos Floudas |editor-last=Floudas |editor-first=C. |editor2-last=Pardalos |editor2-first=P. |title=Encyclopedia of Optimization |publisher=Springer |location=Boston |pages=1538–1542 }}</ref><ref>{{Cite web |title=Mathematical optimization |url=https://www.engati.com/glossary/mathematical-optimization |access-date=2024-08-24 |website=Engati |language=en}}</ref>

In the more general approach, an [[optimization problem]] consists of [[maxima and minima|maximizing or minimizing]] a [[Function of a real variable|real function]] by systematically choosing [[Argument of a function|input]] values from within an allowed set and computing the [[Value (mathematics)|value]] of the function. The generalization of optimization theory and techniques to other formulations constitutes a large area of [[applied mathematics]].<ref>{{Cite web |title=Open Journal of Mathematical Optimization |url=https://ojmo.centre-mersenne.org |access-date=2024-08-24 |website=ojmo.centre-mersenne.org}}</ref>

== Optimization problems ==
{{main|Optimization problem}}

Optimization problems can be divided into two categories, depending on whether the [[Variable (mathematics)|variables]] are [[continuous variable|continuous]] or [[discrete variable|discrete]]:
* An optimization problem with discrete variables is known as a ''[[discrete optimization]]'', in which an [[Mathematical object|object]] such as an [[integer]], [[permutation]] or [[Graph (discrete mathematics)|graph]] must be found from a [[countable set]].
* A problem with continuous variables is known as a ''[[continuous optimization]]'', in which optimal arguments from a continuous set must be found. They can include [[Constrained optimization|constrained problem]]s and multimodal problems.

An optimization problem can be represented in the following way:
:''Given:'' a [[function (mathematics)|function]] {{math|''f'' : ''A'' → <math>\mathbb R</math>}} from some [[Set (mathematics)|set]] {{mvar|A}} to the [[real number]]s
:''Sought:'' an element {{math|'''x'''<sub>0</sub> ∈ ''A''}} such that {{math|''f''('''x'''<sub>0</sub>) ≤ ''f''('''x''')}} for all {{math|'''x''' ∈ ''A''}} ("minimization") or such that {{math|''f''('''x'''<sub>0</sub>) ≥ ''f''('''x''')}} for all {{math|'''x''' ∈ ''A''}} ("maximization").

Such a formulation is called an '''[[optimization problem]]''' or a '''mathematical programming problem''' (a term not directly related to [[computer programming]], but still in use for example in [[linear programming]] – see [[#History|History]] below). Many real-world and theoretical problems may be modeled in this general framework.

Since the following is valid:

:<math>f(\mathbf{x}_{0})\geq f(\mathbf{x}) \Leftrightarrow -f(\mathbf{x}_{0})\leq -f(\mathbf{x}),</math>
it suffices to solve only minimization problems. However, the opposite perspective of considering only maximization problems would be valid, too.

Problems formulated using this technique in the fields of [[physics]] may refer to the technique as ''[[energy]] minimization'',<ref>{{cite book |title=Optimization algorithms in physics |last1=Hartmann |first1=Alexander K |last2=Rieger |first2=Heiko |date=2002 |publisher=Citeseer}}</ref> speaking of the value of the function {{mvar|f}} as representing the energy of the [[system]] being [[Mathematical model|modeled]]. In [[machine learning]], it is always necessary to continuously evaluate the quality of a data model by using a [[Loss function|cost function]] where a minimum implies a set of possibly optimal parameters with an optimal (lowest) error.

Typically, {{mvar|A}} is some [[subset]] of the [[Euclidean space]] <math>\mathbb R^n</math>, often specified by a set of ''[[constraint (mathematics)|constraints]]'', equalities or inequalities that the members of {{mvar|A}} have to satisfy. The [[domain of a function|domain]] {{mvar|A}} of {{mvar|f}} is called the ''search space'' or the ''choice set'', while the elements of {{mvar|A}} are called ''[[candidate solution]]s'' or ''feasible solutions''.

The function {{mvar|f}} is variously called an ''objective function'', ''criterion function'', ''[[loss function]]'', ''cost function'' (minimization),<ref>{{Citation |last=Erwin Diewert |first=W. |title=Cost Functions |date=2017 |work=The New Palgrave Dictionary of Economics |pages=1–12 |url=https://link.springer.com/referenceworkentry/10.1057/978-1-349-95121-5_659-2 |access-date=2024-08-18 |place=London |publisher=Palgrave Macmillan UK |language=en |doi=10.1057/978-1-349-95121-5_659-2 |isbn=978-1-349-95121-5}}</ref> ''utility function'' or ''fitness function'' (maximization), or, in certain fields, an ''energy function'' or ''energy [[functional (mathematics)|functional]]''. A feasible solution that minimizes (or maximizes) the objective function is called an ''optimal solution''.

In mathematics, conventional optimization problems are usually stated in terms of minimization.

A ''local minimum'' {{math|'''x'''*}} is defined as an element for which there exists some {{math|''δ'' > 0}} such that

:<math>\forall\mathbf{x}\in A \; \text{where} \;\left\Vert\mathbf{x}-\mathbf{x}^{\ast}\right\Vert\leq\delta,\,</math>

the expression {{math|''f''('''x'''*) ≤ ''f''('''x''')}} holds;

that is to say, on some region around {{math|'''x'''*}} all of the function values are greater than or equal to the value at that element.
Local maxima are defined similarly.

While a local minimum is at least as good as any nearby elements, a [[global minimum]] is at least as good as every feasible element.
Generally, unless the objective function is [[Convex function|convex]] in a minimization problem, there may be several local minima.
In a [[convex optimization|convex problem]], if there is a local minimum that is interior (not on the edge of the set of feasible elements), it is also the global minimum, but a nonconvex problem may have more than one local minimum not all of which need be global minima.

A large number of algorithms proposed for solving the nonconvex problems – including the majority of commercially available solvers – are not capable of making a distinction between locally optimal solutions and globally optimal solutions, and will treat the former as actual solutions to the original problem. [[Global optimization]] is the branch of [[applied mathematics]] and [[numerical analysis]] that is concerned with the development of deterministic algorithms that are capable of guaranteeing convergence in finite time to the actual optimal solution of a nonconvex problem.

== Notation ==
Optimization problems are often expressed with special notation. Here are some examples:

=== Minimum and maximum value of a function ===
Consider the following notation:
:<math>\min_{x\in\mathbb R}\; \left(x^2 + 1\right)</math>

This denotes the minimum [[Value (mathematics)|value]] of the objective function {{math|''x''<sup>2</sup> + 1}}, when choosing {{mvar|x}} from the set of [[real number]]s <math>\mathbb{R}</math>. The minimum value in this case is 1, occurring at {{math|1=''x'' = 0}}.

Similarly, the notation

:<math>\max_{x\in\mathbb R}\; 2x</math>

asks for the maximum value of the objective function {{math|2''x''}}, where {{mvar|x}} may be any real number. In this case, there is no such maximum as the objective function is unbounded, so the answer is "[[infinity]]" or "[[Undefined (mathematics)|undefined]]".

=== Optimal input arguments ===
{{Main|Arg max}}
Consider the following notation:
:<math>\underset{x\in(-\infty,-1]}{\operatorname{arg\,min}} \; x^2 + 1,</math>
or equivalently
:<math>\underset{x}{\operatorname{arg\,min}} \; x^2 + 1, \; \text{subject to:} \; x\in(-\infty,-1].</math>

This represents the value (or values) of the [[Argument of a function|argument]] {{mvar|x}} in the [[interval (mathematics)|interval]] {{math|(−∞,−1]}} that minimizes (or minimize) the objective function {{math|''x''<sup>2</sup> + 1}} (the actual minimum value of that function is not what the problem asks for). In this case, the answer is {{math|''x'' {{=}} −1}}, since {{math|''x'' {{=}} 0}} is infeasible, that is, it does not belong to the [[feasible set]].

Similarly,
:<math>\underset{x\in[-5,5], \; y\in\mathbb R}{\operatorname{arg\,max}} \; x\cos y,</math>
or equivalently
:<math>\underset{x, \; y}{\operatorname{arg\,max}} \; x\cos y, \; \text{subject to:} \; x\in[-5,5], \; y\in\mathbb R,</math>

represents the {{math|{''x'', ''y''<nowiki>}</nowiki>}} pair (or pairs) that maximizes (or maximize) the value of the objective function {{math|''x'' cos ''y''}}, with the added constraint that {{mvar|x}} lie in the interval {{math|[−5,5]}} (again, the actual maximum value of the expression does not matter). In this case, the solutions are the pairs of the form {{math|{5, 2''k''{{pi}}<nowiki>}</nowiki>}} and {{math|{−5, (2''k'' + 1){{pi}}<nowiki>}</nowiki>}}, where {{mvar|k}} ranges over all [[integer]]s.

Operators {{math|arg min}} and {{math|arg max}} are sometimes also written as {{math|argmin}} and {{math|argmax}}, and stand for ''argument of the minimum'' and ''argument of the maximum''.


== History ==
== History ==
[[Pierre de Fermat|Fermat]] and [[Joseph-Louis Lagrange|Lagrange]] found calculus-based formulae for identifying optima, while [[Isaac Newton|Newton]] and [[Carl Friedrich Gauss|Gauss]] proposed iterative methods for moving towards an optimum.
The first optimization technique, which is known as [[steepest descent]], goes back to [[Carl_Friedrich_Gauss|Gauss]]. Historically, the first term to be introduced was [[linear programming]], which was invented by [[George Dantzig]] in the 1940s. The term ''programming'' in this context does not refer to [[computer programming]] (although computers are nowadays used extensively to solve mathematical problems). Instead, the term comes from the use of ''program'' by the United States military to refer to proposed training and [[logistics]] schedules, which were the problems that Dantzig was studying at the time. (Additionally, later on, the use of the term "programming" was apparently important for receiving government funding, as it was associated with high-technology research areas that were considered important.)

The term "[[linear programming]]" for certain optimization cases was due to [[George Dantzig|George&nbsp;B. Dantzig]], although much of the theory had been introduced by [[Leonid Kantorovich]] in 1939. (''Programming'' in this context does not refer to [[computer programming]], but comes from the use of ''program'' by the [[United States]] military to refer to proposed training and [[logistics]] schedules, which were the problems Dantzig studied at that time.) Dantzig published the [[Simplex algorithm]] in 1947, and also [[John von Neumann]] and other researchers worked on the theoretical aspects of linear programming (like the theory of [[Linear programming#Duality|duality]]) around the same time.<ref>{{Cite journal |last=Bixby |first=Robert E |date=2012 |title=A brief history of linear and mixed-integer programming computation |url=https://www.math.uni-bielefeld.de/documenta/vol-ismp/25_bixby-robert.pdf |journal=Documenta Mathematica |series=Documenta Mathematica Series |volume=2012 |pages=107–121|doi=10.4171/dms/6/16 |isbn=978-3-936609-58-5 }}</ref>


Other important mathematicians in the optimization field include:
Other notable researchers in mathematical optimization include the following:
{{Div col|colwidth=20em}}
* [[Richard Bellman]]
* [[Richard Bellman]]
* [[Dimitri Bertsekas]]
* [[Leonid Vitalyevich Kantorovich]]
* [[Michel Bierlaire]]
* Leonid Khachian
* [[Stephen P. Boyd]]
* Arkadii Nemirovskii
* [[Roger Fletcher (mathematician)|Roger Fletcher]]
* Yurii Nesterov
* [[John von Neumann]]
* [[Martin Grötschel]]
* [[Ronald A. Howard]]
* Boris Polyak
* [[Fritz John]]
* [[Narendra Karmarkar]]
* [[William Karush]]
* [[Leonid Khachiyan]]
* [[Bernard Koopman]]
* [[Harold Kuhn]]
* [[László Lovász]]
* [[David Luenberger]]
* [[Arkadi Nemirovski]]
* [[Yurii Nesterov]]
* [[Lev Pontryagin]]
* [[R. Tyrrell Rockafellar]]
* [[Naum Z. Shor]]
* [[Naum Z. Shor]]
* [[Albert W. Tucker|Albert Tucker]]
* [[Michael J. Todd (mathematician)|Michael J. Todd]]
{{div col end}}
* [[Hoang Tuy]]
<!--In fact, some mathematical programming work had been done previously... (anyone? - Gauss did some stuff here) -->
<!--In fact, some mathematical programming work had been done previously... (anyone? - Gauss did some stuff here), Gauss developed the method of least squares, which is an optimization method. -->


== Major subfields ==
== Major subfields ==
* [[Linear programming]] studies the case in which the objective function ''f'' is linear and the set A is specified using only linear equalities and inequalities. Such a set is called a [[polyhedron]] or a [[polytope]] if it is [[bounded]].
* [[Convex programming]] studies the case when the objective function is [[convex function|convex]] (minimization) or [[Concave function|concave]] (maximization) and the constraint set is [[convex set|convex]]. This can be viewed as a particular case of nonlinear programming or as generalization of linear or convex quadratic programming.
** [[Linear programming]] (LP), a type of convex programming, studies the case in which the objective function ''f'' is linear and the constraints are specified using only linear equalities and inequalities. Such a constraint set is called a [[polyhedron]] or a [[polytope]] if it is [[Bounded set|bounded]].
* [[Integer programming]] studies linear programs in which some or all variables are constrained to take on [[integer]] values.
** [[Second-order cone programming]] (SOCP) is a convex program, and includes certain types of quadratic programs.
* [[Quadratic programming]] allows the objective function to have quadratic terms, while the set A must be specified with linear equalities and inequalities.
** [[Semidefinite programming]] (SDP) is a subfield of convex optimization where the underlying variables are [[semidefinite]] [[matrix (mathematics)|matrices]]. It is a generalization of linear and convex quadratic programming.
* [[Nonlinear programming]] studies the general case in which the objective function or the constraints or both contain nonlinear parts.
* [[Convex programming]] studies the case when the objective function is [[convex function|convex]] and the constraints, if any, form a convex set. This can be viewed as a particular case of nonlinear programming or as generalization of linear or convex quadratic programming.
** [[Conic programming]] is a general form of convex programming. LP, SOCP and SDP can all be viewed as conic programs with the appropriate type of cone.
** [[Geometric programming]] is a technique whereby objective and inequality constraints expressed as [[posynomials]] and equality constraints as [[monomials]] can be transformed into a convex program.
** [[Second order cone programming]] (SOCP).
* [[Semidefinite programming]] (SDP) is a subfield of convex optimization where the underlying variables are [[semidefinite]] [[matrix (mathematics)|matrices]]. It is generalization of linear and convex quadratic programming.
* [[Integer programming]] studies linear programs in which some or all variables are constrained to take on [[integer]] values. This is not convex, and in general much more difficult than regular linear programming.
* [[Quadratic programming]] allows the objective function to have quadratic terms, while the feasible set must be specified with linear equalities and inequalities. For specific forms of the quadratic term, this is a type of convex programming.
* [[Stochastic programming]] studies the case in which some of the constraints or parameters depends on [[random variable]]s.
* [[Fractional programming]] studies optimization of ratios of two nonlinear functions. The special class of concave fractional programs can be transformed to a convex optimization problem.
* [[Robust optimization|Robust programming]] is, as stochastic programming, an attempt to capture uncertainty in the data underlying the optimization problem. This is not done through the use of random variables, but instead, the problem is solved taking into account inaccuracies in the input data.
* [[Nonlinear programming]] studies the general case in which the objective function or the constraints or both contain nonlinear parts. This may or may not be a convex program. In general, whether the program is convex affects the difficulty of solving it.
* [[Stochastic programming]] studies the case in which some of the constraints or parameters depend on [[random variable]]s.
* [[Robust optimization]] is, like stochastic programming, an attempt to capture uncertainty in the data underlying the optimization problem. Robust optimization aims to find solutions that are valid under all possible realizations of the uncertainties defined by an uncertainty set.
* [[Combinatorial optimization]] is concerned with problems where the set of feasible solutions is discrete or can be reduced to a [[discrete mathematics|discrete]] one.
* [[Combinatorial optimization]] is concerned with problems where the set of feasible solutions is discrete or can be reduced to a [[discrete mathematics|discrete]] one.
* [[Stochastic optimization]] is used with random (noisy) function measurements or random inputs in the search process.
* [[Infinite-dimensional optimization]] studies the case when the set of feasible solutions is a subset of an infinite-[[dimension]]al space, such as a space of functions.
* [[Infinite-dimensional optimization]] studies the case when the set of feasible solutions is a subset of an infinite-[[dimension]]al space, such as a space of functions.
* [[Heuristic (computer science)|Heuristics]] and [[metaheuristic]]s make few or no assumptions about the problem being optimized. Usually, heuristics do not guarantee that any optimal solution need be found. On the other hand, heuristics are used to find approximate solutions for many complicated optimization problems.
* [[Heuristic algorithm]]s
* [[Constraint satisfaction]] studies the case in which the objective function ''f'' is constant (this is used in [[artificial intelligence]], particularly in [[automated reasoning]]).
** [[Metaheuristic]]s
** [[Constraint programming]] is a programming paradigm wherein relations between variables are stated in the form of constraints.
* [[Constraint satisfaction]] studies the case in which the objective function ''f'' is constant (this is used in [[artificial intelligence]], particularly in [[automated reasoning]]).
* Disjunctive programming is used where at least one constraint must be satisfied but not all. It is of particular use in scheduling.
** [[Constraint programming]].
* [[Space mapping]] is a concept for modeling and optimization of an engineering system to high-fidelity (fine) model accuracy exploiting a suitable physically meaningful coarse or [[surrogate model]].
* Disjunctive programming used where at least one constraint must be satisfied but not all. Of particular use in scheduling.

* [[Trajectory optimization]] is the speciality of optimizing trajectories for air and space vehicles.
In a number of subfields, the techniques are designed primarily for optimization in dynamic contexts (that is, decision making over time):
In a number of subfields, the techniques are designed primarily for optimization in dynamic contexts (that is, decision making over time):
* [[Calculus of variations]] seeks to optimize an objective defined over many points in time, by considering how the objective function changes if there is a small change in the choice path.
* [[Calculus of variations]] is concerned with finding the best way to achieve some goal, such as finding a surface whose boundary is a specific curve, but with the least possible area.
* [[Optimal control]] theory is a generalization of the calculus of variations.
* [[Optimal control]] theory is a generalization of the calculus of variations which introduces control policies.
* [[Dynamic programming]] studies the case in which the optimization strategy is based on splitting the problem into smaller subproblems. The equation that relates these subproblems is called the [[Bellman equation]].
* [[Dynamic programming]] is the approach to solve the [[stochastic optimization]] problem with stochastic, randomness, and unknown model parameters. It studies the case in which the optimization strategy is based on splitting the problem into smaller subproblems. The equation that describes the relationship between these subproblems is called the [[Bellman equation]].
* [[Mathematical programming with equilibrium constraints]] is where the constraints include [[variational inequalities]] or [[complementarity theory|complementarities]].
* [[Mathematical programming with equilibrium constraints]] is where the constraints include [[variational inequalities]] or [[complementarity theory|complementarities]].


=== Multi-objective optimization ===
== Optimization topics ==
{{Main|Multi-objective optimization}}
=== Optimization problems ===
Adding more than one objective to an optimization problem adds complexity. For example, to optimize a structural design, one would desire a design that is both light and rigid. When two objectives conflict, a trade-off must be created. There may be one lightest design, one stiffest design, and an infinite number of designs that are some compromise of weight and rigidity. The set of trade-off designs that improve upon one criterion at the expense of another is known as the [[Pareto set]]. The curve created plotting weight against stiffness of the best designs is known as the [[Pareto frontier]].
An optimization problem can be represented in the following way
:''Given:'' a [[function (mathematics)|function]] ''f'' : ''A'' <math>\to</math> '''R''' from some [[Set (mathematics)|set]] ''A'' to the [[real number]]s
:''Sought:'' an element ''x''<sub>0</sub> in ''A'' such that ''f''(''x''<sub>0</sub>) ≤ ''f''(''x'') for all ''x'' in ''A'' ("minimization") or such that ''f''(''x''<sub>0</sub>) ≥ ''f''(''x'') for all ''x'' in ''A'' ("maximization").


A design is judged to be "Pareto optimal" (equivalently, "Pareto efficient" or in the Pareto set) if it is not dominated by any other design: If it is worse than another design in some respects and no better in any respect, then it is dominated and is not Pareto optimal.
Such a formulation is called an '''[[optimization problem]]''' or a '''mathematical programming problem''' (a term not directly related to [[computer programming]], but still in use for example in [[linear programming]] - see [[#History|History]] above). Many real-world and theoretical problems may be modeled in this general framework. Problems formulated using this technique in the fields of [[physics]] and [[computer vision]] may refer to the technique as '''energy minimization''', speaking of the value of the function ''f'' as representing the energy of the [[system]] being [[Mathematical model|modeled]].


The choice among "Pareto optimal" solutions to determine the "favorite solution" is delegated to the decision maker. In other words, defining the problem as multi-objective optimization signals that some information is missing: desirable objectives are given but combinations of them are not rated relative to each other. In some cases, the missing information can be derived by interactive sessions with the decision maker.
Typically, ''A'' is some [[subset]] of the [[Euclidean space]] '''R'''<sup>''n''</sup>, often specified by a set of ''[[constraint (mathematics) |constraint]]s'', equalities or inequalities that the members of ''A'' have to satisfy. The [[domain (mathematics)|domain]] ''A'' of ''f'' is called the ''search space'',
while the elements of ''A'' are called ''[[candidate solution]]s'' or ''feasible solutions''.


Multi-objective optimization problems have been generalized further into [[vector optimization]] problems where the (partial) ordering is no longer given by the Pareto ordering.
The function ''f'' is called, variously, an '''objective function''', '''cost function''', '''energy function''', or '''energy [[functional (mathematics) |functional]]'''.<ref>
[http://ic.arc.nasa.gov/people/dhw/papers/78.pdf No Free Lunch Theorems for Optimization]
</ref> A feasible solution that minimizes (or maximizes, if that is the goal) the objective function is called an ''optimal solution''.


=== Multi-modal or global optimization ===
Generally, when the feasible region or the objective function of the problem does not present [[Convex set|convexity]], there may be several local minima and maxima, where a ''local minimum'' x<sup>*</sup> is defined as a point for which there exists some δ &gt; 0 so that for all x such that
Optimization problems are often multi-modal; that is, they possess multiple good solutions. They could all be globally good (same cost function value) or there could be a mix of globally good and locally good solutions. Obtaining all (or at least some of) the multiple solutions is the goal of a multi-modal optimizer.


Classical optimization techniques due to their iterative approach do not perform satisfactorily when they are used to obtain multiple solutions, since it is not guaranteed that different solutions will be obtained even with different starting points in multiple runs of the algorithm.
:<math>\|\mathbf{x}-\mathbf{x}^*\|\leq\delta;\,</math>


Common approaches to [[global optimization]] problems, where multiple local extrema may be present include [[evolutionary algorithm]]s, [[Bayesian optimization]] and [[simulated annealing]].
the expression


== Classification of critical points and extrema ==
:<math>f(\mathbf{x}^*)\leq f(\mathbf{x})</math>
holds; that is to say, on some region around x<sup>*</sup> all of the function values are greater than or equal to the value at that point. Local maxima are defined similarly.


=== Feasibility problem ===
A large number of algorithms proposed for solving non-convex problems – including the majority of commercially available solvers – are not capable of making a distinction between local optimal solutions and rigorous optimal solutions, and will treat the former as actual solutions to the original problem. The branch of [[applied mathematics]] and [[numerical analysis]] that is concerned with the development of deterministic algorithms that are capable of guaranteeing convergence in finite time to the actual optimal solution of a non-convex problem is called [[global optimization]].
The ''[[satisfiability problem]]'', also called the ''feasibility problem'', is just the problem of finding any [[feasible solution]] at all without regard to objective value. This can be regarded as the special case of mathematical optimization where the objective value is the same for every solution, and thus any solution is optimal.


Many optimization algorithms need to start from a feasible point. One way to obtain such a point is to [[Relaxation (approximation)|relax]] the feasibility conditions using a [[slack variable]]; with enough slack, any starting point is feasible. Then, minimize that slack variable until the slack is null or negative.
=== Notation ===
Optimization problems are often expressed with special notation. Here are some examples.


=== Existence ===
:<math>\min_{x\in\mathbb R}\; (x^2 + 1)</math>
The [[extreme value theorem]] of [[Karl Weierstrass]] states that a continuous real-valued function on a compact set attains its maximum and minimum value. More generally, a lower semi-continuous function on a compact set attains its minimum; an upper semi-continuous function on a compact set attains its maximum point or view.


=== Necessary conditions for optimality ===
This asks for the minimum value for the objective function <math>x</math><sup>2</sup><math> + 1</math>, where <math>x</math> ranges over the [[real number]]s <math>\mathbb R</math>. The minimum value in this case is <math>1</math>, occurring at <math>x = 0</math>.
[[Fermat's theorem (stationary points)|One of Fermat's theorems]] states that optima of unconstrained problems are found at [[stationary point]]s, where the first derivative or the gradient of the objective function is zero (see [[first derivative test]]). More generally, they may be found at [[Critical point (mathematics)|critical points]], where the first derivative or gradient of the objective function is zero or is undefined, or on the boundary of the choice set. An equation (or set of equations) stating that the first derivative(s) equal(s) zero at an interior optimum is called a 'first-order condition' or a set of first-order conditions.


Optima of equality-constrained problems can be found by the [[Lagrange multiplier]] method. The optima of problems with equality and/or inequality constraints can be found using the '[[Karush–Kuhn–Tucker conditions]]'.
:<math>\max_{x\in\mathbb R}\; 2x</math>


=== Sufficient conditions for optimality ===
This asks for the maximum value for the objective function 2''x'', where ''x'' ranges over the reals. In this case, there is no such maximum as the objective function is unbounded, so the answer is "[[infinity]]" or "undefined".
While the first derivative test identifies points that might be extrema, this test does not distinguish a point that is a minimum from one that is a maximum or one that is neither. When the objective function is twice differentiable, these cases can be distinguished by checking the second derivative or the matrix of second derivatives (called the [[Hessian matrix]]) in unconstrained problems, or the matrix of second derivatives of the objective function and the constraints called the [[Hessian matrix#Bordered Hessian|bordered Hessian]] in constrained problems. The conditions that distinguish maxima, or minima, from other stationary points are called 'second-order conditions' (see '[[Second derivative test]]'). If a candidate solution satisfies the first-order conditions, then the satisfaction of the second-order conditions as well is sufficient to establish at least local optimality.


=== Sensitivity and continuity of optima ===
:<math>\operatorname{argmin}_{x\in]-\infty;-1]}\; x^2 + 1\,</math>
The [[envelope theorem]] describes how the value of an optimal solution changes when an underlying [[parameter]] changes. The process of computing this change is called [[comparative statics]].


The [[maximum theorem]] of [[Claude Berge]] (1963) describes the continuity of an optimal solution as a function of underlying parameters.
This asks for the value (or values) of ''x'' in the [[interval (mathematics)|interval]] <math>]-\infty;-1]</math> that minimizes (or minimize) the objective function ''x''<sup>2</sup>&nbsp;+&nbsp;1 (the actual minimum value of that function does not matter). In this case, the answer is <math>x</math> = -1.


===Calculus of optimization===
:<math>\operatorname{argmax}_{x\in[-5,5],\;y\in\mathbb R}\; x\cdot\cos(y)\,</math>
{{Main|Karush–Kuhn–Tucker conditions}}
{{See also|Critical point (mathematics)|Differential calculus|Gradient|Hessian matrix|Definite matrix|Lipschitz continuity|Rademacher's theorem|Convex function|Convex analysis}}


For unconstrained problems with twice-differentiable functions, some [[critical point (mathematics)|critical points]] can be found by finding the points where the [[gradient]] of the objective function is zero (that is, the stationary points). More generally, a zero [[subgradient]] certifies that a local minimum has been found for [[convex optimization|minimization problems with convex]] [[convex function|functions]] and other [[Rademacher's theorem|locally]] [[Lipschitz function]]s, which meet in loss function minimization of the neural network. The positive-negative momentum estimation lets to avoid the local minimum and converges at the objective function global minimum.<ref>{{Cite journal |last1=Abdulkadirov |first1=R. |last2=Lyakhov |first2=P. |last3=Bergerman |first3=M. |last4=Reznikov |first4=D. |date=February 2024 |title=Satellite image recognition using ensemble neural networks and difference gradient positive-negative momentum |url=https://linkinghub.elsevier.com/retrieve/pii/S0960077923013346 |journal=Chaos, Solitons & Fractals |language=en |volume=179 |pages=114432 |doi=10.1016/j.chaos.2023.114432|bibcode=2024CSF...17914432A }}</ref>
This asks for the <math>(x,y)</math> pair (or pairs) that maximizes (or maximize) the value of the objective function <math>x*cos(y)</math>, with the added constraint that <math>x</math> lies in the interval <math>[-5;5]</math> (again, the actual maximum value of the expression does not matter). In this case, the solutions are the pairs of the form ( 5 ; 2k[[Pi|π]] ) and ( −5 ;(2k+1)π ), where <math>k</math> ranges over all [[integer]]s.


Further, critical points can be classified using the [[positive definite matrix|definiteness]] of the [[Hessian matrix]]: If the Hessian is ''positive'' definite at a critical point, then the point is a local minimum; if the Hessian matrix is negative definite, then the point is a local maximum; finally, if indefinite, then the point is some kind of [[saddle point]].
=== Techniques ===
Crudely all the methods are divided according to variables called:-<br />
SVO:- [[Single Variable Optimization]]<br />
MVO:- [[Multi Variable Optimization]]<br />
For twice-differentiable functions, unconstrained problems can be solved by finding the points where the [[gradient]] of the objective function is zero (that is, the stationary points) and using the [[Hessian matrix]] to classify the type of each point. If the Hessian is positive definite, the point is a local minimum, if negative definite, a local maximum, and if indefinite it is some kind of saddle point.


Constrained problems can often be transformed into unconstrained problems with the help of [[Lagrange multiplier]]s. [[Lagrangian relaxation]] can also provide approximate solutions to difficult constrained problems.
The existence of derivatives is not always assumed and many methods were devised for specific situations. The basic classes of methods, based on smoothness of the objective function, are:
* [[Combinatorial_optimization | Combinatorial methods]]
* [[Derivative-free methods]]
* [[First order methods]]
* [[Second-order methods]]


When the objective function is a [[convex function]], then any local minimum will also be a global minimum. There exist efficient numerical techniques for minimizing convex functions, such as [[interior-point method]]s.
Actual methods falling somewhere among the categories above include:
* [[Bundle methods]]
* [[Conjugate gradient method]]
* [[Ellipsoid method]]
* [[Gradient descent]] aka steepest descent or steepest ascent
* [[Interior point methods]]
* [[Line search]] - a technique for one dimensional optimization, usually used as a subroutine for other, more general techniques.
* [[Nelder-Mead method]] aka the Amoeba method
* [[Newton's method in optimization|Newton's method]]
* [[Quasi-Newton methods]]
* [[Simplex method]]
* [[Subgradient method]] - similar to gradient method in case there are no gradients


===Global convergence===
Should the objective function be [[Convex function|convex]] over the region of interest, then any local minimum will also be a global minimum. There exist robust, fast numerical techniques for optimizing twice differentiable convex functions. This is for your concern.
More generally, if the objective function is not a quadratic function, then many optimization methods use other methods to ensure that some subsequence of iterations converges to an optimal solution. The first and still popular method for ensuring convergence relies on [[line search]]es, which optimize a function along one dimension. A second and increasingly popular method for ensuring convergence uses [[trust region]]s. Both line searches and trust regions are used in modern methods of [[subgradient method|non-differentiable optimization]]. Usually, a global optimizer is much slower than advanced local optimizers (such as [[BFGS method|BFGS]]), so often an efficient global optimizer can be constructed by starting the local optimizer from different starting points.


== Computational optimization techniques ==
Constrained problems can often be transformed into unconstrained problems with the help of [[Lagrange multiplier]]s.
To solve problems, researchers may use [[algorithm]]s that terminate in a finite number of steps, or [[iterative method]]s that converge to a solution (on some specified class of problems), or [[heuristic algorithm|heuristics]] that may provide approximate solutions to some problems (although their iterates need not converge).


===Optimization algorithms===
Here are a few other popular methods:
* [[Ant colony optimization]]
{{main list|List of optimization algorithms}}
* [[Simplex algorithm]] of [[George Dantzig]], designed for [[linear programming]]
* [[Beam search]]
* Extensions of the simplex algorithm, designed for [[quadratic programming]] and for [[linear-fractional programming]]
* [[Bees algorithm]]
* Variants of the simplex algorithm that are especially suited for [[flow network|network optimization]]
* [[Combinatorial optimization|Combinatorial algorithms]]
* [[Quantum optimization algorithms]]

===Iterative methods===
{{Main|Iterative method}}

The [[iterative methods]] used to solve problems of [[nonlinear programming]] differ according to whether they [[subroutine|evaluate]] [[Hessian matrix|Hessians]], gradients, or only function values. While evaluating Hessians (H) and gradients (G) improves the rate of convergence, for functions for which these quantities exist and vary sufficiently smoothly, such evaluations increase the [[Computational complexity theory|computational complexity]] (or computational cost) of each iteration. In some cases, the computational complexity may be excessively high.

One major criterion for optimizers is just the number of required function evaluations as this often is already a large computational effort, usually much more effort than within the optimizer itself, which mainly has to operate over the N variables. The derivatives provide detailed information for such optimizers, but are even harder to calculate, e.g. approximating the gradient takes at least N+1 function evaluations. For approximations of the 2nd derivatives (collected in the Hessian matrix), the number of function evaluations is in the order of N². Newton's method requires the 2nd-order derivatives, so for each iteration, the number of function calls is in the order of N², but for a simpler pure gradient optimizer it is only N. However, gradient optimizers need usually more iterations than Newton's algorithm. Which one is best with respect to the number of function calls depends on the problem itself.
* Methods that evaluate Hessians (or approximate Hessians, using [[finite difference]]s):
** [[Newton's method in optimization|Newton's method]]
** [[Sequential quadratic programming]]: A Newton-based method for small-medium scale ''constrained'' problems. Some versions can handle large-dimensional problems.
** [[Interior point methods]]: This is a large class of methods for constrained optimization, some of which use only (sub)gradient information and others of which require the evaluation of Hessians.
* Methods that evaluate gradients, or approximate gradients in some way (or even subgradients):
** [[Coordinate descent]] methods: Algorithms which update a single coordinate in each iteration
** [[Conjugate gradient method]]s: [[Iterative method]]s for large problems. (In theory, these methods terminate in a finite number of steps with quadratic objective functions, but this finite termination is not observed in practice on finite–precision computers.)
** [[Gradient descent]] (alternatively, "steepest descent" or "steepest ascent"): A (slow) method of historical and theoretical interest, which has had renewed interest for finding approximate solutions of enormous problems.
** [[Subgradient method]]s: An iterative method for large [[Rademacher's theorem|locally]] [[Lipschitz continuity|Lipschitz functions]] using [[subgradient|generalized gradients]]. Following Boris T. Polyak, subgradient–projection methods are similar to conjugate–gradient methods.
** Bundle method of descent: An iterative method for small–medium-sized problems with locally Lipschitz functions, particularly for [[convex optimization|convex minimization]] problems (similar to conjugate gradient methods).
** [[Ellipsoid method]]: An iterative method for small problems with [[quasiconvex function|quasiconvex]] objective functions and of great theoretical interest, particularly in establishing the polynomial time complexity of some combinatorial optimization problems. It has similarities with Quasi-Newton methods.
** [[Frank–Wolfe algorithm|Conditional gradient method (Frank–Wolfe)]] for approximate minimization of specially structured problems with [[linear constraints]], especially with traffic networks. For general unconstrained problems, this method reduces to the gradient method, which is regarded as obsolete (for almost all problems).
** [[Quasi-Newton method]]s: Iterative methods for medium-large problems (e.g. N<1000).
** [[Simultaneous perturbation stochastic approximation]] (SPSA) method for stochastic optimization; uses random (efficient) gradient approximation.
* Methods that evaluate only function values: If a problem is continuously differentiable, then gradients can be approximated using finite differences, in which case a gradient-based method can be used.
** [[Interpolation]] methods
** [[Pattern search (optimization)|Pattern search]] methods, which have better convergence properties than the [[Nelder–Mead method|Nelder–Mead heuristic (with simplices)]], which is listed below.
** [[Mirror descent]]

===Heuristics===
{{Main|Heuristic algorithm}}

Besides (finitely terminating) [[algorithm]]s and (convergent) [[iterative method]]s, there are [[heuristic algorithm|heuristics]]. A heuristic is any algorithm which is not guaranteed (mathematically) to find the solution, but which is nevertheless useful in certain practical situations. List of some well-known heuristics:

{{div col}}
* [[Differential evolution]]
* [[Differential evolution]]
* [[Dynamic relaxation]]
* [[Dynamic relaxation]]
* [[Evolution strategy]]
* [[Evolutionary algorithms]]
* [[Genetic algorithms]]
* [[Genetic algorithms]]
* [[Hill climbing]] with random restart
* [[Harmony search]]
* [[Hill climbing]]
* [[Memetic algorithm]]
* [[Nelder–Mead method|Nelder–Mead simplicial heuristic]]: A popular heuristic for approximate minimization (without calling gradients)
* [[Particle swarm optimization]]
* [[Particle swarm optimization]]
* [[Quantum annealing]]
* [[Simulated annealing]]
* [[Simulated annealing]]
* [[Stochastic tunneling]]
* [[Stochastic tunneling]]
* [[Tabu search]]
* [[Tabu search]]{{colend}}


== Applications ==
=== Multi-objective optimization ===
{{main|Multiobjective optimization}}


===Mechanics===
Adding more than one objective to an optimization problem adds complexity. For example, if you wanted to optimize a structural design, you would want a design that is both light and rigid. Because these two objectives conflict, a trade-off exists. There will be one lightest design, one stiffest design, and an infinite number of designs that are some compromise of weight and stiffness. This set of trade-off designs is known as a Pareto set. The curve created plotting weight against stiffness of the best designs is known as the [[Pareto frontier]].
Problems in [[rigid body dynamics]] (in particular articulated rigid body dynamics) often require mathematical programming techniques, since you can view rigid body dynamics as attempting to solve an [[ordinary differential equation]] on a constraint manifold;<ref>{{cite journal |first=A.F. |last=Vereshchagin |title=Modelling and control of motion of manipulation robots |journal=Soviet Journal of Computer and Systems Sciences |volume=27 |issue=5 |pages=29–38 |year=1989}}</ref> the constraints are various nonlinear geometric constraints such as "these two points must always coincide", "this surface must not penetrate any other", or "this point must always lie somewhere on this curve". Also, the problem of computing contact forces can be done by solving a [[linear complementarity problem]], which can also be viewed as a QP (quadratic programming) problem.


Many design problems can also be expressed as optimization programs. This application is called design optimization. One subset is the [[engineering optimization]], and another recent and growing subset of this field is [[multidisciplinary design optimization]], which, while useful in many problems, has in particular been applied to [[aerospace engineering]] problems.
A design is judged to be Pareto optimal if it is not dominated by other designs: a Pareto optimal design must be better than another design in at least one aspect. If it is worse than another design in all respects, then it is dominated and is not Pareto optimal.


This approach may be applied in cosmology and astrophysics.<ref>{{cite journal |first1=S. |last1=Haggag|first2=F. |last2=Desokey|first3=M. |last3=Ramadan |title=A cosmological inflationary model using optimal control |journal= Gravitation and Cosmology|volume=23 |issue=3 |pages=236–239 |year=2017 |issn=1995-0721 | doi=10.1134/S0202289317030069 |bibcode=2017GrCo...23..236H|s2cid=125980981}}</ref>
== Uses ==
Problems in [[rigid body dynamics]] (in particular articulated rigid body dynamics) often require mathematical programming techniques, since you can view rigid body dynamics as attempting to solve an [[ordinary differential equation]] on a constraint manifold; the constraints are various nonlinear geometric constraints such as "these two points must always coincide", "this surface must not penetrate any other", or "this point must always lie somewhere on this curve". Also, the problem of computing contact forces can be done by solving a [[linear complementarity problem]], which can also be viewed as a QP (quadratic programming) problem.


===Economics and finance===
Many design problems can also be expressed as optimization programs. This application is called design optimization. One recent and growing subset of this field is [[multidisciplinary design optimization]], which, while useful in many problems, has in particular been applied to [[aerospace engineering]] problems.
[[Economics]] is closely enough linked to optimization of [[agent (economics)|agents]] that an influential definition relatedly describes economics ''qua'' science as the "study of human behavior as a relationship between ends and [[scarce]] means" with alternative uses.<ref>[[Lionel Robbins]] (1935, 2nd ed.) ''[[An Essay on the Nature and Significance of Economic Science#Major propositions|An Essay on the Nature and Significance of Economic Science]]'', Macmillan, p. 16.</ref> Modern optimization theory includes traditional optimization theory but also overlaps with [[game theory]] and the study of economic [[equilibrium (economics)|equilibria]]. The ''[[Journal of Economic Literature]]'' [[JEL classification codes|codes]] classify mathematical programming, optimization techniques, and related topics under [[JEL classification codes#Mathematical and quantitative methods JEL: C Subcategories|JEL:C61-C63]].


[[Mainstream economics]] also relies heavily on mathematical programming. An often studied problem in microeconomics, the [[utility maximization problem]], and its [[dual problem]] the [[Expenditure minimization problem]], are economic optimization problems. [[Consumers]] and firms are assumed to maximize their [[utility]]/[[profit]]. Also, agents are most frequently assumed to be [[risk-averse]] thereby wishing to minimize whatever risk they might be exposed to. [[Asset pricing|Asset prices]] are also explained using optimization though the underlying theory is more complicated than simple utility or profit optimization. [[Trade]] theory also uses optimization to explain trade patterns between nations.
In microeconomics, the [[utility maximization problem]] and its [[dual problem]], the [[expenditure minimization problem]], are economic optimization problems. Insofar as they behave consistently, [[consumer]]s are assumed to maximize their [[utility]], while [[firm]]s are usually assumed to maximize their [[Profit (economics)|profit]]. Also, agents are often modeled as being [[Risk aversion|risk-averse]], thereby preferring to avoid risk. [[Asset pricing|Asset prices]] are also modeled using optimization theory, though the underlying mathematics relies on optimizing [[stochastic process]]es rather than on static optimization. [[International trade theory]] also uses optimization to explain trade patterns between nations. The optimization of [[Portfolio (finance)|portfolios]] is an example of multi-objective optimization in economics.


Since the 1970s, economists have modeled dynamic decisions over time using [[control theory]].<ref>{{cite journal |first=Robert |last=Dorfman |author-link=Robert Dorfman |title=An Economic Interpretation of Optimal Control Theory |journal=[[American Economic Review]] |volume=59 |issue=5 |year=1969 |pages=817–831 |jstor=1810679 }}</ref> For example, dynamic [[search theory|search models]] are used to study [[labor economics|labor-market behavior]].<ref>{{cite book |first=Thomas J. |last=Sargent |author-link=Thomas J. Sargent |chapter=Search |title=Dynamic Macroeconomic Theory |publisher=Harvard University Press |year=1987 |pages=57–91 |isbn= 9780674043084|chapter-url=https://books.google.com/books?id=nVuyXF8ibeIC&pg=PA57 }}</ref> A crucial distinction is between deterministic and stochastic models.<ref>A.G. Malliaris (2008). "stochastic optimal control," ''The New Palgrave Dictionary of Economics'', 2nd Edition. [http://www.dictionaryofeconomics.com/article?id=pde2008_S000269&edition=&field=keyword&q=Taylor's%20th&topicid=&result_number=1 Abstract] {{Webarchive|url=https://web.archive.org/web/20171018182459/http://www.dictionaryofeconomics.com/article?id=pde2008_S000269&edition=&field=keyword&q=Taylor's%20th&topicid=&result_number=1 |date=2017-10-18 }}.</ref> [[Macroeconomics|Macroeconomists]] build [[dynamic stochastic general equilibrium|dynamic stochastic general equilibrium (DSGE)]] models that describe the dynamics of the whole economy as the result of the interdependent optimizing decisions of workers, consumers, investors, and governments.<ref>{{Cite journal |last1=Chaves Maza |first1=Manuel |last2=Fedriani |first2=Eugenio M. |last3=Ordaz Sanz |first3=José Antonio |date=2018-07-01 |title=Factores relevantes para optimizar los servicios públicos de apoyo a los emprendedores y la tasa de supervivencia de las empresas |url=http://dx.doi.org/10.15446/innovar.v28n69.71693 |journal=Innovar |volume=28 |issue=69 |pages=9–24 |doi=10.15446/innovar.v28n69.71693 |issn=2248-6968}}</ref><ref>{{cite journal |first1=Julio |last1=Rotemberg |author-link=Julio Rotemberg |author-link2=Michael Woodford (economist) |first2=Michael |last2=Woodford |year=1997 |title=An Optimization-based Econometric Framework for the Evaluation of Monetary Policy |journal=NBER Macroeconomics Annual |volume=12 |pages=297–346 |doi=10.2307/3585236 |jstor=3585236 |url=http://www.nber.org/chapters/c11041.pdf |doi-access=free }}</ref><ref>From ''[[The New Palgrave Dictionary of Economics]]'' (2008), 2nd Edition with Abstract links:<br />• "[http://www.dictionaryofeconomics.com/article?id=pde2008_N000148&edition=current&q=optimization&topicid=&result_number=1 numerical optimization methods in economics]" by Karl Schmedders<br />• "[http://www.dictionaryofeconomics.com/article?id=pde2008_C000348&edition=current&q=optimization&topicid=&result_number=4 convex programming]" by [[Lawrence E. Blume]]<br />• "[http://www.dictionaryofeconomics.com/article?id=pde2008_A000133&edition=current&q=optimization&topicid=&result_number=20 Arrow–Debreu model of general equilibrium]" by [[John Geanakoplos]].</ref>
Another field that uses optimization techniques extensively is [[operations research]].


===Electrical engineering===
== See also ==
Some common applications of optimization techniques in [[electrical engineering]] include [[active filter]] design,<ref>{{Cite journal|last1=De|first1=Bishnu Prasad|last2=Kar|first2=R.|last3=Mandal|first3=D.|last4=Ghoshal|first4=S.P.|date=2014-09-27|title=Optimal selection of components value for analog active filter design using simplex particle swarm optimization|journal=International Journal of Machine Learning and Cybernetics|volume=6|issue=4|pages=621–636|doi=10.1007/s13042-014-0299-0|s2cid=13071135|issn=1868-8071}}</ref> stray field reduction in superconducting magnetic energy storage systems, [[space mapping]] design of [[microwave]] structures,<ref>{{cite journal |last1=Koziel |first1=Slawomir |last2=Bandler |first2=John W. |title=Space Mapping With Multiple Coarse Models for Optimization of Microwave Components |journal=IEEE Microwave and Wireless Components Letters |date=January 2008 |volume=18 |issue=1 |pages=1–3 |doi=10.1109/LMWC.2007.911969|citeseerx=10.1.1.147.5407 |s2cid=11086218 }}</ref> handset antennas,<ref>{{cite journal |last1=Tu |first1=Sheng |last2=Cheng |first2=Qingsha S. |last3=Zhang |first3=Yifan |last4=Bandler |first4=John W. |last5=Nikolova |first5=Natalia K. |title=Space Mapping Optimization of Handset Antennas Exploiting Thin-Wire Models |journal=IEEE Transactions on Antennas and Propagation |date=July 2013 |volume=61 |issue=7 |pages=3797–3807 |doi=10.1109/TAP.2013.2254695|bibcode=2013ITAP...61.3797T |doi-access=free }}</ref><ref>N. Friedrich, [http://mwrf.com/software/space-mapping-outpaces-em-optimization-handset-antenna-design “Space mapping outpaces EM optimization in handset-antenna design,”] microwaves&rf, August 30, 2013.</ref><ref>{{cite journal |last1=Cervantes-González |first1=Juan C. |last2=Rayas-Sánchez |first2=José E. |last3=López |first3=Carlos A. |last4=Camacho-Pérez |first4=José R. |last5=Brito-Brito |first5=Zabdiel |last6=Chávez-Hurtado |first6=José L. |title=Space mapping optimization of handset antennas considering EM effects of mobile phone components and human body |journal=[[International Journal of RF and Microwave Computer-Aided Engineering]] |date=February 2016 |volume=26 |issue=2 |pages=121–128 |doi=10.1002/mmce.20945|s2cid=110195165 |doi-access=free }}</ref> electromagnetics-based design. Electromagnetically validated design optimization of microwave components and antennas has made extensive use of an appropriate physics-based or empirical [[surrogate model]] and [[space mapping]] methodologies since the discovery of [[space mapping]] in 1993.<ref>{{cite journal |last1=Bandler |first1=J.W. |last2=Biernacki |first2=R.M. |last3=Chen |first3=Shao Hua |last4=Grobelny |first4=P.A. |last5=Hemmers |first5=R.H. |title=Space mapping technique for electromagnetic optimization |journal=IEEE Transactions on Microwave Theory and Techniques |date=1994 |volume=42 |issue=12 |pages=2536–2544 |doi=10.1109/22.339794|bibcode=1994ITMTT..42.2536B }}</ref><ref>{{cite journal |last1=Bandler |first1=J.W. |last2=Biernacki |first2=R.M. |author3=Shao Hua Chen |last4=Hemmers |first4=R.H. |last5=Madsen |first5=K. |title=Electromagnetic optimization exploiting aggressive space mapping |journal=IEEE Transactions on Microwave Theory and Techniques |date=1995 |volume=43 |issue=12 |pages=2874–2882 |doi=10.1109/22.475649|bibcode=1995ITMTT..43.2874B }}</ref> Optimization techniques are also used in [[power-flow analysis]].<ref>{{cite conference|title=Convex relaxation of optimal power flow: A tutorial|conference=2013 iREP Symposium on Bulk Power System Dynamics and Control |url=https://ieeexplore.ieee.org/document/6629391|doi=10.1109/IREP.2013.6629391}}</ref>
{{multicol}}
*[[Arg max]]
*[[Brachistochrone]]
*[[Dynamic programming]]
*[[Fuzzy logic]]
*[[Game theory]]
*[[Goal Programming]]
{{multicol-break}}
*[[List of publications in mathematics#Optimization|Important publications in optimization]]
*[[Interior point method]]s
*[[Operations research]]
*[[Optimization problem]]
*[[:Category:Mathematical optimization software|Mathematical optimization software]]
*[[Process optimization]]
{{multicol-break}}
*[[Radial basis function]]
*[[Random optimization]]
*[[Simplex algorithm]]
*[[Topkis's Theorem]]
*[[Variational calculus]]
*[[Variational inequality]]
{{multicol-end}}


== Solvers ==
===Civil engineering===
Optimization has been widely used in civil engineering. [[Construction management]] and [[transportation engineering]] are among the main branches of civil engineering that heavily rely on optimization. The most common civil engineering problems that are solved by optimization are cut and fill of roads, life-cycle analysis of structures and infrastructures,<ref>{{cite journal |last1=Piryonesi |first1=Sayed Madeh |last2=Tavakolan |first2=Mehdi |title=A mathematical programming model for solving cost-safety optimization (CSO) problems in the maintenance of structures |journal=KSCE Journal of Civil Engineering |date=9 January 2017 |volume=21 |issue=6 |pages=2226–2234 |doi=10.1007/s12205-017-0531-z|bibcode=2017KSJCE..21.2226P |s2cid=113616284 |doi-access=free }}</ref> [[resource leveling]],<ref>{{cite journal |last1=Hegazy |first1=Tarek |title=Optimization of Resource Allocation and Leveling Using Genetic Algorithms |journal=Journal of Construction Engineering and Management |date=June 1999 |volume=125 |issue=3 |pages=167–175 |doi=10.1061/(ASCE)0733-9364(1999)125:3(167) |doi-access=}}</ref><ref name=":0">{{Cite journal|title=Piryonesi, S. M., Nasseri, M., & Ramezani, A. (2018). Resource leveling in construction projects with activity splitting and resource constraints: a simulated annealing optimization. |journal=Canadian Journal of Civil Engineering |date=9 July 2018 |volume=46 |pages=81–86|doi=10.1139/cjce-2017-0670|hdl=1807/93364|hdl-access=free|last1=Piryonesi |first1=S. Madeh |last2=Nasseri |first2=Mehran |last3=Ramezani |first3=Abdollah |s2cid=116480238 }}</ref> [[Hydrological optimization|water resource allocation]], [[traffic]] management<ref>{{Cite journal|last1=Herty|first1=M.|last2=Klar|first2=A.|date=2003-01-01|title=Modeling, Simulation, and Optimization of Traffic Flow Networks|url=https://epubs.siam.org/doi/10.1137/S106482750241459X|journal=SIAM Journal on Scientific Computing|volume=25|issue=3|pages=1066–1087|doi=10.1137/S106482750241459X|bibcode=2003SJSC...25.1066H |issn=1064-8275}}</ref> and schedule optimization.
*[[CPLEX]]
*[[IMSL Numerical Libraries]] are collections of math and statistical algorithms available in C/C++, Fortran, Java and C#/.NET. Optimization routines in the IMSL Libraries include unconstrained, linearly and nonlinearly constrained minimizations, and linear programming algorithms.
*[[IPOPT]] - an open-source primal-dual interior point method NLP solver which handles sparse matrices
*[[KNITRO]] - solver for nonlinear optimization problems
*[[Mathematica]] - handles linear programming, integer programming and constrained non-linear optimization problems
*[[NAG Numerical Libraries]]-The NAG Library contains a comprehensive collection of Optimization routines, which cover a diverse set of problems and circumstances.http://www.nag.co.uk/optimization/index.asp
*[[OpenOpt]] - a free toolbox with connections to lots of solvers, for Python language programmers
*[[Merlin]] - A Fortran-77, user friendly open source software package, for non-linear optimization with bound constraints. Available from the URL: http://merlin.cs.uoi.gr
*[[NLPQL]] - implementation of an SQP method for nonlinear constrained optimization. Available from the URL: http://www.klaus-schittkowski.de/


===Operations research===
==Notes==
Another field that uses optimization techniques extensively is [[operations research]].<ref>{{cite web|title=New force on the political scene: the Seophonisten |url=http://www.seophonist-wahl.de/ |access-date=14 September 2013 |url-status=dead |archive-url=https://web.archive.org/web/20141218090504/http://www.seophonist-wahl.de/ |archive-date=18 December 2014 }}</ref> Operations research also uses stochastic modeling and simulation to support improved decision-making. Increasingly, operations research uses [[stochastic programming]] to model dynamic decisions that adapt to events; such problems can be solved with large-scale optimization and [[stochastic optimization]] methods.
{{refs}}


===Control engineering===
==References==
Mathematical optimization is used in much modern controller design. High-level controllers such as [[model predictive control]] (MPC) or real-time optimization (RTO) employ mathematical optimization. These algorithms run online and repeatedly determine values for decision variables, such as choke openings in a process plant, by iteratively solving a mathematical optimization problem including constraints and a model of the system to be controlled.
* Mordecai Avriel (2003).'' Nonlinear Programming: Analysis and Methods.'' Dover Publishing. ISBN 0-486-43227-0.
* Stephen Boyd and Lieven Vandenberghe (2004). [http://www.stanford.edu/~boyd/cvxbook/ Convex Optimization], Cambridge University Press. ISBN 0-521-83378-7.
* Elster K.-H. (1993), Modern Mathematical Methods of Optimization, Vch Pub. ISBN 3055014529.
* Jorge Nocedal and Stephen J. Wright (2006). [http://www.ece.northwestern.edu/~nocedal/book/num-opt.html Numerical Optimization], Springer. ISBN 0-387-30303-0.
* Panos Y. Papalambros and Douglass J. Wilde (2000). [http://www.optimaldesign.org/ Principles of Optimal Design : Modeling and Computation], Cambridge University Press. ISBN 0-521-62727-3.
* Yang X.-S. (2008), Introduction to Mathematical Optimization: From Linear Programming to Metaheuristics, Cambridge Int. Science Publishing. ISBN 1-904602827.


===Geophysics===
== External links ==
Optimization techniques are regularly used in [[geophysics|geophysical]] parameter estimation problems. Given a set of geophysical measurements, e.g. [[seismology|seismic recordings]], it is common to solve for the [[mineral physics|physical properties]] and [[structure of the earth|geometrical shapes]] of the underlying rocks and fluids. The majority of problems in geophysics are nonlinear with both deterministic and stochastic methods being widely used.
{{linkfarm}}
* [http://www.coin-or.org/ COIN-OR] &mdash; Computational Infrastructure for Operations Research
* [http://www.convexoptimization.com Convex Optimization & Euclidean Distance Geometry] by Jon Dattorro
* [http://plato.asu.edu/guide.html Decision Tree for Optimization Software] Links to optimization source codes
* [http://www.mat.univie.ac.at/%7Eneum/glopt.html Global optimization]
* [http://glossary.computing.society.informs.org/ Mathematical Programming Glossary]
* [http://www.ipp.mpg.de/de/for/bereiche/stellarator/Comp_sci/CompScience/csep/csep1.phy.ornl.gov/mo/mo.html Mathematical optimization]
* [http://www.mathprog.org/ Mathematical Programming Society]
* [http://www-fp.mcs.anl.gov/otc/Guide/index.html NEOS Guide] currently being replaced by the [http://wiki.mcs.anl.gov/neos NEOS Wiki]
* [http://www.optimization-online.org Optimization Online] A repository for optimization e-prints
* [http://www2.arnes.si/%7Eljc3m2/igor/links.html Optimization Related Links]
* [http://www.bowdoin.edu/faculty/a/alevy/book.shtml The Basics of Practical Optimization] An undergraduate optimization text
* [http://see.stanford.edu/see/courseinfo.aspx?coll=2db7ced4-39d1-4fdb-90e8-364129597c87 Convex Optimization I] EE364a: Course from Stanford University
* [http://www.bowdoin.edu/faculty/a/alevy/book.shtml Convex Optimization – Boyd and Vandenberghe] Book on Convex Optimization
* [http://simplemax.net Simplemax Online Optimization Services] Web applications to access nonlinear optimization services


===Molecular modeling===
'''Modeling languages:'''
{{main|Molecular modeling}}
* [http://www.aimms.com AIMMS]
Nonlinear optimization methods are widely used in [[conformational analysis]].
* [http://www.ampl.com/ AMPL]
* [http://www.gams.com/ GAMS] &mdash; General Algebraic Modeling System
* [http://www.maximal-usa.com/mpl/ MPL]
* [http://www.ilog.com/products/oplstudio/ OPL]
* [http://www.ateji.com/optimj.html OPTIMJ]


===Computational systems biology===
'''Solvers:'''
{{main|Computational systems biology}}
* [http://www.conopt.com/ CONOPT]
Optimization techniques are used in many facets of computational systems biology such as model building, optimal experimental design, metabolic engineering, and synthetic biology.<ref name="Papoutsakis 1984">{{Cite journal|last=Papoutsakis|first=Eleftherios Terry|date=February 1984|title=Equations and calculations for fermentations of butyric acid bacteria|journal=Biotechnology and Bioengineering|volume=26|issue=2|pages=174–187|doi=10.1002/bit.260260210|pmid=18551704|s2cid=25023799|issn=0006-3592}}</ref> [[Linear programming]] has been applied to calculate the maximal possible yields of fermentation products,<ref name="Papoutsakis 1984" /> and to infer gene regulatory networks from multiple microarray datasets<ref>{{Cite journal|last1=Wang|first1=Yong|last2=Joshi|first2=Trupti|last3=Zhang|first3=Xiang-Sun|last4=Xu|first4=Dong|last5=Chen|first5=Luonan|date=2006-07-24|title=Inferring gene regulatory networks from multiple microarray datasets |journal=Bioinformatics|language=en|volume=22|issue=19|pages=2413–2420|doi=10.1093/bioinformatics/btl396|pmid=16864593|issn=1460-2059|doi-access=}}</ref> as well as transcriptional regulatory networks from high-throughput data.<ref>{{Cite journal|last1=Wang|first1=Rui-Sheng|last2=Wang|first2=Yong|last3=Zhang|first3=Xiang-Sun|last4=Chen|first4=Luonan|date=2007-09-22|title=Inferring transcriptional regulatory networks from high-throughput data|journal=Bioinformatics|volume=23|issue=22|pages=3056–3064|doi=10.1093/bioinformatics/btm465|pmid=17890736|issn=1460-2059|doi-access=free}}</ref> [[Nonlinear programming]] has been used to analyze energy metabolism<ref>{{Cite journal|last1=Vo|first1=Thuy D.|last2=Paul Lee|first2=W.N.|last3=Palsson|first3=Bernhard O.|date=May 2007|title=Systems analysis of energy metabolism elucidates the affected respiratory chain complex in Leigh's syndrome|journal=Molecular Genetics and Metabolism|volume=91|issue=1|pages=15–22|doi=10.1016/j.ymgme.2007.01.012|pmid=17336115|issn=1096-7192}}</ref> and has been applied to metabolic engineering and parameter estimation in biochemical pathways.<ref>{{Cite journal|last1=Mendes|first1=P.|author-link1 = Pedro Pedrosa Mendes|last2=Kell|first2=D.|date=1998|title=Non-linear optimization of biochemical pathways: applications to metabolic engineering and parameter estimation|journal=Bioinformatics|volume=14|issue=10|pages=869–883|issn=1367-4803|pmid=9927716|doi=10.1093/bioinformatics/14.10.869|doi-access=free}}</ref>
* [http://www.ilog.com/products/cplex/ CPLEX] - linear, quadratic, and mixed-integer programming solver
* [http://www.stanford.edu/group/SOL/software.html Free Optimization Software by Systems Optimization Laboratory, Stanford University]
* [http://www.dna-evolutions.com/dnaappletsample.html JOpt]
* [http://trilinos.sandia.gov/packages/moocho/ Moocho] - a very flexible open-source NLP solver
* [http://www.mosek.com/ Mosek] - linear, quadratic, conic and mixed-integer programming solver
* [http://www.sas.com/technologies/analytics/optimization/ SAS/OR]
* [http://www.fea-optimization.com/optm/index_e.htm SmartDO] - Engineering global optimization (commercial) software
* [http://www.ime.usp.br/~egbirgin/tango/ TANGO Project] - Trustable Algorithms for Nonlinear General Optimization


===Machine learning===
'''Libraries:'''
{{main|Machine learning#Optimization}}
* [http://www.alglib.net/optimization/ ALGLIB] Optimization sources. C++, C#, Delphi, Visual Basic.
* [http://www.ilog.com/products/cplex/product/interfaces.cfm CPLEX Component Libraries]
* [http://www2.arnes.si/~ljc3m2/igor/ioptlib/ IOptLib (Investigative Optimization Library)] - a free open source library for development of optimization algorithms (ANSI C).
* [http://optalgtoolkit.sourceforge.net/ OAT (Optimization Algorithm Toolkit)] - a set of standard optimization algorithms and problems in Java.
* [http://ool.sourceforge.net/ OOL (Open Optimization library)] - a set of optimization routines in C.


== Solvers ==
{{Mathematics-footer}}
{{main|List of optimization software}}
{{Systems Engineering}}

==See also==
{{colbegin|colwidth=22em}}
* [[Brachistochrone curve]]
* [[Curve fitting]]
* [[Deterministic global optimization]]
* [[Goal programming]]
* [[List of publications in mathematics#Optimization|Important publications in optimization]]
* [[Least squares]]
* [[Mathematical Optimization Society]] (formerly Mathematical Programming Society)
* [[:Category:Optimization algorithms and methods|Mathematical optimization algorithms]]
* [[:Category:Mathematical optimization software|Mathematical optimization software]]
* [[Process optimization]]
* [[Simulation-based optimization]]
* [[Test functions for optimization]]
* [[Vehicle routing problem]]
{{colend}}

==Notes==
{{Reflist}}

==Further reading==
* {{cite book |last1=Boyd |first1=Stephen P. |author-link=Stephen P. Boyd |first2=Lieven |last2=Vandenberghe |title=Convex Optimization |location=Cambridge |publisher=Cambridge University Press |year=2004 |isbn=0-521-83378-7 |url=https://web.stanford.edu/~boyd/cvxbook/ |ref=none}}
* {{cite book |first1=P. E. |last1=Gill |first2=W. |last2=Murray |first3=M. H. |last3=Wright |author-link3=Margaret H. Wright |year=1982 |title=Practical Optimization |publisher=Academic Press |location=London |isbn=0-12-283952-8 |ref=none}}
* {{cite book |last=Lee |first=Jon |author-link=Jon Lee (mathematician) |title=A First Course in Combinatorial Optimization |publisher=Cambridge University Press |year=2004 |isbn=0-521-01012-8 |ref=none}}
* {{cite book | year=2006 |url=http://www.ece.northwestern.edu/~nocedal/book/num-opt.html |title=Numerical Optimization |edition=2nd |publisher=Springer |location=Berlin |isbn=0-387-30303-0 |first1=Jorge |last1=Nocedal |author-link=Jorge Nocedal |first2=Stephen J. |last2=Wright |ref=none}}
* G.L. Nemhauser, A.H.G. Rinnooy Kan and M.J. Todd (eds.): ''Optimization'', Elsevier, (1989).
* Stanislav Walukiewicz:''Integer Programming'', Springer,ISBN 978-9048140688, (1990).
* R. Fletcher: ''Practical Methods of Optimization'', 2nd Ed.,Wiley, (2000).
* Panos M. Pardalos:''Approximation and Complexity in Numerical Optimization: Continuous and Discrete Problems'', Springer,ISBN 978-1-44194829-8, (2000).
* Xiaoqi Yang, K. L. Teo, Lou Caccetta (Eds.):''Optimization Methods and Applications'',Springer, ISBN 978-0-79236866-3, (2001).
* Panos M. Pardalos, and Mauricio G. C. Resende(Eds.):''Handbook of Applied Optimization''、Oxford Univ Pr on Demand, ISBN 978-0-19512594-8, (2002).
* Wil Michiels, Emile Aarts, and Jan Korst: ''Theoretical Aspects of Local Search'', Springer, ISBN 978-3-64207148-5, (2006).
* Der-San Chen, Robert G. Batson,and Yu Dang: ''Applied Integer Programming: Modeling and Solution'',Wiley,ISBN 978-0-47037306-4, (2010).
* Mykel J. Kochenderfer and Tim A. Wheeler: ''Algorithms for Optimization'', The MIT Press, ISBN 978-0-26203942-0, (2019).
* Vladislav Bukshtynov: ''Optimization: Success in Practice'', CRC Press (Taylor & Francis), ISBN 978-1-03222947-8, (2023) .
* Rosario Toscano: ''Solving Optimization Problems with the Heuristic Kalman Algorithm: New Stochastic Methods'', Springer, ISBN 978-3-031-52458-5 (2024).
* Immanuel M. Bomze, Tibor Csendes, Reiner Horst and Panos M. Pardalos: ''Developments in Global Optimization'', Kluwer Academic, ISBN 978-1-4419-4768-0 (2010).

==External links==
{{Commons category}}
* {{cite web |url=http://plato.asu.edu/guide.html |title=Decision Tree for Optimization Software }} Links to optimization source codes
* {{cite web |url=https://www.mat.univie.ac.at/~neum/glopt.html |title=Global optimization }}
* {{cite web |url=https://see.stanford.edu/Course/EE364A |title=EE364a: Convex Optimization I |work=Course from Stanford University }}
* {{cite web |title=Mathematical Optimization: Finding Minima of Functions |first=Gaël |last=Varoquaux |url=https://scipy-lectures.org/advanced/mathematical_optimization/index.html }}

{{Optimization algorithms |state=expanded}}
{{Areas of mathematics |collapsed}}
{{Systems engineering |collapsed}}
{{Authority control}}


[[Category:Mathematical optimization| ]]
[[Category:Mathematical optimization| ]]
[[Category:Operations research]]
[[Category:Operations research]]
[[Category:Mathematical and quantitative methods (economics)|Optimization]]

[[ar:رياضيات الاستمثال]]
[[bn:সেরা-অনুকূলকরণ (গণিত)]]
[[cs:Optimalizace (matematika)]]
[[da:Optimering (matematik)]]
[[de:Optimierung (Mathematik)]]
[[el:Βελτιστοποίηση]]
[[es:Optimización (matemática)]]
[[eo:Optimumigo (matematiko)]]
[[fa:بهینه‌سازی (ریاضیات)]]
[[fr:Optimisation (mathématiques)]]
[[ko:최적화 문제]]
[[hi:अभीष्टीकरण]]
[[id:Optimisasi]]
[[it:Ottimizzazione (matematica)]]
[[he:אופטימיזציה (מתמטיקה)]]
[[lo:ການຊອກຄ່າເໝາະສົມ (ຄະນິດສາດ)]]
[[lt:Optimizavimas (matematika)]]
[[ja:最適化問題]]
[[pl:Optymalizacja (matematyka)]]
[[ro:Optimizare]]
[[ru:Оптимизация (математика)]]
[[sk:Optimalizácia (matematika)]]
[[sl:Optimizacija (matematika)]]
[[sr:Оптимизација (математика)]]
[[su:Optimisasi (matematik)]]
[[fi:Matemaattinen optimointi]]
[[sv:Optimeringslära]]
[[vi:Tối ưu hóa (toán học)]]
[[tr:Optimizasyon]]
[[uk:Задача оптимізації]]
[[zh:最优化]]

Latest revision as of 21:49, 7 January 2025

Graph of a surface given by z = f(x, y) = −(x² + y²) + 4. The global maximum at (x, y, z) = (0, 0, 4) is indicated by a blue dot.
Nelder-Mead minimum search of Simionescu's function. Simplex vertices are ordered by their values, with 1 having the lowest ( best) value.

Mathematical optimization (alternatively spelled optimisation) or mathematical programming is the selection of a best element, with regard to some criteria, from some set of available alternatives.[1][2] It is generally divided into two subfields: discrete optimization and continuous optimization. Optimization problems arise in all quantitative disciplines from computer science and engineering[3] to operations research and economics, and the development of solution methods has been of interest in mathematics for centuries.[4][5]

In the more general approach, an optimization problem consists of maximizing or minimizing a real function by systematically choosing input values from within an allowed set and computing the value of the function. The generalization of optimization theory and techniques to other formulations constitutes a large area of applied mathematics.[6]

Optimization problems

[edit]

Optimization problems can be divided into two categories, depending on whether the variables are continuous or discrete:

An optimization problem can be represented in the following way:

Given: a function f : A from some set A to the real numbers
Sought: an element x0A such that f(x0) ≤ f(x) for all xA ("minimization") or such that f(x0) ≥ f(x) for all xA ("maximization").

Such a formulation is called an optimization problem or a mathematical programming problem (a term not directly related to computer programming, but still in use for example in linear programming – see History below). Many real-world and theoretical problems may be modeled in this general framework.

Since the following is valid:

it suffices to solve only minimization problems. However, the opposite perspective of considering only maximization problems would be valid, too.

Problems formulated using this technique in the fields of physics may refer to the technique as energy minimization,[7] speaking of the value of the function f as representing the energy of the system being modeled. In machine learning, it is always necessary to continuously evaluate the quality of a data model by using a cost function where a minimum implies a set of possibly optimal parameters with an optimal (lowest) error.

Typically, A is some subset of the Euclidean space , often specified by a set of constraints, equalities or inequalities that the members of A have to satisfy. The domain A of f is called the search space or the choice set, while the elements of A are called candidate solutions or feasible solutions.

The function f is variously called an objective function, criterion function, loss function, cost function (minimization),[8] utility function or fitness function (maximization), or, in certain fields, an energy function or energy functional. A feasible solution that minimizes (or maximizes) the objective function is called an optimal solution.

In mathematics, conventional optimization problems are usually stated in terms of minimization.

A local minimum x* is defined as an element for which there exists some δ > 0 such that

the expression f(x*) ≤ f(x) holds;

that is to say, on some region around x* all of the function values are greater than or equal to the value at that element. Local maxima are defined similarly.

While a local minimum is at least as good as any nearby elements, a global minimum is at least as good as every feasible element. Generally, unless the objective function is convex in a minimization problem, there may be several local minima. In a convex problem, if there is a local minimum that is interior (not on the edge of the set of feasible elements), it is also the global minimum, but a nonconvex problem may have more than one local minimum not all of which need be global minima.

A large number of algorithms proposed for solving the nonconvex problems – including the majority of commercially available solvers – are not capable of making a distinction between locally optimal solutions and globally optimal solutions, and will treat the former as actual solutions to the original problem. Global optimization is the branch of applied mathematics and numerical analysis that is concerned with the development of deterministic algorithms that are capable of guaranteeing convergence in finite time to the actual optimal solution of a nonconvex problem.

Notation

[edit]

Optimization problems are often expressed with special notation. Here are some examples:

Minimum and maximum value of a function

[edit]

Consider the following notation:

This denotes the minimum value of the objective function x2 + 1, when choosing x from the set of real numbers . The minimum value in this case is 1, occurring at x = 0.

Similarly, the notation

asks for the maximum value of the objective function 2x, where x may be any real number. In this case, there is no such maximum as the objective function is unbounded, so the answer is "infinity" or "undefined".

Optimal input arguments

[edit]

Consider the following notation:

or equivalently

This represents the value (or values) of the argument x in the interval (−∞,−1] that minimizes (or minimize) the objective function x2 + 1 (the actual minimum value of that function is not what the problem asks for). In this case, the answer is x = −1, since x = 0 is infeasible, that is, it does not belong to the feasible set.

Similarly,

or equivalently

represents the {x, y} pair (or pairs) that maximizes (or maximize) the value of the objective function x cos y, with the added constraint that x lie in the interval [−5,5] (again, the actual maximum value of the expression does not matter). In this case, the solutions are the pairs of the form {5, 2kπ} and {−5, (2k + 1)π}, where k ranges over all integers.

Operators arg min and arg max are sometimes also written as argmin and argmax, and stand for argument of the minimum and argument of the maximum.

History

[edit]

Fermat and Lagrange found calculus-based formulae for identifying optima, while Newton and Gauss proposed iterative methods for moving towards an optimum.

The term "linear programming" for certain optimization cases was due to George B. Dantzig, although much of the theory had been introduced by Leonid Kantorovich in 1939. (Programming in this context does not refer to computer programming, but comes from the use of program by the United States military to refer to proposed training and logistics schedules, which were the problems Dantzig studied at that time.) Dantzig published the Simplex algorithm in 1947, and also John von Neumann and other researchers worked on the theoretical aspects of linear programming (like the theory of duality) around the same time.[9]

Other notable researchers in mathematical optimization include the following:

Major subfields

[edit]
  • Convex programming studies the case when the objective function is convex (minimization) or concave (maximization) and the constraint set is convex. This can be viewed as a particular case of nonlinear programming or as generalization of linear or convex quadratic programming.
    • Linear programming (LP), a type of convex programming, studies the case in which the objective function f is linear and the constraints are specified using only linear equalities and inequalities. Such a constraint set is called a polyhedron or a polytope if it is bounded.
    • Second-order cone programming (SOCP) is a convex program, and includes certain types of quadratic programs.
    • Semidefinite programming (SDP) is a subfield of convex optimization where the underlying variables are semidefinite matrices. It is a generalization of linear and convex quadratic programming.
    • Conic programming is a general form of convex programming. LP, SOCP and SDP can all be viewed as conic programs with the appropriate type of cone.
    • Geometric programming is a technique whereby objective and inequality constraints expressed as posynomials and equality constraints as monomials can be transformed into a convex program.
  • Integer programming studies linear programs in which some or all variables are constrained to take on integer values. This is not convex, and in general much more difficult than regular linear programming.
  • Quadratic programming allows the objective function to have quadratic terms, while the feasible set must be specified with linear equalities and inequalities. For specific forms of the quadratic term, this is a type of convex programming.
  • Fractional programming studies optimization of ratios of two nonlinear functions. The special class of concave fractional programs can be transformed to a convex optimization problem.
  • Nonlinear programming studies the general case in which the objective function or the constraints or both contain nonlinear parts. This may or may not be a convex program. In general, whether the program is convex affects the difficulty of solving it.
  • Stochastic programming studies the case in which some of the constraints or parameters depend on random variables.
  • Robust optimization is, like stochastic programming, an attempt to capture uncertainty in the data underlying the optimization problem. Robust optimization aims to find solutions that are valid under all possible realizations of the uncertainties defined by an uncertainty set.
  • Combinatorial optimization is concerned with problems where the set of feasible solutions is discrete or can be reduced to a discrete one.
  • Stochastic optimization is used with random (noisy) function measurements or random inputs in the search process.
  • Infinite-dimensional optimization studies the case when the set of feasible solutions is a subset of an infinite-dimensional space, such as a space of functions.
  • Heuristics and metaheuristics make few or no assumptions about the problem being optimized. Usually, heuristics do not guarantee that any optimal solution need be found. On the other hand, heuristics are used to find approximate solutions for many complicated optimization problems.
  • Constraint satisfaction studies the case in which the objective function f is constant (this is used in artificial intelligence, particularly in automated reasoning).
    • Constraint programming is a programming paradigm wherein relations between variables are stated in the form of constraints.
  • Disjunctive programming is used where at least one constraint must be satisfied but not all. It is of particular use in scheduling.
  • Space mapping is a concept for modeling and optimization of an engineering system to high-fidelity (fine) model accuracy exploiting a suitable physically meaningful coarse or surrogate model.

In a number of subfields, the techniques are designed primarily for optimization in dynamic contexts (that is, decision making over time):

Multi-objective optimization

[edit]

Adding more than one objective to an optimization problem adds complexity. For example, to optimize a structural design, one would desire a design that is both light and rigid. When two objectives conflict, a trade-off must be created. There may be one lightest design, one stiffest design, and an infinite number of designs that are some compromise of weight and rigidity. The set of trade-off designs that improve upon one criterion at the expense of another is known as the Pareto set. The curve created plotting weight against stiffness of the best designs is known as the Pareto frontier.

A design is judged to be "Pareto optimal" (equivalently, "Pareto efficient" or in the Pareto set) if it is not dominated by any other design: If it is worse than another design in some respects and no better in any respect, then it is dominated and is not Pareto optimal.

The choice among "Pareto optimal" solutions to determine the "favorite solution" is delegated to the decision maker. In other words, defining the problem as multi-objective optimization signals that some information is missing: desirable objectives are given but combinations of them are not rated relative to each other. In some cases, the missing information can be derived by interactive sessions with the decision maker.

Multi-objective optimization problems have been generalized further into vector optimization problems where the (partial) ordering is no longer given by the Pareto ordering.

Multi-modal or global optimization

[edit]

Optimization problems are often multi-modal; that is, they possess multiple good solutions. They could all be globally good (same cost function value) or there could be a mix of globally good and locally good solutions. Obtaining all (or at least some of) the multiple solutions is the goal of a multi-modal optimizer.

Classical optimization techniques due to their iterative approach do not perform satisfactorily when they are used to obtain multiple solutions, since it is not guaranteed that different solutions will be obtained even with different starting points in multiple runs of the algorithm.

Common approaches to global optimization problems, where multiple local extrema may be present include evolutionary algorithms, Bayesian optimization and simulated annealing.

Classification of critical points and extrema

[edit]

Feasibility problem

[edit]

The satisfiability problem, also called the feasibility problem, is just the problem of finding any feasible solution at all without regard to objective value. This can be regarded as the special case of mathematical optimization where the objective value is the same for every solution, and thus any solution is optimal.

Many optimization algorithms need to start from a feasible point. One way to obtain such a point is to relax the feasibility conditions using a slack variable; with enough slack, any starting point is feasible. Then, minimize that slack variable until the slack is null or negative.

Existence

[edit]

The extreme value theorem of Karl Weierstrass states that a continuous real-valued function on a compact set attains its maximum and minimum value. More generally, a lower semi-continuous function on a compact set attains its minimum; an upper semi-continuous function on a compact set attains its maximum point or view.

Necessary conditions for optimality

[edit]

One of Fermat's theorems states that optima of unconstrained problems are found at stationary points, where the first derivative or the gradient of the objective function is zero (see first derivative test). More generally, they may be found at critical points, where the first derivative or gradient of the objective function is zero or is undefined, or on the boundary of the choice set. An equation (or set of equations) stating that the first derivative(s) equal(s) zero at an interior optimum is called a 'first-order condition' or a set of first-order conditions.

Optima of equality-constrained problems can be found by the Lagrange multiplier method. The optima of problems with equality and/or inequality constraints can be found using the 'Karush–Kuhn–Tucker conditions'.

Sufficient conditions for optimality

[edit]

While the first derivative test identifies points that might be extrema, this test does not distinguish a point that is a minimum from one that is a maximum or one that is neither. When the objective function is twice differentiable, these cases can be distinguished by checking the second derivative or the matrix of second derivatives (called the Hessian matrix) in unconstrained problems, or the matrix of second derivatives of the objective function and the constraints called the bordered Hessian in constrained problems. The conditions that distinguish maxima, or minima, from other stationary points are called 'second-order conditions' (see 'Second derivative test'). If a candidate solution satisfies the first-order conditions, then the satisfaction of the second-order conditions as well is sufficient to establish at least local optimality.

Sensitivity and continuity of optima

[edit]

The envelope theorem describes how the value of an optimal solution changes when an underlying parameter changes. The process of computing this change is called comparative statics.

The maximum theorem of Claude Berge (1963) describes the continuity of an optimal solution as a function of underlying parameters.

Calculus of optimization

[edit]

For unconstrained problems with twice-differentiable functions, some critical points can be found by finding the points where the gradient of the objective function is zero (that is, the stationary points). More generally, a zero subgradient certifies that a local minimum has been found for minimization problems with convex functions and other locally Lipschitz functions, which meet in loss function minimization of the neural network. The positive-negative momentum estimation lets to avoid the local minimum and converges at the objective function global minimum.[10]

Further, critical points can be classified using the definiteness of the Hessian matrix: If the Hessian is positive definite at a critical point, then the point is a local minimum; if the Hessian matrix is negative definite, then the point is a local maximum; finally, if indefinite, then the point is some kind of saddle point.

Constrained problems can often be transformed into unconstrained problems with the help of Lagrange multipliers. Lagrangian relaxation can also provide approximate solutions to difficult constrained problems.

When the objective function is a convex function, then any local minimum will also be a global minimum. There exist efficient numerical techniques for minimizing convex functions, such as interior-point methods.

Global convergence

[edit]

More generally, if the objective function is not a quadratic function, then many optimization methods use other methods to ensure that some subsequence of iterations converges to an optimal solution. The first and still popular method for ensuring convergence relies on line searches, which optimize a function along one dimension. A second and increasingly popular method for ensuring convergence uses trust regions. Both line searches and trust regions are used in modern methods of non-differentiable optimization. Usually, a global optimizer is much slower than advanced local optimizers (such as BFGS), so often an efficient global optimizer can be constructed by starting the local optimizer from different starting points.

Computational optimization techniques

[edit]

To solve problems, researchers may use algorithms that terminate in a finite number of steps, or iterative methods that converge to a solution (on some specified class of problems), or heuristics that may provide approximate solutions to some problems (although their iterates need not converge).

Optimization algorithms

[edit]

Iterative methods

[edit]

The iterative methods used to solve problems of nonlinear programming differ according to whether they evaluate Hessians, gradients, or only function values. While evaluating Hessians (H) and gradients (G) improves the rate of convergence, for functions for which these quantities exist and vary sufficiently smoothly, such evaluations increase the computational complexity (or computational cost) of each iteration. In some cases, the computational complexity may be excessively high.

One major criterion for optimizers is just the number of required function evaluations as this often is already a large computational effort, usually much more effort than within the optimizer itself, which mainly has to operate over the N variables. The derivatives provide detailed information for such optimizers, but are even harder to calculate, e.g. approximating the gradient takes at least N+1 function evaluations. For approximations of the 2nd derivatives (collected in the Hessian matrix), the number of function evaluations is in the order of N². Newton's method requires the 2nd-order derivatives, so for each iteration, the number of function calls is in the order of N², but for a simpler pure gradient optimizer it is only N. However, gradient optimizers need usually more iterations than Newton's algorithm. Which one is best with respect to the number of function calls depends on the problem itself.

  • Methods that evaluate Hessians (or approximate Hessians, using finite differences):
    • Newton's method
    • Sequential quadratic programming: A Newton-based method for small-medium scale constrained problems. Some versions can handle large-dimensional problems.
    • Interior point methods: This is a large class of methods for constrained optimization, some of which use only (sub)gradient information and others of which require the evaluation of Hessians.
  • Methods that evaluate gradients, or approximate gradients in some way (or even subgradients):
    • Coordinate descent methods: Algorithms which update a single coordinate in each iteration
    • Conjugate gradient methods: Iterative methods for large problems. (In theory, these methods terminate in a finite number of steps with quadratic objective functions, but this finite termination is not observed in practice on finite–precision computers.)
    • Gradient descent (alternatively, "steepest descent" or "steepest ascent"): A (slow) method of historical and theoretical interest, which has had renewed interest for finding approximate solutions of enormous problems.
    • Subgradient methods: An iterative method for large locally Lipschitz functions using generalized gradients. Following Boris T. Polyak, subgradient–projection methods are similar to conjugate–gradient methods.
    • Bundle method of descent: An iterative method for small–medium-sized problems with locally Lipschitz functions, particularly for convex minimization problems (similar to conjugate gradient methods).
    • Ellipsoid method: An iterative method for small problems with quasiconvex objective functions and of great theoretical interest, particularly in establishing the polynomial time complexity of some combinatorial optimization problems. It has similarities with Quasi-Newton methods.
    • Conditional gradient method (Frank–Wolfe) for approximate minimization of specially structured problems with linear constraints, especially with traffic networks. For general unconstrained problems, this method reduces to the gradient method, which is regarded as obsolete (for almost all problems).
    • Quasi-Newton methods: Iterative methods for medium-large problems (e.g. N<1000).
    • Simultaneous perturbation stochastic approximation (SPSA) method for stochastic optimization; uses random (efficient) gradient approximation.
  • Methods that evaluate only function values: If a problem is continuously differentiable, then gradients can be approximated using finite differences, in which case a gradient-based method can be used.

Heuristics

[edit]

Besides (finitely terminating) algorithms and (convergent) iterative methods, there are heuristics. A heuristic is any algorithm which is not guaranteed (mathematically) to find the solution, but which is nevertheless useful in certain practical situations. List of some well-known heuristics:

Applications

[edit]

Mechanics

[edit]

Problems in rigid body dynamics (in particular articulated rigid body dynamics) often require mathematical programming techniques, since you can view rigid body dynamics as attempting to solve an ordinary differential equation on a constraint manifold;[11] the constraints are various nonlinear geometric constraints such as "these two points must always coincide", "this surface must not penetrate any other", or "this point must always lie somewhere on this curve". Also, the problem of computing contact forces can be done by solving a linear complementarity problem, which can also be viewed as a QP (quadratic programming) problem.

Many design problems can also be expressed as optimization programs. This application is called design optimization. One subset is the engineering optimization, and another recent and growing subset of this field is multidisciplinary design optimization, which, while useful in many problems, has in particular been applied to aerospace engineering problems.

This approach may be applied in cosmology and astrophysics.[12]

Economics and finance

[edit]

Economics is closely enough linked to optimization of agents that an influential definition relatedly describes economics qua science as the "study of human behavior as a relationship between ends and scarce means" with alternative uses.[13] Modern optimization theory includes traditional optimization theory but also overlaps with game theory and the study of economic equilibria. The Journal of Economic Literature codes classify mathematical programming, optimization techniques, and related topics under JEL:C61-C63.

In microeconomics, the utility maximization problem and its dual problem, the expenditure minimization problem, are economic optimization problems. Insofar as they behave consistently, consumers are assumed to maximize their utility, while firms are usually assumed to maximize their profit. Also, agents are often modeled as being risk-averse, thereby preferring to avoid risk. Asset prices are also modeled using optimization theory, though the underlying mathematics relies on optimizing stochastic processes rather than on static optimization. International trade theory also uses optimization to explain trade patterns between nations. The optimization of portfolios is an example of multi-objective optimization in economics.

Since the 1970s, economists have modeled dynamic decisions over time using control theory.[14] For example, dynamic search models are used to study labor-market behavior.[15] A crucial distinction is between deterministic and stochastic models.[16] Macroeconomists build dynamic stochastic general equilibrium (DSGE) models that describe the dynamics of the whole economy as the result of the interdependent optimizing decisions of workers, consumers, investors, and governments.[17][18][19]

Electrical engineering

[edit]

Some common applications of optimization techniques in electrical engineering include active filter design,[20] stray field reduction in superconducting magnetic energy storage systems, space mapping design of microwave structures,[21] handset antennas,[22][23][24] electromagnetics-based design. Electromagnetically validated design optimization of microwave components and antennas has made extensive use of an appropriate physics-based or empirical surrogate model and space mapping methodologies since the discovery of space mapping in 1993.[25][26] Optimization techniques are also used in power-flow analysis.[27]

Civil engineering

[edit]

Optimization has been widely used in civil engineering. Construction management and transportation engineering are among the main branches of civil engineering that heavily rely on optimization. The most common civil engineering problems that are solved by optimization are cut and fill of roads, life-cycle analysis of structures and infrastructures,[28] resource leveling,[29][30] water resource allocation, traffic management[31] and schedule optimization.

Operations research

[edit]

Another field that uses optimization techniques extensively is operations research.[32] Operations research also uses stochastic modeling and simulation to support improved decision-making. Increasingly, operations research uses stochastic programming to model dynamic decisions that adapt to events; such problems can be solved with large-scale optimization and stochastic optimization methods.

Control engineering

[edit]

Mathematical optimization is used in much modern controller design. High-level controllers such as model predictive control (MPC) or real-time optimization (RTO) employ mathematical optimization. These algorithms run online and repeatedly determine values for decision variables, such as choke openings in a process plant, by iteratively solving a mathematical optimization problem including constraints and a model of the system to be controlled.

Geophysics

[edit]

Optimization techniques are regularly used in geophysical parameter estimation problems. Given a set of geophysical measurements, e.g. seismic recordings, it is common to solve for the physical properties and geometrical shapes of the underlying rocks and fluids. The majority of problems in geophysics are nonlinear with both deterministic and stochastic methods being widely used.

Molecular modeling

[edit]

Nonlinear optimization methods are widely used in conformational analysis.

Computational systems biology

[edit]

Optimization techniques are used in many facets of computational systems biology such as model building, optimal experimental design, metabolic engineering, and synthetic biology.[33] Linear programming has been applied to calculate the maximal possible yields of fermentation products,[33] and to infer gene regulatory networks from multiple microarray datasets[34] as well as transcriptional regulatory networks from high-throughput data.[35] Nonlinear programming has been used to analyze energy metabolism[36] and has been applied to metabolic engineering and parameter estimation in biochemical pathways.[37]

Machine learning

[edit]

Solvers

[edit]

See also

[edit]

Notes

[edit]
  1. ^ "The Nature of Mathematical Programming Archived 2014-03-05 at the Wayback Machine," Mathematical Programming Glossary, INFORMS Computing Society.
  2. ^ "Mathematical Programming: An Overview" (PDF). Retrieved 26 April 2024.
  3. ^ Martins, Joaquim R. R. A.; Ning, Andrew (2021-10-01). Engineering Design Optimization. Cambridge University Press. ISBN 978-1108833417.
  4. ^ Du, D. Z.; Pardalos, P. M.; Wu, W. (2008). "History of Optimization". In Floudas, C.; Pardalos, P. (eds.). Encyclopedia of Optimization. Boston: Springer. pp. 1538–1542.
  5. ^ "Mathematical optimization". Engati. Retrieved 2024-08-24.
  6. ^ "Open Journal of Mathematical Optimization". ojmo.centre-mersenne.org. Retrieved 2024-08-24.
  7. ^ Hartmann, Alexander K; Rieger, Heiko (2002). Optimization algorithms in physics. Citeseer.
  8. ^ Erwin Diewert, W. (2017), "Cost Functions", The New Palgrave Dictionary of Economics, London: Palgrave Macmillan UK, pp. 1–12, doi:10.1057/978-1-349-95121-5_659-2, ISBN 978-1-349-95121-5, retrieved 2024-08-18
  9. ^ Bixby, Robert E (2012). "A brief history of linear and mixed-integer programming computation" (PDF). Documenta Mathematica. Documenta Mathematica Series. 2012: 107–121. doi:10.4171/dms/6/16. ISBN 978-3-936609-58-5.
  10. ^ Abdulkadirov, R.; Lyakhov, P.; Bergerman, M.; Reznikov, D. (February 2024). "Satellite image recognition using ensemble neural networks and difference gradient positive-negative momentum". Chaos, Solitons & Fractals. 179: 114432. Bibcode:2024CSF...17914432A. doi:10.1016/j.chaos.2023.114432.
  11. ^ Vereshchagin, A.F. (1989). "Modelling and control of motion of manipulation robots". Soviet Journal of Computer and Systems Sciences. 27 (5): 29–38.
  12. ^ Haggag, S.; Desokey, F.; Ramadan, M. (2017). "A cosmological inflationary model using optimal control". Gravitation and Cosmology. 23 (3): 236–239. Bibcode:2017GrCo...23..236H. doi:10.1134/S0202289317030069. ISSN 1995-0721. S2CID 125980981.
  13. ^ Lionel Robbins (1935, 2nd ed.) An Essay on the Nature and Significance of Economic Science, Macmillan, p. 16.
  14. ^ Dorfman, Robert (1969). "An Economic Interpretation of Optimal Control Theory". American Economic Review. 59 (5): 817–831. JSTOR 1810679.
  15. ^ Sargent, Thomas J. (1987). "Search". Dynamic Macroeconomic Theory. Harvard University Press. pp. 57–91. ISBN 9780674043084.
  16. ^ A.G. Malliaris (2008). "stochastic optimal control," The New Palgrave Dictionary of Economics, 2nd Edition. Abstract Archived 2017-10-18 at the Wayback Machine.
  17. ^ Chaves Maza, Manuel; Fedriani, Eugenio M.; Ordaz Sanz, José Antonio (2018-07-01). "Factores relevantes para optimizar los servicios públicos de apoyo a los emprendedores y la tasa de supervivencia de las empresas". Innovar. 28 (69): 9–24. doi:10.15446/innovar.v28n69.71693. ISSN 2248-6968.
  18. ^ Rotemberg, Julio; Woodford, Michael (1997). "An Optimization-based Econometric Framework for the Evaluation of Monetary Policy" (PDF). NBER Macroeconomics Annual. 12: 297–346. doi:10.2307/3585236. JSTOR 3585236.
  19. ^ From The New Palgrave Dictionary of Economics (2008), 2nd Edition with Abstract links:
    • "numerical optimization methods in economics" by Karl Schmedders
    • "convex programming" by Lawrence E. Blume
    • "Arrow–Debreu model of general equilibrium" by John Geanakoplos.
  20. ^ De, Bishnu Prasad; Kar, R.; Mandal, D.; Ghoshal, S.P. (2014-09-27). "Optimal selection of components value for analog active filter design using simplex particle swarm optimization". International Journal of Machine Learning and Cybernetics. 6 (4): 621–636. doi:10.1007/s13042-014-0299-0. ISSN 1868-8071. S2CID 13071135.
  21. ^ Koziel, Slawomir; Bandler, John W. (January 2008). "Space Mapping With Multiple Coarse Models for Optimization of Microwave Components". IEEE Microwave and Wireless Components Letters. 18 (1): 1–3. CiteSeerX 10.1.1.147.5407. doi:10.1109/LMWC.2007.911969. S2CID 11086218.
  22. ^ Tu, Sheng; Cheng, Qingsha S.; Zhang, Yifan; Bandler, John W.; Nikolova, Natalia K. (July 2013). "Space Mapping Optimization of Handset Antennas Exploiting Thin-Wire Models". IEEE Transactions on Antennas and Propagation. 61 (7): 3797–3807. Bibcode:2013ITAP...61.3797T. doi:10.1109/TAP.2013.2254695.
  23. ^ N. Friedrich, “Space mapping outpaces EM optimization in handset-antenna design,” microwaves&rf, August 30, 2013.
  24. ^ Cervantes-González, Juan C.; Rayas-Sánchez, José E.; López, Carlos A.; Camacho-Pérez, José R.; Brito-Brito, Zabdiel; Chávez-Hurtado, José L. (February 2016). "Space mapping optimization of handset antennas considering EM effects of mobile phone components and human body". International Journal of RF and Microwave Computer-Aided Engineering. 26 (2): 121–128. doi:10.1002/mmce.20945. S2CID 110195165.
  25. ^ Bandler, J.W.; Biernacki, R.M.; Chen, Shao Hua; Grobelny, P.A.; Hemmers, R.H. (1994). "Space mapping technique for electromagnetic optimization". IEEE Transactions on Microwave Theory and Techniques. 42 (12): 2536–2544. Bibcode:1994ITMTT..42.2536B. doi:10.1109/22.339794.
  26. ^ Bandler, J.W.; Biernacki, R.M.; Shao Hua Chen; Hemmers, R.H.; Madsen, K. (1995). "Electromagnetic optimization exploiting aggressive space mapping". IEEE Transactions on Microwave Theory and Techniques. 43 (12): 2874–2882. Bibcode:1995ITMTT..43.2874B. doi:10.1109/22.475649.
  27. ^ Convex relaxation of optimal power flow: A tutorial. 2013 iREP Symposium on Bulk Power System Dynamics and Control. doi:10.1109/IREP.2013.6629391.
  28. ^ Piryonesi, Sayed Madeh; Tavakolan, Mehdi (9 January 2017). "A mathematical programming model for solving cost-safety optimization (CSO) problems in the maintenance of structures". KSCE Journal of Civil Engineering. 21 (6): 2226–2234. Bibcode:2017KSJCE..21.2226P. doi:10.1007/s12205-017-0531-z. S2CID 113616284.
  29. ^ Hegazy, Tarek (June 1999). "Optimization of Resource Allocation and Leveling Using Genetic Algorithms". Journal of Construction Engineering and Management. 125 (3): 167–175. doi:10.1061/(ASCE)0733-9364(1999)125:3(167).
  30. ^ Piryonesi, S. Madeh; Nasseri, Mehran; Ramezani, Abdollah (9 July 2018). "Piryonesi, S. M., Nasseri, M., & Ramezani, A. (2018). Resource leveling in construction projects with activity splitting and resource constraints: a simulated annealing optimization". Canadian Journal of Civil Engineering. 46: 81–86. doi:10.1139/cjce-2017-0670. hdl:1807/93364. S2CID 116480238.
  31. ^ Herty, M.; Klar, A. (2003-01-01). "Modeling, Simulation, and Optimization of Traffic Flow Networks". SIAM Journal on Scientific Computing. 25 (3): 1066–1087. Bibcode:2003SJSC...25.1066H. doi:10.1137/S106482750241459X. ISSN 1064-8275.
  32. ^ "New force on the political scene: the Seophonisten". Archived from the original on 18 December 2014. Retrieved 14 September 2013.
  33. ^ a b Papoutsakis, Eleftherios Terry (February 1984). "Equations and calculations for fermentations of butyric acid bacteria". Biotechnology and Bioengineering. 26 (2): 174–187. doi:10.1002/bit.260260210. ISSN 0006-3592. PMID 18551704. S2CID 25023799.
  34. ^ Wang, Yong; Joshi, Trupti; Zhang, Xiang-Sun; Xu, Dong; Chen, Luonan (2006-07-24). "Inferring gene regulatory networks from multiple microarray datasets". Bioinformatics. 22 (19): 2413–2420. doi:10.1093/bioinformatics/btl396. ISSN 1460-2059. PMID 16864593.
  35. ^ Wang, Rui-Sheng; Wang, Yong; Zhang, Xiang-Sun; Chen, Luonan (2007-09-22). "Inferring transcriptional regulatory networks from high-throughput data". Bioinformatics. 23 (22): 3056–3064. doi:10.1093/bioinformatics/btm465. ISSN 1460-2059. PMID 17890736.
  36. ^ Vo, Thuy D.; Paul Lee, W.N.; Palsson, Bernhard O. (May 2007). "Systems analysis of energy metabolism elucidates the affected respiratory chain complex in Leigh's syndrome". Molecular Genetics and Metabolism. 91 (1): 15–22. doi:10.1016/j.ymgme.2007.01.012. ISSN 1096-7192. PMID 17336115.
  37. ^ Mendes, P.; Kell, D. (1998). "Non-linear optimization of biochemical pathways: applications to metabolic engineering and parameter estimation". Bioinformatics. 14 (10): 869–883. doi:10.1093/bioinformatics/14.10.869. ISSN 1367-4803. PMID 9927716.

Further reading

[edit]
  • Boyd, Stephen P.; Vandenberghe, Lieven (2004). Convex Optimization. Cambridge: Cambridge University Press. ISBN 0-521-83378-7.
  • Gill, P. E.; Murray, W.; Wright, M. H. (1982). Practical Optimization. London: Academic Press. ISBN 0-12-283952-8.
  • Lee, Jon (2004). A First Course in Combinatorial Optimization. Cambridge University Press. ISBN 0-521-01012-8.
  • Nocedal, Jorge; Wright, Stephen J. (2006). Numerical Optimization (2nd ed.). Berlin: Springer. ISBN 0-387-30303-0.
  • G.L. Nemhauser, A.H.G. Rinnooy Kan and M.J. Todd (eds.): Optimization, Elsevier, (1989).
  • Stanislav Walukiewicz:Integer Programming, Springer,ISBN 978-9048140688, (1990).
  • R. Fletcher: Practical Methods of Optimization, 2nd Ed.,Wiley, (2000).
  • Panos M. Pardalos:Approximation and Complexity in Numerical Optimization: Continuous and Discrete Problems, Springer,ISBN 978-1-44194829-8, (2000).
  • Xiaoqi Yang, K. L. Teo, Lou Caccetta (Eds.):Optimization Methods and Applications,Springer, ISBN 978-0-79236866-3, (2001).
  • Panos M. Pardalos, and Mauricio G. C. Resende(Eds.):Handbook of Applied Optimization、Oxford Univ Pr on Demand, ISBN 978-0-19512594-8, (2002).
  • Wil Michiels, Emile Aarts, and Jan Korst: Theoretical Aspects of Local Search, Springer, ISBN 978-3-64207148-5, (2006).
  • Der-San Chen, Robert G. Batson,and Yu Dang: Applied Integer Programming: Modeling and Solution,Wiley,ISBN 978-0-47037306-4, (2010).
  • Mykel J. Kochenderfer and Tim A. Wheeler: Algorithms for Optimization, The MIT Press, ISBN 978-0-26203942-0, (2019).
  • Vladislav Bukshtynov: Optimization: Success in Practice, CRC Press (Taylor & Francis), ISBN 978-1-03222947-8, (2023) .
  • Rosario Toscano: Solving Optimization Problems with the Heuristic Kalman Algorithm: New Stochastic Methods, Springer, ISBN 978-3-031-52458-5 (2024).
  • Immanuel M. Bomze, Tibor Csendes, Reiner Horst and Panos M. Pardalos: Developments in Global Optimization, Kluwer Academic, ISBN 978-1-4419-4768-0 (2010).
[edit]