/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* Copyright (C) 2007 Ferdinando Ametrano Copyright (C) 2007 Chiara Fornarola 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 floatingratebond.hpp \brief floating-rate bond */ #ifndef quantlib_floating_rate_bond_hpp #define quantlib_floating_rate_bond_hpp #include namespace QuantLib { class Schedule; class IborIndex; //! floating-rate bond (possibly capped and/or floored) /*! \ingroup instruments \test calculations are tested by checking results against cached values. */ class FloatingRateBond : public Bond { public: FloatingRateBond(Natural settlementDays, Real faceAmount, const Schedule& schedule, const boost::shared_ptr& index, const DayCounter& accrualDayCounter, BusinessDayConvention paymentConvention = Following, Natural fixingDays = Null(), const std::vector& gearings = std::vector(1, 1.0), const std::vector& spreads = std::vector(1, 0.0), const std::vector& caps = std::vector(), const std::vector& floors = std::vector(), bool inArrears = false, Real redemption = 100.0, const Date& issueDate = Date(), const Handle& discountCurve = Handle()); FloatingRateBond(Natural settlementDays, Real faceAmount, const Date& startDate, const Date& maturityDate, Frequency couponFrequency, const Calendar& calendar, const boost::shared_ptr& index, const DayCounter& accrualDayCounter, BusinessDayConvention accrualConvention = Following, BusinessDayConvention paymentConvention = Following, Natural fixingDays = Null(), const std::vector& gearings = std::vector(1, 1.0), const std::vector& spreads = std::vector(1, 0.0), const std::vector& caps = std::vector(), const std::vector& floors = std::vector(), bool inArrears = false, Real redemption = 100.0, const Date& issueDate = Date(), const Handle& discountCurve = Handle(), const Date& stubDate = Date(), bool fromEnd = true); }; } #endif