 
               

 
               The parameter vector  may be subject to a set of m linear equality and inequality constraints:
 may be subject to a set of m linear equality and inequality constraints: 
            
![\[ \begin{array}{ll} \sum \limits _{j=1}^ n a_{ij} x_ j = b_ i, & i=1,\dots , m_ e \\ \sum \limits _{j=1}^ n a_{ij} x_ j \geq b_ i, & i=m_ e+1,\dots , m \end{array} \]](images/ormplpug_nlp0294.png)
 The coefficients  and right-hand sides
 and right-hand sides  of the equality and inequality constraints are collected in the
 of the equality and inequality constraints are collected in the  matrix A and the
 matrix A and the  vector b.
vector b. 
            
The m linear constraints define a feasible region  in
 in  that must contain the point
 that must contain the point  that minimizes the problem. If the feasible region
 that minimizes the problem. If the feasible region  is empty, no solution to the optimization problem exists.
 is empty, no solution to the optimization problem exists. 
            
All optimization techniques in PROC NLP (except those processing nonlinear constraints) are active set methods. The iteration starts with a feasible point  , which either is provided by the user or can be computed by the Schittkowski and Stoer (1979) algorithm implemented in PROC NLP. The algorithm then moves from one feasible point
, which either is provided by the user or can be computed by the Schittkowski and Stoer (1979) algorithm implemented in PROC NLP. The algorithm then moves from one feasible point  to a better feasible point
 to a better feasible point  along a feasible search direction
 along a feasible search direction  :
: 
            
![\[ x^{(k)} = x^{(k-1)} + \alpha ^{(k)} s^{(k)} \: , \quad \alpha ^{(k)} > 0 \]](images/ormplpug_nlp0299.png)
Theoretically, the path of points  never leaves the feasible region
 never leaves the feasible region  of the optimization problem, but it can hit its boundaries. The active set
 of the optimization problem, but it can hit its boundaries. The active set  of point
 of point  is defined as the index set of all linear equality constraints and those inequality constraints that are satisfied at
 is defined as the index set of all linear equality constraints and those inequality constraints that are satisfied at  . If no constraint is active for
. If no constraint is active for  , the point is located in the interior of
, the point is located in the interior of  , and the active set
, and the active set  is empty. If the point
 is empty. If the point  in iteration k hits the boundary of inequality constraint i, this constraint i becomes active and is added to
 in iteration k hits the boundary of inequality constraint i, this constraint i becomes active and is added to  . Each equality or active inequality constraint reduces the dimension (degrees of freedom) of the optimization problem.
. Each equality or active inequality constraint reduces the dimension (degrees of freedom) of the optimization problem. 
            
In practice, the active constraints can be satisfied only with finite precision. The LCEPSILON=
               r option specifies the range for active and violated linear constraints. 
               If the point  satisfies the condition
 satisfies the condition 
            
![\[ \left| \sum _{j=1}^ n a_{ij} x_ j^{(k)} - b_ i \right| \leq t \]](images/ormplpug_nlp0302.png)
 where  , the constraint i is recognized as an active constraint. Otherwise, the constraint i is either an inactive inequality or a violated inequality or equality constraint. Due to rounding errors in computing the
               projected search direction, error can be accumulated so that an iterate
, the constraint i is recognized as an active constraint. Otherwise, the constraint i is either an inactive inequality or a violated inequality or equality constraint. Due to rounding errors in computing the
               projected search direction, error can be accumulated so that an iterate  steps out of the feasible region. In those cases, PROC NLP may try to pull the iterate
 steps out of the feasible region. In those cases, PROC NLP may try to pull the iterate  into the feasible region. However, in some cases the algorithm needs to increase the feasible region by increasing the LCEPSILON=
               r value. If this happens it is indicated by a message displayed in the log output.
 into the feasible region. However, in some cases the algorithm needs to increase the feasible region by increasing the LCEPSILON=
               r value. If this happens it is indicated by a message displayed in the log output. 
            
If you cannot expect an improvement in the value of the objective function by moving from an active constraint back into the
               interior of the feasible region, you use this inequality constraint as an equality constraint in the next iteration. That
               means the active set  still contains the constraint i. Otherwise you release the active inequality constraint and increase the dimension of the optimization problem in the next
               iteration.
 still contains the constraint i. Otherwise you release the active inequality constraint and increase the dimension of the optimization problem in the next
               iteration. 
            
A serious numerical problem can arise when some of the active constraints become (nearly) linearly dependent. Linearly dependent equality constraints are removed before entering the optimization. You can use the LCSINGULAR= option to specify a criterion r used in the update of the QR decomposition that decides whether an active constraint is linearly dependent relative to a set of other active constraints.
If the final parameter set  is subjected to
 is subjected to  linear equality or active inequality constraints, the QR decomposition of the
 linear equality or active inequality constraints, the QR decomposition of the  matrix
 matrix  of the linear constraints is computed by
 of the linear constraints is computed by  , where Q is an
, where Q is an  orthogonal matrix and R is an
 orthogonal matrix and R is an  upper triangular matrix. The n columns of matrix Q can be separated into two matrices,
 upper triangular matrix. The n columns of matrix Q can be separated into two matrices, ![$ Q=[Y,Z]$](images/ormplpug_nlp0309.png) , where Y contains the first
, where Y contains the first  orthogonal columns of Q and Z contains the last
 orthogonal columns of Q and Z contains the last  orthogonal columns of Q. The
 orthogonal columns of Q. The  column-orthogonal matrix Z is also called the nullspace matrix of the active linear constraints
 column-orthogonal matrix Z is also called the nullspace matrix of the active linear constraints  . The
. The  columns of the
 columns of the  matrix Z form a basis orthogonal to the rows of the
 matrix Z form a basis orthogonal to the rows of the  matrix
 matrix  .
. 
            
At the end of the iteration process, the PROC NLP can display the projected gradient
![\[ g_ Z = Z^ Tg \]](images/ormplpug_nlp0316.png)
 In the case of boundary constrained optimization, the elements of the projected gradient correspond to the gradient elements
               of the free parameters. A necessary condition for  to be a local minimum of the optimization problem is
 to be a local minimum of the optimization problem is 
            
![\[ g_ Z(x^{*}) = Z^ Tg(x^{*}) = 0 \]](images/ormplpug_nlp0317.png)
 The symmetric  matrix
 matrix 
            
![\[ G_ Z = Z^ TGZ \]](images/ormplpug_nlp0319.png)
 is called a projected Hessian matrix. 
               
               A second-order necessary condition for  to be a local minimizer requires that the projected Hessian matrix is positive semidefinite. If available, the projected
               gradient and projected Hessian matrix can be displayed and written in an OUTEST=
                data set.
 to be a local minimizer requires that the projected Hessian matrix is positive semidefinite. If available, the projected
               gradient and projected Hessian matrix can be displayed and written in an OUTEST=
                data set. 
            
Those elements of the  vector of first-order estimates of Lagrange multipliers
 vector of first-order estimates of Lagrange multipliers 
               
            
![\[ \lambda = (\hat{A}\hat{A}^ T)^{-1} \hat{A} ZZ^ T g \]](images/ormplpug_nlp0321.png)
 which correspond to active inequality constraints indicate whether an improvement of the objective function can be obtained
               by releasing this active constraint. For minimization (maximization), a significant negative (positive) Lagrange multiplier
               indicates that a possible reduction (increase) of the objective function can be obtained by releasing this active linear constraint.
               The LCDEACT=
               r option can be used to specify a threshold 
               r for the Lagrange multiplier that decides whether an active inequality constraint remains active or can be deactivated. The
               Lagrange multipliers are displayed (and written in an OUTEST=
                data set) only if linear constraints are active at the solution  . (In the case of boundary-constrained optimization, the Lagrange multipliers for active lower (upper) constraints are the
               negative (positive) gradient elements corresponding to the active parameters.)
. (In the case of boundary-constrained optimization, the Lagrange multipliers for active lower (upper) constraints are the
               negative (positive) gradient elements corresponding to the active parameters.)