1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134
|
/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
Copyright (C) 2006 Ferdinando Ametrano
Copyright (C) 2006 Mario Pucci
Copyright (C) 2006 StatPro Italia srl
Copyright (C) 2015 Peter Caspers
Copyright (C) 2019 Klaus Spanderen
This file is part of QuantLib, a free-software/open-source library
for financial quantitative analysts and developers - http://quantlib.org/
QuantLib is free software: you can redistribute it and/or modify it
under the terms of the QuantLib license. You should have received a
copy of the license along with this program; if not, please email
<quantlib-dev@lists.sf.net>. The license is also available online at
<https://www.quantlib.org/license.shtml>.
This program is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. See the license for more details.
*/
/*! \file sabr.hpp
\brief SABR functions
*/
#ifndef quantlib_sabr_hpp
#define quantlib_sabr_hpp
#include <ql/types.hpp>
#include <ql/termstructures/volatility/volatilitytype.hpp>
#include <array>
namespace QuantLib {
Real unsafeSabrLogNormalVolatility(Rate strike,
Rate forward,
Time expiryTime,
Real alpha,
Real beta,
Real nu,
Real rho);
Real unsafeShiftedSabrVolatility(Rate strike,
Rate forward,
Time expiryTime,
Real alpha,
Real beta,
Real nu,
Real rho,
Real shift,
VolatilityType volatilityType = VolatilityType::ShiftedLognormal);
/* Normal SABR implemented according to
https://www2.deloitte.com/content/dam/Deloitte/global/Documents/Financial-Services/be-aers-fsi-sabr-sensitivities.pdf
*/
Real unsafeSabrNormalVolatility(Rate strike,
Rate forward,
Time expiryTime,
Real alpha,
Real beta,
Real nu,
Real rho);
Real unsafeSabrVolatility(Rate strike,
Rate forward,
Time expiryTime,
Real alpha,
Real beta,
Real nu,
Real rho,
VolatilityType volatilityType = VolatilityType::ShiftedLognormal);
Real sabrVolatility(Rate strike,
Rate forward,
Time expiryTime,
Real alpha,
Real beta,
Real nu,
Real rho,
VolatilityType volatilityType = VolatilityType::ShiftedLognormal);
Real shiftedSabrVolatility(Rate strike,
Rate forward,
Time expiryTime,
Real alpha,
Real beta,
Real nu,
Real rho,
Real shift,
VolatilityType volatilityType = VolatilityType::ShiftedLognormal);
Real sabrFlochKennedyVolatility(Rate strike,
Rate forward,
Time expiryTime,
Real alpha,
Real beta,
Real nu,
Real rho);
void validateSabrParameters(Real alpha,
Real beta,
Real nu,
Real rho);
//! Initial guess for SABR calibration
/*! See Fabien Le Floc’h and Gary Kennedy, "Explicit SABR Calibration through Simple Expansions",
available from <https://papers.ssrn.com/sol3/papers.cfm?abstract_id=2467231>.
The returned array contains the guesses for alpha, beta, nu and rho. The value for beta
is the one passed in input.
The idea is to estimate atm volatility, skew and curvature using the three volatility points
closest around the forward (k_0 and vol_0 would be the closest strike and its volatility,
k_m and vol_m the previous point, k_p and vol_p the following one) and solve a system for
the SABR parameters that match them.
\warning This functionality requires Boost 1.78 or later. When compiled with an earlier
version, calling this function will raise a run-time exception.
*/
std::array<Real, 4> sabrGuess(Real k_m, Volatility vol_m,
Real k_0, Volatility vol_0,
Real k_p, Volatility vol_p,
Rate forward,
Time expiryTime,
Real beta,
Real shift,
VolatilityType volatilityType);
}
#endif
|