QuantLib
: a free/open-source library for quantitative finance
fully annotated source code - version 1.34
Loading...
Searching...
No Matches
ql
pricingengines
swaption
fdg2swaptionengine.hpp
Go to the documentation of this file.
1
/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2
3
/*
4
Copyright (C) 2011 Klaus Spanderen
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
/*! \file fdg2swaptionengine.hpp
21
\brief finite differences swaption engine
22
*/
23
24
#ifndef quantlib_fd_g2_swaption_engine_hpp
25
#define quantlib_fd_g2_swaption_engine_hpp
26
27
#include <
ql/instruments/swaption.hpp
>
28
#include <
ql/pricingengines/genericmodelengine.hpp
>
29
#include <
ql/models/shortrate/twofactormodels/g2.hpp
>
30
#include <
ql/methods/finitedifferences/solvers/fdmbackwardsolver.hpp
>
31
32
namespace
QuantLib
{
33
34
class
FdG2SwaptionEngine
35
:
public
GenericModelEngine
<G2,Swaption::arguments,Swaption::results> {
36
public
:
37
explicit
FdG2SwaptionEngine
(
38
const
ext::shared_ptr<G2>& model,
39
Size
tGrid = 100,
Size
xGrid = 50,
Size
yGrid = 50,
40
Size
dampingSteps = 0,
Real
invEps = 1e-5,
41
const
FdmSchemeDesc
& schemeDesc =
FdmSchemeDesc::Hundsdorfer
());
42
43
void
calculate
()
const override
;
44
45
private
:
46
const
Size
tGrid_
,
xGrid_
,
yGrid_
,
dampingSteps_
;
47
const
Real
invEps_
;
48
const
FdmSchemeDesc
schemeDesc_
;
49
};
50
}
51
#endif
QuantLib::FdG2SwaptionEngine
Definition:
fdg2swaptionengine.hpp:35
QuantLib::FdG2SwaptionEngine::calculate
void calculate() const override
Definition:
fdg2swaptionengine.cpp:48
QuantLib::FdG2SwaptionEngine::dampingSteps_
const Size dampingSteps_
Definition:
fdg2swaptionengine.hpp:46
QuantLib::FdG2SwaptionEngine::yGrid_
const Size yGrid_
Definition:
fdg2swaptionengine.hpp:46
QuantLib::FdG2SwaptionEngine::invEps_
const Real invEps_
Definition:
fdg2swaptionengine.hpp:47
QuantLib::FdG2SwaptionEngine::tGrid_
const Size tGrid_
Definition:
fdg2swaptionengine.hpp:46
QuantLib::FdG2SwaptionEngine::xGrid_
const Size xGrid_
Definition:
fdg2swaptionengine.hpp:46
QuantLib::FdG2SwaptionEngine::schemeDesc_
const FdmSchemeDesc schemeDesc_
Definition:
fdg2swaptionengine.hpp:48
QuantLib::GenericModelEngine
Base class for some pricing engine on a particular model.
Definition:
genericmodelengine.hpp:40
fdmbackwardsolver.hpp
g2.hpp
Two-factor additive Gaussian Model G2++.
genericmodelengine.hpp
Generic option engine based on a model.
QuantLib::Real
QL_REAL Real
real number
Definition:
types.hpp:50
QuantLib::Size
std::size_t Size
size of a container
Definition:
types.hpp:58
QuantLib
Definition:
any.hpp:35
QuantLib::FdmSchemeDesc
Definition:
fdmbackwardsolver.hpp:35
QuantLib::FdmSchemeDesc::Hundsdorfer
static FdmSchemeDesc Hundsdorfer()
Definition:
fdmbackwardsolver.cpp:58
swaption.hpp
Swaption class.
Generated by
Doxygen
1.9.5