Documentation Center

  • Trial Software
  • Product Updates

floorbylg2f

Price floor using Linear Gaussian two-factor model

Syntax

  • FloorPrice = floorbylg2f(ZeroCurve,a,b,sigma,eta,rho,Strike,
    Maturity)
    example
  • CapPrice = floorbylg2f(___,Name,Value) example

Description

example

FloorPrice = floorbylg2f(ZeroCurve,a,b,sigma,eta,rho,Strike,
Maturity)
returns the floor price for a two-factor additive Gaussian interest-rate model.

example

CapPrice = floorbylg2f(___,Name,Value) returns the floor price for a two-factor additive Gaussian interest-rate model using optional name-value pairs.

Examples

expand all

Price a Floor Using a Linear Gaussian Two-Factor Model

Define the ZeroCurve, a, b, sigma, eta, and rho parameters to compute the floor price.

Settle = datenum('15-Dec-2007');

ZeroTimes = [3/12 6/12 1 5 7 10 20 30]';
ZeroRates = [0.033 0.034 0.035 0.040 0.042 0.044 0.048 0.0475]';
CurveDates = daysadd(Settle,360*ZeroTimes,1);

irdc = IRDataCurve('Zero',Settle,CurveDates,ZeroRates);

a = .07;
b = .5;
sigma = .01;
eta = .006;
rho = -.7;

FloorMaturity = daysadd(Settle,360*[1:5 7 10 15 20 25 30],1);

Strike = [0.035 0.037 0.038 0.039 0.040 0.042 0.044 0.046 0.047 0.047 0.047]';

Price = floorbylg2f(irdc,a,b,sigma,eta,rho,Strike,FloorMaturity)
Price =

         0
    0.4041
    0.8282
    1.3103
    1.8346
    3.0636
    4.9172
    7.7614
    9.7166
   11.4163
   12.7628

Input Arguments

expand all

ZeroCurve — Zero curve for Linear Gaussian two-factor modelstructure

Zero curve for the Linear Gaussian two-factor model, specified using IRDataCurve or RateSpec.

Data Types: struct

a — Mean reversion for first factor for Linear Gaussian two-factor modelscalar

Mean reversion for the first factor for the Linear Gaussian two-factor model, specified as a scalar.

Data Types: single | double

b — Mean reversion for second factor for Linear Gaussian two-factor modelscalar

Mean reversion for the second factor for the Linear Gaussian two-factor model, specified as a scalar.

Data Types: single | double

sigma — Volatility for first factor for Linear Gaussian two-factor modelscalar

Volatility for the first factor for the Linear Gaussian two-factor model, specified as a scalar.

Data Types: single | double

eta — Volatility for second factor for Linear Gaussian two-factor modelscalar

Volatility for the second factor for the Linear Gaussian two-factor model, specified as a scalar.

Data Types: single | double

rho — Scalar correlation of factorsscalar

Scalar correlation of the factors, specified as a scalar.

Data Types: single | double

Strike — Floor strike pricenonnegative integer | vector of nonnegative integers

Floor strike price specified, as a nonnegative integer using a NumFloors-by-1 vector of floor strike prices.

Data Types: single | double

Maturity — Floor maturity datenonnegative integer | vector of nonnegative integers | string of dates

Floor maturity date, specified using a NumFloors-by-1 vector of serial date numbers or date strings.

Data Types: single | double | cell

Name-Value Pair Arguments

Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and Value is the corresponding value. Name must appear inside single quotes (' '). You can specify several name and value pair arguments in any order as Name1,Value1,...,NameN,ValueN.

Example: Price = floorbylg2f(irdc,a,b,sigma,eta,rho,Strike,FloorMaturity,'Reset',1,'Notional',100)

'Reset' — Frequency of floor payments per year2 (default) | positive integer from the set [1,2,3,4,6,12] | vector of positive integers from the set [1,2,3,4,6,12]

Frequency of floor payments per year, specified as positive integers for the values [1,2,4,6,12] in a NumFloors-by-1 vector.

Data Types: single | double

'Notional' — Notional value of floor100 (default) | nonnegative integer | vector of nonnegative integers

Notional value of the floor, specified as a nonnegative integer using a NumFloors-by-1 vector of notional amounts.

Data Types: single | double

Output Arguments

expand all

FloorPrice — Floor pricescalar | vector

Floor price, returned as a scalar or a NumFloors-by-1 vector.

More About

expand all

Algorithms

The following defines the two-factor additive Gaussian interest-rate model, given the ZeroCurve, a, b, sigma, eta, and rho parameters:

where is a two-dimensional Brownian motion with correlation ρ and ϕ is a function chosen to match the initial zero curve.

References

[1] Brigo, D. and F. Mercurio, Interest Rate Models - Theory and Practice, Springer Finance, 2006.

See Also

| |

Was this topic helpful?