swaptionvolmatrix.hpp
来自「有很多的函数库」· HPP 代码 · 共 201 行
HPP
201 行
/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
Copyright (C) 2006 Fran鏾is du Vignaud
Copyright (C) 2006 Ferdinando Ametrano
Copyright (C) 2000, 2001, 2002, 2003 RiskMap srl
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
<http://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 swaptionvolmatrix.hpp
\brief Swaption at-the-money volatility matrix
*/
#ifndef quantlib_swaption_volatility_matrix_hpp
#define quantlib_swaption_volatility_matrix_hpp
#include <ql/termstructures/volatilities/swaptionvoldiscrete.hpp>
#include <ql/time/daycounters/actual365fixed.hpp>
#include <ql/math/matrix.hpp>
#include <ql/math/interpolations/bilinearinterpolation.hpp>
#include <ql/quote.hpp>
#include <ql/patterns/lazyobject.hpp>
#include <boost/noncopyable.hpp>
#include <vector>
namespace QuantLib {
//! At-the-money swaption-volatility matrix
/*! This class provides the at-the-money volatility for a given
swaption by interpolating a volatility matrix whose elements
are the market volatilities of a set of swaption with given
option date and swapLength.
The volatility matrix <tt>M</tt> must be defined so that:
- the number of rows equals the number of option dates;
- the number of columns equals the number of swap tenors;
- <tt>M[i][j]</tt> contains the volatility corresponding
to the <tt>i</tt>-th option and <tt>j</tt>-th tenor.
*/
class SwaptionVolatilityMatrix : public LazyObject,
public SwaptionVolatilityDiscrete,
private boost::noncopyable {
public:
//! floating reference date, floating market data
SwaptionVolatilityMatrix(
const Calendar& calendar,
const std::vector<Period>& optionTenors,
const std::vector<Period>& swapTenors,
const std::vector<std::vector<Handle<Quote> > >& vols,
const DayCounter& dayCounter = Actual365Fixed(),
BusinessDayConvention bdc = Following);
//! fixed reference date, floating market data
SwaptionVolatilityMatrix(
const Date& referenceDate,
const Calendar& calendar,
const std::vector<Period>& optionTenors,
const std::vector<Period>& swapTenors,
const std::vector<std::vector<Handle<Quote> > >& vols,
const DayCounter& dayCounter = Actual365Fixed(),
BusinessDayConvention bdc = Following);
//! floating reference date, fixed market data
SwaptionVolatilityMatrix(
const Calendar& calendar,
const std::vector<Period>& optionTenors,
const std::vector<Period>& swapTenors,
const Matrix& volatilities,
const DayCounter& dayCounter = Actual365Fixed(),
BusinessDayConvention bdc = Following);
//! fixed reference date, fixed market data
SwaptionVolatilityMatrix(
const Date& referenceDate,
const Calendar& calendar,
const std::vector<Period>& optionTenors,
const std::vector<Period>& swapTenors,
const Matrix& volatilities,
const DayCounter& dayCounter = Actual365Fixed(),
BusinessDayConvention bdc = Following);
//! \deprecated alternative constructors instead
// fixed reference date and fixed market data, option dates
SwaptionVolatilityMatrix(const Date& referenceDate,
const std::vector<Date>& optionDates,
const std::vector<Period>& swapTenors,
const Matrix& volatilities,
const DayCounter& dayCounter);
//! \name TermStructure interface
//@{
Date maxDate() const;
//@}
//! \name LazyObject interface
//@{
void update();
void performCalculations() const;
//@}
//! \name SwaptionVolatilityStructure interface
//@{
const Period& maxSwapTenor() const;
Time maxSwapLength() const;
Rate minStrike() const;
Rate maxStrike() const;
//! return trivial smile section
boost::shared_ptr<SmileSection> smileSectionImpl(Time optionTime,
Time swapLength) const;
//@}
//! \name Other inspectors
//@{
//! returns the lower indexes of surrounding volatility matrix corners
std::pair<Size,Size> locate(const Date& optionDates,
const Period& swapTenor) const {
std::pair<Time,Time> times = convertDates(optionDates,swapTenor);
return locate(times.first, times.second);
}
//! returns the lower indexes of surrounding volatility matrix corners
std::pair<Size,Size> locate(Time optionTime,
Time swapLength) const {
return std::make_pair(interpolation_.locateY(optionTime),
interpolation_.locateX(swapLength));
}
//@}
private:
void checkInputs(Size volRows,
Size volsColumns) const;
void registerWithMarketData();
Volatility volatilityImpl(Time optionTime,
Time swapLength,
Rate strike) const;
Volatility volatilityImpl(const Date& optionDates,
const Period& swapTenor,
Rate strike) const;
Volatility volatilityImpl(const Period& optionTenor,
const Period& swapTenor,
Rate strike) const;
std::vector<std::vector<Handle<Quote> > > volHandles_;
mutable Matrix volatilities_;
Interpolation2D interpolation_;
};
// inline definitions
inline Date SwaptionVolatilityMatrix::maxDate() const {
return optionDates_.back();
}
inline const Period& SwaptionVolatilityMatrix::maxSwapTenor() const {
return swapTenors_.back();
}
inline Time SwaptionVolatilityMatrix::maxSwapLength() const {
return swapLengths_.back();
}
inline Rate SwaptionVolatilityMatrix::minStrike() const {
return -5.0; //FIXME
}
inline Rate SwaptionVolatilityMatrix::maxStrike() const {
return 5.0; //FIXME
}
inline Volatility SwaptionVolatilityMatrix::volatilityImpl(
Time optionTime, Time swapLength, Rate) const {
calculate();
return interpolation_(swapLength, optionTime, true);
}
inline Volatility SwaptionVolatilityMatrix::volatilityImpl(
const Date& optionDate,
const Period& swapTenor, Rate) const {
const std::pair<Time, Time> p = convertDates(optionDate, swapTenor);
return volatilityImpl(p.first, p.second,true);
}
inline Volatility SwaptionVolatilityMatrix::volatilityImpl(
const Period& optionTenor,
const Period& swapTenor, Rate) const {
Date optionDate = optionDateFromTenor(optionTenor);
return volatilityImpl(optionDate, swapTenor,true);
}
inline void SwaptionVolatilityMatrix::update(){
TermStructure::update();
LazyObject::update();
}
}
#endif
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?