/usr/include/ql/cashflows/cpicouponpricer.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 | /* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
Copyright (C) 2009, 2011 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 cpicouponpricer.hpp
\brief zero inflation-coupon pricer
*/
#ifndef quantlib_cpicouponpricer_hpp
#define quantlib_cpicouponpricer_hpp
#include <ql/cashflow.hpp>
#include <ql/option.hpp>
#include <ql/cashflows/inflationcouponpricer.hpp>
#include <ql/cashflows/cpicoupon.hpp>
#include <ql/termstructures/volatility/inflation/cpivolatilitystructure.hpp>
namespace QuantLib {
//! base pricer for capped/floored CPI coupons N.B. vol-dependent parts are a TODO
/*! \note this pricer can already do swaplets but to get
volatility-dependent coupons you need to implement the descendents.
*/
class CPICouponPricer : public InflationCouponPricer {
public:
CPICouponPricer(const Handle<CPIVolatilitySurface>& capletVol
= Handle<CPIVolatilitySurface>());
virtual Handle<CPIVolatilitySurface> capletVolatility() const{
return capletVol_;
}
virtual void setCapletVolatility(
const Handle<CPIVolatilitySurface>& 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:
//! can 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<CPIVolatilitySurface> capletVol_;
const CPICoupon* coupon_;
Real gearing_;
Spread spread_;
Real discount_;
Real spreadLegValue_;
};
} // namespace QuantLib
#endif
|