DiscreteFinCalc : Financial Calculator for discrete time discounting

Description

DiscreteFinCalc.gms: Financial Calculator for discrete 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 : DiscreteFinCalc.gms

$title Financial Calculator for discrete time discounting

* DiscreteFinCalc.gms: Financial Calculator for discrete time discounting
* Consiglio, Nielsen and Zenios.
* PRACTICAL FINANCIAL OPTIMIZATION: A Library of GAMS Models, Section 4.2.2
* Last modified: Apr 2008.


* 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

* 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;

* A 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) = (1 + r(t)) ** (-tau(t));

ForwRate(t1,t2) $ (tau(t1) < tau(t2)) =
       (Discount(t1) / Discount(t2)) ** (1/(tau(t2) - tau(t1))) - 1;

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) * (1 + 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;