| ConstraintTolerance | Determines the feasibility with respect to nonlinear constraints. Also,
                            max(sqrt(eps),ConstraintTolerance)determines
                        feasibility with respect to linear constraints. For an options
                        structure, use TolCon. | Nonnegative scalar | {1e-3} | 
| CreationFcn
 | Function that creates the initial population. Specify as a name of a built-in creation
                        function or a function handle. See Population Options. | {'gacreationuniform'}|{'gacreationlinearfeasible'}*|'gacreationnonlinearfeasible'|{'gacreationuniformint'}I* forga|{'gacreationsobol'}I* forgamultiobj| Custom creation
                            function
 | 
| CrossoverFcn
 | Function that the algorithm uses to create crossover children. Specify as a name of a
                        built-in crossover function or a function handle. See Crossover Options. | {'crossoverscattered'}forga,{'crossoverintermediate'}*forgamultiobj|{'crossoverlaplace'}I* |'crossoverheuristic'|'crossoversinglepoint'|'crossovertwopoint'|'crossoverarithmetic'| Custom crossover
                            function
 | 
| CrossoverFraction
 | The fraction of the population at the next generation, not including elite children, that the
                        crossover function creates. | Nonnegative scalar | {0.8} | 
| Display
 | Level of display. | 'off'|'iter'|'diagnose'|{'final'}
 | 
| DistanceMeasureFcn
 | Function that computes the distance measure of individuals. Specify as a name of a
                        built-in distance measure function or a function handle. The value applies
                        to the decision variable or design space (genotype) or to function space
                        (phenotype). The default 'distancecrowding'is in
                        function space (phenotype). Forgamultiobjonly. See
                            Multiobjective Options. For
                        an options structure, use a function handle, not a name. | {'distancecrowding'}means the same as{@distancecrowding,'phenotype'}|{@distancecrowding,'genotype'}| Custom distance
                            function
 | 
| EliteCount
 | NM Positive integer
specifying how many individuals in the current generation are guaranteed
to survive to the next generation. Not used in gamultiobj. | Nonnegative integer | {ceil(0.05*PopulationSize)}|{0.05*(default PopulationSize)}for mixed-integer
                        problems | 
| FitnessLimit
 | NM If the fitness function
attains the value of FitnessLimit, the algorithm
halts. | Scalar | {-Inf} | 
| FitnessScalingFcn
 | Function that scales the values of the fitness function. Specify as a name of a
                        built-in scaling function or a function handle. Option unavailable for
                            gamultiobj. | {'fitscalingrank'}|'fitscalingshiftlinear'|'fitscalingprop'|'fitscalingtop'| Custom fitness scaling
                            function
 | 
| FunctionTolerance | The algorithm stops if the average relative change in the best fitness function value
                        over MaxStallGenerationsgenerations is less than or
                        equal toFunctionTolerance. IfStallTestis'geometricWeighted',
                        then the algorithm stops if the weighted average relative change is less
                        than or equal toFunctionTolerance. For
                            gamultiobj, the algorithm stops when the geometric
                        average of the relative change in value of the spread overoptions.MaxStallGenerationsgenerations is less thanoptions.FunctionTolerance, and the final spread is
                        less than the mean spread over the pastoptions.MaxStallGenerationsgenerations. See gamultiobj Algorithm. For an options structure, use
                        TolFun. | Nonnegative scalar | {1e-6}forga,{1e-4}forgamultiobj | 
| HybridFcn
 | I* Function that continues the optimization after
                            gaterminates. Specify as a name or a function
                        handle. Alternatively, a cell array specifying the hybrid
                        function and its options. See ga Hybrid Function. For gamultiobj, the only hybrid
                        function is@fgoalattain. See gamultiobj Hybrid Function. When the problem has integer constraints, you cannot use a
                        hybrid function. See When to Use a Hybrid Function. | Function name or handle | 'fminsearch' | 'patternsearch' | 'fminunc' |
                            'fmincon' | {[]} or 1-by-2 cell array
                        | {@solver, hybridoptions}, wheresolver =
                            fminsearch,patternsearch,fminunc, orfmincon{[]} | 
| InitialPenalty | NM
                        I* Initial value of the penalty
                        parameter | Positive scalar | {10} | 
| InitialPopulationMatrix
 | Initial population used to seed the genetic algorithm. Has up to
                            PopulationSizerows andNcolumns,
                        whereNis the number of variables. You can pass a
                        partial population, meaning one with fewer thanPopulationSizerows. In that case, the genetic
                        algorithm usesCreationFcnto generate the remaining
                        population members. See Population Options. For an options structure, use
                            InitialPopulation. | Matrix | {[]} | 
| InitialPopulationRange
 | Matrix or vector specifying the range of the individuals in the initial population.
                        Applies to gacreationuniformcreation function.gashifts and scales the default initial range to
                        match any finite bounds. For an options structure, use
                            PopInitRange. | Matrix or vector | {[-10;10]}for unbounded components,{[-1e4+1;1e4+1]}for unbounded components of
                        integer-constrained problems,{[lb;ub]}for bounded
                        components, with the default range modified to match one-sided
                    bounds | 
| InitialScoresMatrix
 | Initial scores used to determine fitness. Has up to PopulationSizerows andNfcolumns, whereNfis the
                        number of fitness functions (1forga, greater than1forgamultiobj). You can pass a partial scores matrix,
                        meaning one with fewer thanPopulationSizerows. In that
                        case, the solver fills in the scores when it evaluates the fitness
                        functions. For an options structure, use
                            InitialScores. | Column vector for single objective | matrix for multiobjective
| {[]} | 
| MaxGenerations
 | Maximum number of iterations before the algorithm halts. For an options
                        structure, use Generations. | Nonnegative integer |{100*numberOfVariables}forga,{200*numberOfVariables}forgamultiobj | 
| MaxStallGenerations
 | The algorithm stops if the average relative change in the best fitness function value
                        over MaxStallGenerationsgenerations is less than or
                        equal toFunctionTolerance. IfStallTestis'geometricWeighted',
                        then the algorithm stops if the weighted average relative change is less
                        than or equal toFunctionTolerance. For
                            gamultiobj, the algorithm stops when the geometric
                        average of the relative change in value of the spread overoptions.MaxStallGenerationsgenerations is less thanoptions.FunctionTolerance, and the final spread is
                        less than the mean spread over the pastoptions.MaxStallGenerationsgenerations. See gamultiobj Algorithm. For an options structure, use
                            StallGenLimit. | Nonnegative integer | {50}forga,{100}forgamultiobj | 
| MaxStallTime
 | NM The algorithm stops if there is no improvement in
                        the objective function for MaxStallTimeseconds, as
                        measured byticandtoc. For an
                        options structure, use StallTimeLimit. | Positive scalar | {Inf} | 
| MaxTime
 | The algorithm stops after running for MaxTimeseconds, as measured
                        byticandtoc. This limit is enforced
                        after each iteration, sogacan exceed the limit when
                        an iteration takes substantial time. For an options structure,
                        use TimeLimit. | Nonnegative scalar | {Inf} | 
| MigrationDirection | Direction of migration. See Migration Options. | 'both'|{'forward'}
 | 
| MigrationFraction | Scalar from 0 through 1 specifying the fraction of individuals in each subpopulation
                        that migrates to a different subpopulation. See Migration Options. | Scalar | {0.2} | 
| MigrationInterval | Positive integer specifying the number of generations
that take place between migrations of individuals between subpopulations.
See Migration Options. | Positive integer | {20} | 
| MutationFcn
 | Function that produces mutation children. Specify as a name of a built-in mutation
                        function or a function handle. See Mutation Options. | {'mutationgaussian'}forgawithout constraints
                        |{'mutationadaptfeasible'}*forgamultiobjand forgawith
                        constraints |{'mutationpower'}I* |'mutationpositivebasis'|'mutationuniform'| Custom mutation function
 | 
| NonlinearConstraintAlgorithm
 | Nonlinear constraint algorithm. See Nonlinear Constraint Solver Algorithms for Genetic Algorithm. Option unchangeable for
                            gamultiobj. For an options structure,
                        use NonlinConAlgorithm. | {'auglag'}forga,{'penalty'}forgamultiobj
 | 
| OutputFcn
 | Functions that gacalls at each iteration. Specify as a function
                        handle or a cell array of function handles. See Output Function Options. For an options structure,
                        use OutputFcns. | Function  handle or cell array of function handles |
                    {[]} | 
| ParetoFraction
 | Scalar from 0 through 1 specifying the fraction of individuals to keep on the first
                        Pareto front while the solver selects individuals from higher fronts, for
                            gamultiobjonly. See Multiobjective Options. | Scalar | {0.35} | 
| PenaltyFactor | NM I* Penalty
update parameter. | Positive scalar | {100} | 
| PlotFcn
 | Function that plots data computed by the algorithm. Specify as a name of a built-in
                        plot function, a function handle, or a cell array of built-in names or
                        function handles. See Plot Options. For an options
                        structure, use PlotFcns. | gaorgamultiobj:{[]} |
                            'gaplotdistance' | 'gaplotgenealogy' | 'gaplotselection' |
                            'gaplotscorediversity' |'gaplotscores' | 'gaplotstopping' |
                            'gaplotmaxconstr' | Custom plot function
 gaonly:'gaplotbestf' | 'gaplotbestindiv' | 'gaplotexpectation' |
                            'gaplotrange'
 gamultiobjonly:'gaplotpareto' | 'gaplotparetodistance' | 'gaplotrankhist' |
                            'gaplotspread'
 | 
| PlotInterval | Positive integer specifying the number of generations
between consecutive calls to the plot functions. | Positive integer | {1} | 
| PopulationSize
 | Size of the population. | Positive integer | {50}whennumberOfVariables <=
                            5,{200}otherwise | Forgaonly with a mixed-integer problem,{min(max(10*nvars,40),100)} | 
| PopulationType
 | Data type of the population. Must be 'doubleVector'for
                        mixed-integer problems. | 'bitstring'|'custom'|{'doubleVector'}
 gaignores
all constraints whenPopulationTypeis set to'bitString'or'custom'.
See Population Options.
 | 
| SelectionFcn
 | Function that selects parents of crossover and mutation children. Specify as a name of
                        a built-in selection function or a function handle.
                             gamultiobjuses only'selectiontournament'or a custom selection
                        function.
 | {'selectionstochunif'}forga,{'selectiontournament'}forgamultiobj|'selectionremainder'|'selectionuniform'|'selectionroulette'| Custom selection
                            function
 | 
| StallTest | NM Stopping test type. | 'geometricWeighted'|{'averageChange'}
 | 
| UseParallel | Compute fitness and nonlinear constraint functions in
parallel. See Vectorize and Parallel Options (User Function Evaluation) and How to Use Parallel Processing in Global Optimization Toolbox. | true|{false}
 | 
| UseVectorized
 | Specifies whether functions are vectorized. See Vectorize and Parallel Options (User Function Evaluation) and
                            Vectorize the Fitness Function. For an options structure, use Vectorizedwith the values'on'or'off'. | true|{false}
 |