/usr/include/ql/experimental/coupons/swapspreadindex.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 | /*
Copyright (C) 2014 Peter Caspers
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 swapspreadindex.hpp
\brief swap-rate spread indexes
*/
#ifndef quantlib_swapspreadindex_hpp
#define quantlib_swapspreadindex_hpp
#include <ql/indexes/swapindex.hpp>
namespace QuantLib {
//! class for swap-rate spread indexes
class SwapSpreadIndex : public virtual InterestRateIndex {
public:
SwapSpreadIndex(const std::string& familyName,
const boost::shared_ptr<SwapIndex>& swapIndex1,
const boost::shared_ptr<SwapIndex>& swapIndex2,
const Real gearing1 = 1.0,
const Real gearing2 = -1.0);
//! \name InterestRateIndex interface
//@{
Date maturityDate(const Date& valueDate) const {
QL_FAIL("SwapSpreadIndex does not provide a single maturity date");
}
Rate forecastFixing(const Date& fixingDate) const;
Rate pastFixing(const Date& fixingDate) const;
bool allowsNativeFixings() { return false; }
//@}
//! \name Inspectors
//@{
boost::shared_ptr<SwapIndex> swapIndex1() { return swapIndex1_; }
boost::shared_ptr<SwapIndex> swapIndex2() { return swapIndex2_; }
Real gearing1() { return gearing1_; }
Real gearing2() { return gearing2_; }
//@}
private:
boost::shared_ptr<SwapIndex> swapIndex1_, swapIndex2_;
Real gearing1_, gearing2_;
};
inline Rate SwapSpreadIndex::forecastFixing(const Date& fixingDate) const {
return gearing1_ * swapIndex1_->fixing(fixingDate,false) +
gearing2_ * swapIndex2_->fixing(fixingDate,false);
}
inline Rate SwapSpreadIndex::pastFixing(const Date& fixingDate) const {
return gearing1_ * swapIndex1_->pastFixing(fixingDate) +
gearing2_ * swapIndex2_->pastFixing(fixingDate);
}
}
#endif
|