/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* Copyright (C) 2000, 2001, 2002, 2003 RiskMap srl Copyright (C) 2003, 2004, 2005, 2007 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 . The license is also available online at . 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 flatforward.hpp \brief flat forward rate term structure */ #ifndef quantlib_flat_forward_curve_hpp #define quantlib_flat_forward_curve_hpp #include #include namespace QuantLib { //! Flat interest-rate curve /*! \ingroup yieldtermstructures */ class FlatForward : public YieldTermStructure { public: // constructors FlatForward(const Date& referenceDate, const Handle& forward, const DayCounter& dayCounter, Compounding compounding = Continuous, Frequency frequency = Annual); FlatForward(const Date& referenceDate, Rate forward, const DayCounter& dayCounter, Compounding compounding = Continuous, Frequency frequency = Annual); FlatForward(Natural settlementDays, const Calendar& calendar, const Handle& forward, const DayCounter& dayCounter, Compounding compounding = Continuous, Frequency frequency = Annual); FlatForward(Natural settlementDays, const Calendar& calendar, Rate forward, const DayCounter& dayCounter, Compounding compounding = Continuous, Frequency frequency = Annual); // inspectors Compounding compounding() const { return compounding_; } Frequency compoundingFrequency() const { return frequency_; } Date maxDate() const; void update(); private: DiscountFactor discountImpl(Time) const; void updateRate(); Handle forward_; Compounding compounding_; Frequency frequency_; InterestRate rate_; }; // inline definitions inline FlatForward::FlatForward(const Date& referenceDate, const Handle& forward, const DayCounter& dayCounter, Compounding compounding, Frequency frequency) : YieldTermStructure(referenceDate, Calendar(), dayCounter), forward_(forward), compounding_(compounding), frequency_(frequency) { registerWith(forward_); updateRate(); } inline FlatForward::FlatForward(const Date& referenceDate, Rate forward, const DayCounter& dayCounter, Compounding compounding, Frequency frequency) : YieldTermStructure(referenceDate, Calendar(), dayCounter), forward_(boost::shared_ptr(new SimpleQuote(forward))), compounding_(compounding), frequency_(frequency) { updateRate(); } inline FlatForward::FlatForward(Natural settlementDays, const Calendar& calendar, const Handle& forward, const DayCounter& dayCounter, Compounding compounding, Frequency frequency) : YieldTermStructure(settlementDays, calendar, dayCounter), forward_(forward), compounding_(compounding), frequency_(frequency) { registerWith(forward_); updateRate(); } inline FlatForward::FlatForward(Natural settlementDays, const Calendar& calendar, Rate forward, const DayCounter& dayCounter, Compounding compounding, Frequency frequency) : YieldTermStructure(settlementDays, calendar, dayCounter), forward_(boost::shared_ptr(new SimpleQuote(forward))), compounding_(compounding), frequency_(frequency) { updateRate(); } inline Date FlatForward::maxDate() const { return Date::maxDate(); } inline void FlatForward::update() { updateRate(); YieldTermStructure::update(); } inline DiscountFactor FlatForward::discountImpl(Time t) const { return rate_.discountFactor(t); } inline void FlatForward::updateRate() { rate_ = InterestRate(forward_->value(), dayCounter(), compounding_, frequency_); } } #endif