/usr/include/ql/experimental/callablebonds/callablebond.hpp is in libquantlib0-dev 1.9.1-1.
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 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 | /* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
Copyright (C) 2008 Allen Kuo
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 callablebond.hpp
\brief callable bond classes
*/
#ifndef quantlib_callable_bond_hpp
#define quantlib_callable_bond_hpp
#include <ql/instruments/bond.hpp>
#include <ql/pricingengine.hpp>
#include <ql/instruments/callabilityschedule.hpp>
#include <ql/termstructures/yieldtermstructure.hpp>
#include <ql/handle.hpp>
#include <ql/quotes/simplequote.hpp>
namespace QuantLib {
class Schedule;
class DayCounter;
//! Callable bond base class
/*! Base callable bond class for fixed and zero coupon bonds.
Defines commonalities between fixed and zero coupon callable
bonds. At present, only European and Bermudan put/call schedules
supported (no American optionality), as defined by the Callability
class.
\todo models/shortrate/calibrationHelpers
\todo OAS/OAD
\todo floating rate callable bonds ?
\ingroup instruments
*/
class CallableBond : public Bond {
public:
class arguments;
class results;
class engine;
//! \name Inspectors
//@{
//! return the bond's put/call schedule
const CallabilitySchedule& callability() const {
return putCallSchedule_;
}
//@}
//! \name Calculations
//@{
//! returns the Black implied forward yield volatility
/*! the forward yield volatility, see Hull, Fourth Edition,
Chapter 20, pg 536). Relevant only to European put/call
schedules
*/
Volatility impliedVolatility(
Real targetValue,
const Handle<YieldTermStructure>& discountCurve,
Real accuracy,
Size maxEvaluations,
Volatility minVol,
Volatility maxVol) const;
//@}
virtual void setupArguments(PricingEngine::arguments*) const {}
protected:
CallableBond(Natural settlementDays,
const Schedule& schedule,
const DayCounter& paymentDayCounter,
const Date& issueDate = Date(),
const CallabilitySchedule& putCallSchedule
= CallabilitySchedule());
DayCounter paymentDayCounter_;
Frequency frequency_;
CallabilitySchedule putCallSchedule_;
//! must be set by derived classes for impliedVolatility() to work
mutable boost::shared_ptr<PricingEngine> blackEngine_;
//! Black fwd yield volatility quote handle to internal blackEngine_
mutable RelinkableHandle<Quote> blackVolQuote_;
//! Black fwd yield volatility quote handle to internal blackEngine_
mutable RelinkableHandle<YieldTermStructure> blackDiscountCurve_;
//! helper class for Black implied volatility calculation
class ImpliedVolHelper;
friend class ImpliedVolHelper;
class ImpliedVolHelper {
public:
ImpliedVolHelper(const CallableBond& bond,
Real targetValue);
Real operator()(Volatility x) const;
private:
boost::shared_ptr<PricingEngine> engine_;
Real targetValue_;
boost::shared_ptr<SimpleQuote> vol_;
const Instrument::results* results_;
};
};
class CallableBond::arguments : public Bond::arguments {
public:
arguments() {}
std::vector<Date> couponDates;
std::vector<Real> couponAmounts;
//! redemption = face amount * redemption / 100.
Real redemption;
Date redemptionDate;
DayCounter paymentDayCounter;
Frequency frequency;
CallabilitySchedule putCallSchedule;
//! bond full/dirty/cash prices
std::vector<Real> callabilityPrices;
std::vector<Date> callabilityDates;
void validate() const;
};
//! results for a callable bond calculation
class CallableBond::results : public Bond::results {
public:
// no extra results set yet
};
//! base class for callable fixed rate bond engine
class CallableBond::engine
: public GenericEngine<CallableBond::arguments,
CallableBond::results> {};
//! callable/puttable fixed rate bond
/*! Callable fixed rate bond class.
\ingroup instruments
<b> Example: </b>
\link CallableBonds.cpp
\endlink
*/
class CallableFixedRateBond : public CallableBond {
public:
CallableFixedRateBond(Natural settlementDays,
Real faceAmount,
const Schedule& schedule,
const std::vector<Rate>& coupons,
const DayCounter& accrualDayCounter,
BusinessDayConvention paymentConvention
= Following,
Real redemption = 100.0,
const Date& issueDate = Date(),
const CallabilitySchedule& putCallSchedule
= CallabilitySchedule());
virtual void setupArguments(PricingEngine::arguments* args) const;
private:
//! accrued interest used internally, where includeToday = false
/*! same as Bond::accruedAmount() but with enable early
payments true. Forces accrued to be calculated in a
consistent way for future put/ call dates, which can be
problematic in lattice engines when option dates are also
coupon dates.
*/
Real accrued(Date settlement) const;
};
//! callable/puttable zero coupon bond
/*! Callable zero coupon bond class.
\ingroup instruments
*/
class CallableZeroCouponBond : public CallableFixedRateBond {
public:
CallableZeroCouponBond(Natural settlementDays,
Real faceAmount,
const Calendar& calendar,
const Date& maturityDate,
const DayCounter& dayCounter,
BusinessDayConvention paymentConvention
= Following,
Real redemption = 100.0,
const Date& issueDate = Date(),
const CallabilitySchedule& putCallSchedule
= CallabilitySchedule());
};
}
#endif
|