Description
ContinuosFinCalc.gms: Financial Calculator for continuos time discounting Consiglio, Nielsen and Zenios. PRACTICAL FINANCIAL OPTIMIZATION: A Library of GAMS Models, Section 4.2.2 Last modified: Apr 2008.
Category : GAMS FIN library
Mainfile : ContinuousFinCalc.gms
$title Financial Calculator for continuos time discounting
* ContinuosFinCalc.gms: Financial Calculator for continuos time discounting
* Consiglio, Nielsen and Zenios.
* PRACTICAL FINANCIAL OPTIMIZATION: A Library of GAMS Models, Section 4.2.2
* Last modified: Apr 2008.
* This file contains the continuous discounting formulas. See
* DiscreteFinCalc.gms for the corresponding discrete time formulas.
* To demonstrate the formulas we set up an artificial yield curve
* over a 30-year horizon; time points indicated by tau(t) start at 0
SET time /1 * 30/;
ALIAS (time,t,t1,t2);
PARAMETER
   tau(t) Time Tau;
* Time points are annual
tau(t) = ord(t) - 1;
* The toy yield curve:
PARAMETER
   r(t) Spot rates;
* Linear, increasing from 3% to 6%
r(t) = tau(t)/30*0.03 + 0.03;
* Discount factors and forward rate calculations:
PARAMETERS
  Discount(t)          Discount factors
  ForwRate(t1, t2)     Forward rates;
Discount(t) = exp( -r(t)*tau(t) );
ForwRate(t1,t2) $ (tau(t1) < tau(t2)) =
          (r(t2)*tau(t2) - r(t1)*tau(t1)) / (tau(t2)-tau(t1));
DISPLAY r, Discount, ForwRate;
* Now construct an artificial liability stream, and calculate its present value
PARAMETER
   L(t) Artificial liability stream;
L(t) = 1000 + normal(0, 1000);
* Present value of liabilities
PARAMETER
   PV Present value;
PV = SUM(t, L(t) * exp( -r(t)*tau(t) ));
DISPLAY PV;
* Alternative, using the Discount parameter.
* Of course, we must obtain the same value
PV = SUM(t, L(t) * Discount(t));
DISPLAY PV;