You might need to formulate problems with more than one objective, since a single objective with several constraints may not adequately represent the problem being faced. If so, there is a vector of objectives,
F(x) = [F1(x), F2(x),...,Fm(x)],
that must be traded off in some way. The relative importance of these objectives is not generally known until the system's best capabilities are determined and tradeoffs between the objectives fully understood. As the number of objectives increases, tradeoffs are likely to become complex and less easily quantified. The designer must rely on his or her intuition and ability to express preferences throughout the optimization cycle. Thus, requirements for a multiobjective design strategy must enable a natural problem formulation to be expressed, and be able to solve the problem and enter preferences into a numerically tractable and realistic design problem.
Note that because F(x) is a vector, if any of the components of F(x) are competing, there is no unique solution to this problem. Instead, the concept of noninferiority in Zadeh  (also called Pareto optimality in Censor  and Da Cunha and Polak ) must be used to characterize the objectives. A noninferior solution is one in which an improvement in one objective requires a degradation of another. To define this concept more precisely, consider a feasible region, Ω, in the parameter space. x is an element of the n-dimensional real numbers that satisfies all the constraints, i.e.,
This allows definition of the corresponding feasible region for the objective function space Λ:
The performance vector F(x) maps parameter space into objective function space, as represented in two dimensions in the figure Mapping from Parameter Space into Objective Function Space.
Figure 8-1. Mapping from Parameter Space into Objective Function Space
A noninferior solution point can now be defined.
In the two-dimensional representation of the figure Set of Noninferior Solutions, the set of noninferior solutions lies on the curve between C and D. Points A and B represent specific noninferior points.
Figure 8-2. Set of Noninferior Solutions
A and B are clearly noninferior solution points because an improvement in one objective, F1, requires a degradation in the other objective, F2, i.e., F1B < F1A, F2B > F2A.
Since any point in Ω that is an inferior point represents a point in which improvement can be attained in all the objectives, it is clear that such a point is of no value. Multiobjective optimization is, therefore, concerned with the generation and selection of noninferior solution points.
Noninferior solutions are also called Pareto optima.
A general goal in multiobjective optimization is constructing the
Pareto optima. The algorithm used in
described in Deb .
gamultiobj solver attempts to create
a set of Pareto optima for a multiobjective minimization. You may
optionally set bounds or other constraints on variables.
the genetic algorithm for finding local Pareto optima. As in the
you may specify an initial population, or have the solver generate
The fitness function for use in
return a vector of type
double. The population
may be of type
double, a bit string vector, or
can be a custom-typed vector. As in
ga, if you
use a custom population type, you must write your own creation, mutation,
and crossover functions that accept inputs of that population type,
and specify these functions in the following fields, respectively:
Creation function (
Mutation function (
Crossover function (
You can set the initial population in a variety of ways. Suppose that you choose a population of size m. (The default population size is 15 times the number of variables n.) You can set the population:
As an m-by-n matrix, where the rows represent m individuals.
As a k-by-n matrix, where k < m. The remaining m – k individuals are generated by a creation function.
The entire population can be created by a creation function.