The NLPC Nonlinear Optimization Solver |
Infeasibility |
Like any iterative algorithm, an optimization algorithm is carried out in finite-precision arithmetic and is subject to numerical rounding errors. Thus, when an algorithm terminates, the constraints might not be satisfied exactly. Instead we consider a constraint to be satisfied if the violation is within some prescribed tolerance. Such a violation can be measured in an absolute or relative sense.
For an optimization problem of the general form described in the section Overview: NLPC Nonlinear Optimization Solver, we rewrite the constraints (including bound constraints) in the form
where and denote the sets of equality and inequality constraints, respectively. We define the absolute infeasibility at to be the maximum constraint violation in absolute measure as follows:
We define the relative infeasibility at to be the maximum constraint violation in relative measure as follows:
For feasibility control, we choose to be the tolerance for the relative infeasibility. For a solution to be considered feasible, we require that the following hold for the relative infeasibility:
In the NLPC solver, we set E.
Associated with the infeasibility is the conditional optimality. A solution is considered to be conditionally optimal if satisfies the optimality criteria described in the section Optimality Control and if the following is true:
That is, the default tolerance for the relative infeasibility is not satisfied, but the relative infeasibility is not too large. This is useful for problems whose constraints are not well scaled.
Copyright © SAS Institute, Inc. All Rights Reserved.