QuantLib
: a free/open-source library for quantitative finance
Fully annotated sources - version 1.32
Loading...
Searching...
No Matches
ql
processes
coxingersollrossprocess.cpp
1
/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2
3
/*
4
Copyright (C) 2020 Lew Wei Hao
5
6
This file is part of QuantLib, a free-software/open-source library
7
for financial quantitative analysts and developers - http://quantlib.org/
8
9
QuantLib is free software: you can redistribute it and/or modify it
10
under the terms of the QuantLib license. You should have received a
11
copy of the license along with this program; if not, please email
12
<quantlib-dev@lists.sf.net>. The license is also available online at
13
<http://quantlib.org/license.shtml>.
14
15
This program is distributed in the hope that it will be useful, but WITHOUT
16
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
17
FOR A PARTICULAR PURPOSE. See the license for more details.
18
*/
19
20
#include <ql/processes/coxingersollrossprocess.hpp>
21
22
namespace
QuantLib
{
23
24
CoxIngersollRossProcess::CoxIngersollRossProcess
(
Real
speed,
25
Volatility
vol,
26
Real
x0,
27
Real
level)
28
: x0_(x0), speed_(speed), level_(level), volatility_(vol) {
29
QL_REQUIRE(
volatility_
>= 0.0,
"negative volatility given"
);
30
}
31
32
Real
CoxIngersollRossProcess::variance
(
Time
,
Real
,
Time
dt)
const
{
33
Real
exponent1 = std::exp(-
speed_
* dt);
34
Real
exponent2 = std::exp(-2 *
speed_
* dt);
35
Real
fraction = (
volatility_
*
volatility_
) /
speed_
;
36
37
return
x0_
* fraction * (exponent1 - exponent2) +
level_
* fraction * (1 - exponent1) * (1 - exponent1);
38
}
39
40
}
41
QuantLib::CoxIngersollRossProcess::speed_
Real speed_
Definition:
coxingersollrossprocess.hpp:68
QuantLib::CoxIngersollRossProcess::CoxIngersollRossProcess
CoxIngersollRossProcess(Real speed, Volatility vol, Real x0=0.0, Real level=0.0)
Definition:
coxingersollrossprocess.cpp:24
QuantLib::CoxIngersollRossProcess::level_
Real level_
Definition:
coxingersollrossprocess.hpp:68
QuantLib::CoxIngersollRossProcess::variance
Real variance(Time t0, Real x0, Time dt) const override
Definition:
coxingersollrossprocess.cpp:32
QuantLib::CoxIngersollRossProcess::x0_
Real x0_
Definition:
coxingersollrossprocess.hpp:68
QuantLib::CoxIngersollRossProcess::volatility_
Volatility volatility_
Definition:
coxingersollrossprocess.hpp:69
QuantLib::Time
Real Time
continuous quantity with 1-year units
Definition:
types.hpp:62
QuantLib::Real
QL_REAL Real
real number
Definition:
types.hpp:50
QuantLib::Volatility
Real Volatility
volatility
Definition:
types.hpp:78
QuantLib
Definition:
any.hpp:35
Generated by
Doxygen
1.9.5