/usr/include/ql/cashflows/inflationcouponpricer.hpp is in libquantlib0-dev 1.4-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 | /* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
Copyright (C) 2009 Chris Kenyon
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 inflationcouponpricer.hpp
\brief inflation-coupon pricers
*/
#ifndef quantlib_inflation_coupon_pricer_hpp
#define quantlib_inflation_coupon_pricer_hpp
#include <ql/cashflow.hpp>
#include <ql/option.hpp>
#include <ql/cashflows/yoyinflationcoupon.hpp>
#include <ql/termstructures/volatility/inflation/yoyinflationoptionletvolatilitystructure.hpp>
namespace QuantLib {
//! Base inflation-coupon pricer.
/*! The main reason we can't use FloatingRateCouponPricer as the
base is that it takes a FloatingRateCoupon which takes an
InterestRateIndex and we need an inflation index (these are
lagged).
The basic inflation-specific thing that the pricer has to do
is deal with different lags in the index and the option
e.g. the option could look 3 months back and the index 2.
We add the requirement that pricers do inverseCap/Floor-lets.
These are cap/floor-lets as usually defined, i.e. pay out if
underlying is above/below a strike. The non-inverse (usual)
versions are from a coupon point of view (a capped coupon has
a maximum at the strike).
We add the inverse prices so that conventional caps can be
priced simply.
*/
class InflationCouponPricer: public virtual Observer,
public virtual Observable {
public:
virtual ~InflationCouponPricer() {}
//! \name Interface
//@{
virtual Real swapletPrice() const = 0;
virtual Rate swapletRate() const = 0;
virtual Real capletPrice(Rate effectiveCap) const = 0;
virtual Rate capletRate(Rate effectiveCap) const = 0;
virtual Real floorletPrice(Rate effectiveFloor) const = 0;
virtual Rate floorletRate(Rate effectiveFloor) const = 0;
virtual void initialize(const InflationCoupon&) = 0;
//@}
//! \name Observer interface
//@{
virtual void update(){notifyObservers();}
//@}
protected:
Handle<YieldTermStructure> rateCurve_;
Date paymentDate_;
};
//! base pricer for capped/floored YoY inflation coupons
/*! \note this pricer can already do swaplets but to get
volatility-dependent coupons you need the descendents.
*/
class YoYInflationCouponPricer : public InflationCouponPricer {
public:
YoYInflationCouponPricer(const Handle<YoYOptionletVolatilitySurface>& capletVol
= Handle<YoYOptionletVolatilitySurface>());
virtual Handle<YoYOptionletVolatilitySurface> capletVolatility() const{
return capletVol_;
}
virtual void setCapletVolatility(
const Handle<YoYOptionletVolatilitySurface>& capletVol);
//! \name InflationCouponPricer interface
//@{
virtual Real swapletPrice() const;
virtual Rate swapletRate() const;
virtual Real capletPrice(Rate effectiveCap) const;
virtual Rate capletRate(Rate effectiveCap) const;
virtual Real floorletPrice(Rate effectiveFloor) const;
virtual Rate floorletRate(Rate effectiveFloor) const;
virtual void initialize(const InflationCoupon&);
//@}
protected:
//! car replace this if really required
virtual Real optionletPrice(Option::Type optionType,
Real effStrike) const;
//! usually only need implement this (of course they may need
//! to re-implement initialize too ...)
virtual Real optionletPriceImp(Option::Type, Real strike,
Real forward, Real stdDev) const;
virtual Rate adjustedFixing(Rate fixing = Null<Rate>()) const;
//! data
Handle<YoYOptionletVolatilitySurface> capletVol_;
const YoYInflationCoupon* coupon_;
Real gearing_;
Spread spread_;
Real discount_;
Real spreadLegValue_;
};
//! Black-formula pricer for capped/floored yoy inflation coupons
class BlackYoYInflationCouponPricer : public YoYInflationCouponPricer {
public:
BlackYoYInflationCouponPricer(
const Handle<YoYOptionletVolatilitySurface>& capletVol
= Handle<YoYOptionletVolatilitySurface>())
: YoYInflationCouponPricer(capletVol) {}
virtual ~BlackYoYInflationCouponPricer() {}
protected:
Real optionletPriceImp(Option::Type, Real strike,
Real forward, Real stdDev) const;
};
//! Unit-Displaced-Black-formula pricer for capped/floored yoy inflation coupons
class UnitDisplacedBlackYoYInflationCouponPricer
: public YoYInflationCouponPricer {
public:
UnitDisplacedBlackYoYInflationCouponPricer(
const Handle<YoYOptionletVolatilitySurface>& capletVol
= Handle<YoYOptionletVolatilitySurface>())
: YoYInflationCouponPricer(capletVol) {}
virtual ~UnitDisplacedBlackYoYInflationCouponPricer() {}
protected:
Real optionletPriceImp(Option::Type, Real strike,
Real forward, Real stdDev) const;
};
//! Bachelier-formula pricer for capped/floored yoy inflation coupons
class BachelierYoYInflationCouponPricer
: public YoYInflationCouponPricer {
public:
BachelierYoYInflationCouponPricer(
const Handle<YoYOptionletVolatilitySurface>& capletVol
= Handle<YoYOptionletVolatilitySurface>())
: YoYInflationCouponPricer(capletVol) {}
virtual ~BachelierYoYInflationCouponPricer() {}
protected:
Real optionletPriceImp(Option::Type, Real strike,
Real forward, Real stdDev) const;
};
}
#endif
|