/usr/include/ql/discretizedasset.hpp is in libquantlib0-dev 1.12-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 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 | /* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
Copyright (C) 2001, 2002, 2003 Sadruddin Rejeb
Copyright (C) 2004, 2005, 2006 StatPro Italia 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 discretizedasset.hpp
\brief Discretized asset classes
*/
#ifndef quantlib_discretized_asset_hpp
#define quantlib_discretized_asset_hpp
#include <ql/numericalmethod.hpp>
#include <ql/math/comparison.hpp>
#include <ql/exercise.hpp>
namespace QuantLib {
//! Discretized asset class used by numerical methods
class DiscretizedAsset {
public:
DiscretizedAsset()
: latestPreAdjustment_(QL_MAX_REAL),
latestPostAdjustment_(QL_MAX_REAL) {}
virtual ~DiscretizedAsset() {}
//! \name inspectors
//@{
Time time() const { return time_; }
Time& time() { return time_; }
const Array& values() const { return values_; }
Array& values() { return values_; }
const boost::shared_ptr<Lattice>& method() const {
return method_;
}
//@}
/*! \name High-level interface
Users of discretized assets should use these methods in
order to initialize, evolve and take the present value of
the assets. They call the corresponding methods in the
Lattice interface, to which we refer for
documentation.
@{
*/
void initialize(const boost::shared_ptr<Lattice>&,
Time t);
void rollback(Time to);
void partialRollback(Time to);
Real presentValue();
//@}
/*! \name Low-level interface
These methods (that developers should override when
deriving from DiscretizedAsset) are to be used by
numerical methods and not directly by users, with the
exception of adjustValues(), preAdjustValues() and
postAdjustValues() that can be used together with
partialRollback().
@{
*/
/*! This method should initialize the asset values to an Array
of the given size and with values depending on the
particular asset.
*/
virtual void reset(Size size) = 0;
/*! This method will be invoked after rollback and before any
other asset (i.e., an option on this one) has any chance to
look at the values. For instance, payments happening at times
already spanned by the rollback will be added here.
This method is not virtual; derived classes must override
the protected preAdjustValuesImpl() method instead.
*/
void preAdjustValues();
/*! This method will be invoked after rollback and after any
other asset had their chance to look at the values. For
instance, payments happening at the present time (and therefore
not included in an option to be exercised at this time) will be
added here.
This method is not virtual; derived classes must override
the protected postAdjustValuesImpl() method instead.
*/
void postAdjustValues();
/*! This method performs both pre- and post-adjustment */
void adjustValues() {
preAdjustValues();
postAdjustValues();
}
/*! This method returns the times at which the numerical
method should stop while rolling back the asset. Typical
examples include payment times, exercise times and such.
\note The returned values are not guaranteed to be sorted.
*/
virtual std::vector<Time> mandatoryTimes() const = 0;
//@}
protected:
/*! This method checks whether the asset was rolled at the
given time. */
bool isOnTime(Time t) const;
/*! This method performs the actual pre-adjustment */
virtual void preAdjustValuesImpl() {}
/*! This method performs the actual post-adjustment */
virtual void postAdjustValuesImpl() {}
Time time_;
Time latestPreAdjustment_, latestPostAdjustment_;
Array values_;
private:
boost::shared_ptr<Lattice> method_;
};
//! Useful discretized discount bond asset
class DiscretizedDiscountBond : public DiscretizedAsset {
public:
DiscretizedDiscountBond() {}
void reset(Size size) {
values_ = Array(size, 1.0);
}
std::vector<Time> mandatoryTimes() const {
return std::vector<Time>();
}
};
//! Discretized option on a given asset
/*! \warning it is advised that derived classes take care of
creating and initializing themselves an instance of
the underlying.
*/
class DiscretizedOption : public DiscretizedAsset {
public:
DiscretizedOption(
const boost::shared_ptr<DiscretizedAsset>& underlying,
Exercise::Type exerciseType,
const std::vector<Time>& exerciseTimes)
: underlying_(underlying), exerciseType_(exerciseType),
exerciseTimes_(exerciseTimes) {}
void reset(Size size);
std::vector<Time> mandatoryTimes() const;
protected:
void postAdjustValuesImpl();
void applyExerciseCondition();
boost::shared_ptr<DiscretizedAsset> underlying_;
Exercise::Type exerciseType_;
std::vector<Time> exerciseTimes_;
};
// inline definitions
inline void DiscretizedAsset::initialize(
const boost::shared_ptr<Lattice>& method,
Time t) {
method_ = method;
method_->initialize(*this, t);
}
inline void DiscretizedAsset::rollback(Time to) {
method_->rollback(*this, to);
}
inline void DiscretizedAsset::partialRollback(Time to) {
method_->partialRollback(*this, to);
}
inline Real DiscretizedAsset::presentValue() {
return method_->presentValue(*this);
}
inline void DiscretizedAsset::preAdjustValues() {
if (!close_enough(time(),latestPreAdjustment_)) {
preAdjustValuesImpl();
latestPreAdjustment_ = time();
}
}
inline void DiscretizedAsset::postAdjustValues() {
if (!close_enough(time(),latestPostAdjustment_)) {
postAdjustValuesImpl();
latestPostAdjustment_ = time();
}
}
inline bool DiscretizedAsset::isOnTime(Time t) const {
const TimeGrid& grid = method()->timeGrid();
return close_enough(grid[grid.index(t)],time());
}
inline void DiscretizedOption::reset(Size size) {
QL_REQUIRE(method() == underlying_->method(),
"option and underlying were initialized on "
"different methods");
values_ = Array(size, 0.0);
adjustValues();
}
inline std::vector<Time> DiscretizedOption::mandatoryTimes() const {
std::vector<Time> times = underlying_->mandatoryTimes();
// discard negative times...
std::vector<Time>::const_iterator i =
std::find_if(exerciseTimes_.begin(),exerciseTimes_.end(),
std::bind2nd(std::greater_equal<Time>(),0.0));
// and add the positive ones
times.insert(times.end(), i, exerciseTimes_.end());
return times;
}
inline void DiscretizedOption::applyExerciseCondition() {
for (Size i=0; i<values_.size(); i++)
values_[i] = std::max(underlying_->values()[i], values_[i]);
}
}
#endif
|