Logo
Fully annotated reference manual - version 1.8.12
Loading...
Searching...
No Matches
normalsabrsmilesection.cpp
Go to the documentation of this file.
1/*
2 Copyright (C) 2017 Quaternion Risk Management Ltd
3 All rights reserved.
4
5 This file is part of ORE, a free-software/open-source library
6 for transparent pricing and risk analysis - http://opensourcerisk.org
7
8 ORE is free software: you can redistribute it and/or modify it
9 under the terms of the Modified BSD License. You should have received a
10 copy of the license along with this program.
11 The license is also available online at <http://opensourcerisk.org>
12
13 This program is distributed on the basis that it will form a useful
14 contribution to risk analytics and model standardisation, but WITHOUT
15 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
16 FITNESS FOR A PARTICULAR PURPOSE. See the license for more details.
17*/
18
21
22#include <ql/termstructures/volatility/sabr.hpp>
23#include <ql/utilities/dataformatters.hpp>
24
25namespace QuantExt {
26
27NormalSabrSmileSection::NormalSabrSmileSection(Time timeToExpiry, Rate forward, const std::vector<Real>& sabrParams)
28 : SmileSection(timeToExpiry, DayCounter(), Normal), forward_(forward) {
29 alpha_ = sabrParams[0];
30 nu_ = sabrParams[1];
31 rho_ = sabrParams[2];
32 // validateSabrParameters(alpha_, 0.0, nu_, rho_);
33}
34
35NormalSabrSmileSection::NormalSabrSmileSection(const Date& d, Rate forward, const std::vector<Real>& sabrParams,
36 const DayCounter& dc)
37 : SmileSection(d, dc, Date(), Normal), forward_(forward) {
38 alpha_ = sabrParams[0];
39 nu_ = sabrParams[1];
40 rho_ = sabrParams[2];
41 // validateSabrParameters(alpha_, 0.0, nu_, rho_);
42}
43
44Real NormalSabrSmileSection::varianceImpl(Rate strike) const {
45 Volatility vol = normalSabrVolatility(strike, forward_, exerciseTime(), alpha_, nu_, rho_);
46 return vol * vol * exerciseTime();
47}
48
50 Real vol = normalSabrVolatility(strike, forward_, exerciseTime(), alpha_, nu_, rho_);
51 return vol;
52}
53} // namespace QuantExt
NormalSabrSmileSection(Time timeToExpiry, Rate forward, const std::vector< Real > &sabrParameters)
Real varianceImpl(Rate strike) const override
Volatility volatilityImpl(Rate strike) const override
Real normalSabrVolatility(Rate strike, Rate forward, Time expiryTime, Real alpha, Real nu, Real rho)
Definition: normalsabr.cpp:28
normal SABR model implied volatility approximation
normal sabr smile section class