srpchase.gms : Scenario Tree Construction Example

Description

SCENRED - Scenario Tree Construction Example
3-stage stochastic purchase example problem

Analytical solution:
    OPT  = 4.167 (Optimal value)
    VOPI = 3.667 (Value of perfect information)

H. Heitsch, W. Roemisch, and C. Strugarek
Stability of Multistage Stochastic Programs
SIAM Journal on Optimization 17 (2006), 511-525

Keywords: linear programming, stochastic programming, scenario tree construction

  Dimension (even number)


Small Model of Type : LP


Category : GAMS Model library


Main file : srpchase.gms

$title Scenario Tree Construction Example (SRPCHASE,SEQ=344)

$onText
SCENRED - Scenario Tree Construction Example
3-stage stochastic purchase example problem

Analytical solution:
    OPT  = 4.167 (Optimal value)
    VOPI = 3.667 (Value of perfect information)

H. Heitsch, W. Roemisch, and C. Strugarek
Stability of Multistage Stochastic Programs
SIAM Journal on Optimization 17 (2006), 511-525

Keywords: linear programming, stochastic programming, scenario tree construction
$offText

* Dimension (even number)
$if not set DIM $set DIM 1000
$ifE mod(%DIM%,2)=1 $eval DIM %DIM%+1

Set
   n             'nodes'            / n0*n%DIM% /
   t             'time periods'     / t1*t3     /
   stage(n,t)    'stage mapping'
   ancestor(n,n) 'ancestor matrix'
   leaf(n)       'leaf nodes';

* Build a fan
* Assign stage mapping and leaf nodes
stage('n0','t1') = yes;
stage( n  ,'t2') = ord(n) > 1 and ord(n) <= %DIM%/2 + 1;
stage( n  ,'t3') = ord(n) > %DIM%/2 + 1;

leaf(n) = stage(n,'t3');

* Build ancenstor relations to represent the fan
ancestor(n,'n0')$stage(n,'t2')         = yes;
ancestor(n,n-card(leaf))$stage(n,'t3') = yes;

* Random variables (price) and probabilities
Parameter
   price(n) 'node prices'
   prob(n)  'node probabilities';

prob(n) = 1/card(leaf);

* First stage
price('n0') = 1;
prob('n0')  = 1;

* Second stage - price is uniformly distributed in [0,1]
price(n)$stage(n,'t2') = uniform(0,1);

* Third stage - price is conditional linearly distributed
Scalar alpha, beta;

loop(stage(n,'t3'),
   alpha         = 1 -   price(n - card(leaf));
   beta          = 1 - 2*price(n - card(leaf));
   price(n)      = uniform(0,1);
   price(n)$beta = alpha/beta - sign(beta)*sqrt(sqr(alpha/beta) - price(n)/beta);
);

* Initialize ScenRed
$set srprefix srpchase
$libInclude scenred

File fopts 'Scenred option file' / 'sr2%srprefix%.opt' /;
putClose fopts 'order           1'
             / 'section   epsilon'
             / ' 2           0.05'
             / ' 3           0.05'
             / 'end';

* Scenred method choice
ScenRedParms('construction_method') = 2;
ScenRedParms('reduction_method'   ) = 2;
ScenRedParms('sroption'           ) = 1;

* Scenred call
$libInclude scenred %srprefix% tree_con n ancestor prob ancestor prob price

Variable
   x(n) 'amount of purchase'
   y(n) 'slack variable'
   cost 'objective value';

Positive Variable x, y;

Equation
   objective 'expected cost'
   slack(n)  'slack equation'
   demand(n) 'demand inequality';

Set srn(n) 'subset of nodes after tree construction';
srn(n) = prob(n);

objective.. cost =e= sum(srn, prob(srn)*price(srn)*x(srn));

slack(srn)$(not leaf(srn)).. y(srn) =e= x(srn) + sum(ancestor(srn,n), y(n));

demand(leaf(srn)).. x(srn) + sum(ancestor(srn,n), y(n)) =g= 1;

Model purchase / all /;

solve purchase minimizing cost using lp;