9.3 Sensitivity Analysis

Given an optimization problem it is often useful to obtain information about how the optimal objective value changes when the problem parameters are perturbed. E.g, assume that a bound represents the capacity of a machine. Now, it may be possible to expand the capacity for a certain cost and hence it is worthwhile knowing what the value of additional capacity is. This is precisely the type of questions the sensitivity analysis deals with.

Analyzing how the optimal objective value changes when the problem data is changed is called sensitivity analysis.

References

The book [Chvatal83] discusses the classical sensitivity analysis in Chapter 10 whereas the book [RTV97] presents a modern introduction to sensitivity analysis. Finally, it is recommended to read the short paper [Wal00] to avoid some of the pitfalls associated with sensitivity analysis.

Warning

Currently, sensitivity analysis is only available for continuous linear optimization problems. Moreover, MOSEK can only deal with perturbations of bounds and objective function coefficients.

9.3.1 Sensitivity Analysis for Linear Problems

9.3.1.1 The Optimal Objective Value Function

Assume that we are given the problem

(9.3)z(lc,uc,lx,ux,c)=minimizecTxsubject tolcAxuc,lxxux,

and we want to know how the optimal objective value changes as lic is perturbed. To answer this question we define the perturbed problem for lic as follows

flic(β)=minimizecTxsubject tolc+βeiAxuc,lxxux,

where ei is the i-th column of the identity matrix. The function

(9.4)flic(β)

shows the optimal objective value as a function of β. Please note that a change in β corresponds to a perturbation in lic and hence (9.4) shows the optimal objective value as a function of varying lic with the other bounds fixed.

It is possible to prove that the function (9.4) is a piecewise linear and convex function, i.e. its graph may look like in Fig. 9.1 and Fig. 9.2.

_images/optimal_val_fun2.png

Fig. 9.1 β=0 is in the interior of linearity interval.

_images/optimal_val_fun.png

Fig. 9.2 β=0 is a breakpoint.

Clearly, if the function flic(β) does not change much when β is changed, then we can conclude that the optimal objective value is insensitive to changes in lic. Therefore, we are interested in the rate of change in flic(β) for small changes in β — specifically the gradient

flic(0),

which is called the shadow price related to lic. The shadow price specifies how the objective value changes for small changes of β around zero. Moreover, we are interested in the linearity interval

β[β1,β2]

for which

flic(β)=flic(0).

Since flic is not a smooth function flic may not be defined at 0, as illustrated in Fig. 9.2. In this case we can define a left and a right shadow price and a left and a right linearity interval.

The function flic considered only changes in lic. We can define similar functions for the remaining parameters of the z defined in (9.3) as well:

flic(β)=z(lc+βei,uc,lx,ux,c),i=1,,m,fuic(β)=z(lc,uc+βei,lx,ux,c),i=1,,m,fljx(β)=z(lc,uc,lx+βej,ux,c),j=1,,n,fujx(β)=z(lc,uc,lx,ux+βej,c),j=1,,n,fcj(β)=z(lc,uc,lx,ux,c+βej),j=1,,n.

Given these definitions it should be clear how linearity intervals and shadow prices are defined for the parameters uic etc.

9.3.1.1.1 Equality Constraints

In MOSEK a constraint can be specified as either an equality constraint or a ranged constraint. If some constraint eic is an equality constraint, we define the optimal value function for this constraint as

feic(β)=z(lc+βei,uc+βei,lx,ux,c)

Thus for an equality constraint the upper and the lower bounds (which are equal) are perturbed simultaneously. Therefore, MOSEK will handle sensitivity analysis differently for a ranged constraint with lic=uic and for an equality constraint.

9.3.1.2 The Basis Type Sensitivity Analysis

The classical sensitivity analysis discussed in most textbooks about linear optimization, e.g. [Chvatal83], is based on an optimal basis. This method may produce misleading results [RTV97] but is computationally cheap. This is the type of sensitivity analysis implemented in MOSEK.

We will now briefly discuss the basis type sensitivity analysis. Given an optimal basic solution which provides a partition of variables into basic and non-basic variables, the basis type sensitivity analysis computes the linearity interval [β1,β2] so that the basis remains optimal for the perturbed problem. A shadow price associated with the linearity interval is also computed. However, it is well-known that an optimal basic solution may not be unique and therefore the result depends on the optimal basic solution employed in the sensitivity analysis. If the optimal objective value function has a breakpoint for β=0 then the basis type sensitivity method will only provide a subset of either the left or the right linearity interval.

In summary, the basis type sensitivity analysis is computationally cheap but does not provide complete information. Hence, the results of the basis type sensitivity analysis should be used with care.

9.3.1.3 Example: Sensitivity Analysis

As an example we will use the following transportation problem. Consider the problem of minimizing the transportation cost between a number of production plants and stores. Each plant supplies a number of goods and each store has a given demand that must be met. Supply, demand and cost of transportation per unit are shown in Fig. 9.3.

_images/transportp2.png

Fig. 9.3 Supply, demand and cost of transportation.

If we denote the number of transported goods from location i to location j by xij, problem can be formulated as the linear optimization problem of minimizing

1x11+2x12+5x23+2x24+1x31+2x33+1x34

subject to

(9.5)x11+x12400,x23+x241200,x31+x33+x341000,x11+x31=800,x12=100,x23+x33=500,x24+x34=500,x11,x12,x23,x24,x31,x33,x340.

The sensitivity parameters are shown in Table 9.1 and Table 9.2.

Table 9.1 Ranges and shadow prices related to bounds on constraints and variables.

Con.

β1

β2

σ1

σ2

1

300.00

0.00

3.00

3.00

2

700.00

+

0.00

0.00

3

500.00

0.00

3.00

3.00

4

0.00

500.00

4.00

4.00

5

0.00

300.00

5.00

5.00

6

0.00

700.00

5.00

5.00

7

500.00

700.00

2.00

2.00

Var.

β1

β2

σ1

σ2

x11

300.00

0.00

0.00

x12

100.00

0.00

0.00

x23

0.00

0.00

0.00

x24

500.00

0.00

0.00

x31

500.00

0.00

0.00

x33

500.00

0.00

0.00

x34

0.000000

500.00

2.00

2.00


Table 9.2 Ranges and shadow prices related to the objective coefficients.

Var.

β1

β2

σ1

σ2

c1

3.00

300.00

300.00

c2

100.00

100.00

c3

2.00

0.00

0.00

c4

2.00

500.00

500.00

c5

3.00

500.00

500.00

c6

2.00

500.00

500.00

c7

2.00

0.00

0.00


Examining the results from the sensitivity analysis we see that for constraint number 1 we have σ1=3 and β1=300, β2=0.

If the upper bound on constraint 1 is decreased by

β[0,300]

then the optimal objective value will increase by the value

σ1β=3β.

9.3.2 Sensitivity Analysis with MOSEK

A sensitivity analysis can be performed with the MOSEK command line tool specifying the option -sen, e.g.

mosek myproblem.mps -sen sensitivity.ssp

where sensitivity.ssp is a file in the format described in the next section. The ssp file describes which parts of the problem the sensitivity analysis should be performed on, see Sec. 9.3.2.1 (Sensitivity Analysis Specification File).

By default results are written to a file named myproblem.sen. If necessary, this file name can be changed by setting the MSK_SPAR_SENSITIVITY_RES_FILE_NAME parameter.

9.3.2.1 Sensitivity Analysis Specification File

MOSEK employs an MPS-like file format to specify on which model parameters the sensitivity analysis should be performed. The format of the sensitivity specification file is shown in Listing 9.2, where capitalized names are keywords, and names in brackets are names of the constraints and variables to be included in the analysis.

Listing 9.2 Sensitivity analysis file specification.
BOUNDS CONSTRAINTS
U|L|LU [cname1]
U|L|LU [cname2]-[cname3]
BOUNDS VARIABLES
U|L|LU [vname1]
U|L|LU [vname2]-[vname3]
OBJECTIVE VARIABLES
[vname1]
[vname2]-[vname3]

The sensitivity specification file has three sections, i.e.

  • BOUNDS CONSTRAINTS: Specifies on which bounds on constraints the sensitivity analysis should be performed.

  • BOUNDS VARIABLES: Specifies on which bounds on variables the sensitivity analysis should be performed.

  • OBJECTIVE VARIABLES: Specifies on which objective coefficients the sensitivity analysis should be performed.

A line in the body of a section must begin with a whitespace. In the BOUNDS sections one of the keys L, U, and LU must appear next. These keys specify whether the sensitivity analysis is performed on the lower bound, on the upper bound, or on both the lower and the upper bound respectively. Next, a single constraint (variable) or range of constraints (variables) is specified.

Recall from Sec. 9.3.1.1.1 (Equality Constraints) that equality constraints are handled in a special way. Sensitivity analysis of an equality constraint can be specified with either L, U, or LU, all indicating the same, namely that upper and lower bounds (which are equal) are perturbed simultaneously.

As an example consider

BOUNDS CONSTRAINTS
L  "cons1"
U  "cons2"
LU "cons3"-"cons6"

which requests that sensitivity analysis is performed on the lower bound of the constraint named cons1, on the upper bound of the constraint named cons2, and on both lower and upper bound on the constraints named cons3 to cons6.

It is allowed to use indexes instead of names, for instance

BOUNDS CONSTRAINTS
L  "cons1"
U  2
LU 3 - 6

The character * indicates that the line contains a comment and is ignored.

9.3.2.2 Example: Sensitivity Analysis from Command Line

As an example consider problem (9.5): the sensitivity file shown below (included in the distribution among the examples).

Listing 9.3 Sensitivity file for problem (9.5). Click here to download.
* Comment 1

BOUNDS CONSTRAINTS
 U "c1"         * Analyze upper bound for constraints named c1 
 U 2            * Analyze upper bound for constraints with index 2 
 U 3-5          * Analyze upper bound for constraint with index in interval [3:5] 

VARIABLES CONSTRAINTS
 L 2-4          * This section specifies which bounds on variables should be analyzed.  
 L "x11" 
OBJECTIVE CONSTRAINTS
 "x11"          * This section specifies which objective coeficients should be analysed. 
 2

The command

mosek transport.lp -sen sensitivity.ssp

produces the output file as follow

Listing 9.4 Results of sensitivity analysis
BOUNDS CONSTRAINTS
INDEX    NAME             BOUND    LEFTRANGE        RIGHTRANGE       LEFTPRICE        RIGHTPRICE
0        c1               UP       -6.574875e-18    5.000000e+02     1.000000e+00     1.000000e+00
2        c3               UP       -6.574875e-18    5.000000e+02     1.000000e+00     1.000000e+00
3        c4               FIX      -5.000000e+02    6.574875e-18     2.000000e+00     2.000000e+00
4        c5               FIX      -1.000000e+02    6.574875e-18     3.000000e+00     3.000000e+00
5        c6               FIX      -5.000000e+02    6.574875e-18     3.000000e+00     3.000000e+00

BOUNDS VARIABLES
INDEX    NAME             BOUND    LEFTRANGE        RIGHTRANGE       LEFTPRICE        RIGHTPRICE
2        x23              LO       -6.574875e-18    5.000000e+02     2.000000e+00     2.000000e+00
3        x24              LO       -inf             5.000000e+02     0.000000e+00     0.000000e+00
4        x31              LO       -inf             5.000000e+02     0.000000e+00     0.000000e+00
0        x11              LO       -inf             3.000000e+02     0.000000e+00     0.000000e+00

OBJECTIVE VARIABLES
INDEX    NAME                      LEFTRANGE        RIGHTRANGE       LEFTPRICE        RIGHTPRICE
0        x11                       -inf             1.000000e+00     3.000000e+02     3.000000e+02
2        x23                       -2.000000e+00    +inf             0.000000e+00     0.000000e+00

9.3.2.3 Controlling Log Output

Setting the parameter MSK_IPAR_LOG_SENSITIVITY to 1 or 0 (default) controls whether or not the results from sensitivity calculations are printed to the message stream.

The parameter MSK_IPAR_LOG_SENSITIVITY_OPT controls the amount of debug information on internal calculations from the sensitivity analysis.