QuantLib: a free/open-source library for quantitative finance
fully annotated source code - version 1.34
|
Multiplicative seasonality in the price index (CPI/RPI/HICP/etc). More...
#include <seasonality.hpp>
Public Member Functions | |
MultiplicativePriceSeasonality ()=default | |
MultiplicativePriceSeasonality (const Date &seasonalityBaseDate, Frequency frequency, const std::vector< Rate > &seasonalityFactors) | |
virtual void | set (const Date &seasonalityBaseDate, Frequency frequency, const std::vector< Rate > &seasonalityFactors) |
virtual Date | seasonalityBaseDate () const |
inspectors More... | |
virtual Frequency | frequency () const |
virtual std::vector< Rate > | seasonalityFactors () const |
virtual Rate | seasonalityFactor (const Date &d) const |
The factor returned is NOT normalized relative to ANYTHING. More... | |
Public Member Functions inherited from Seasonality | |
virtual | ~Seasonality ()=default |
Private Attributes | |
Date | seasonalityBaseDate_ |
Frequency | frequency_ |
std::vector< Rate > | seasonalityFactors_ |
Seasonality interface | |
Rate | correctZeroRate (const Date &d, Rate r, const InflationTermStructure &iTS) const override |
Rate | correctYoYRate (const Date &d, Rate r, const InflationTermStructure &iTS) const override |
bool | isConsistent (const InflationTermStructure &iTS) const override |
~MultiplicativePriceSeasonality () override=default | |
virtual void | validate () const |
virtual Rate | seasonalityCorrection (Rate r, const Date &d, const DayCounter &dc, const Date &curveBaseDate, bool isZeroRate) const |
Multiplicative seasonality in the price index (CPI/RPI/HICP/etc).
Stationary multiplicative seasonality in CPI/RPI/HICP (i.e. in price) implies that zero inflation swap rates are affected, but that year-on-year inflation swap rates show no effect. Of course, if the seasonality in CPI/RPI/HICP is non-stationary then both swap rates will be affected.
Factors must be in multiples of the minimum required for one year, e.g. 12 for monthly, and these factors are reused for as long as is required, i.e. they wrap around. So, for example, if 24 factors are given this repeats every two years. True stationary seasonality can be obtained by giving the same number of factors as the frequency dictates e.g. 12 for monthly seasonality.
Seasonality is treated as piecewise constant, hence it works correctly with uninterpolated indices if the seasonality correction factor frequency is the same as the index frequency (or less).
Definition at line 119 of file seasonality.hpp.
|
default |
MultiplicativePriceSeasonality | ( | const Date & | seasonalityBaseDate, |
Frequency | frequency, | ||
const std::vector< Rate > & | seasonalityFactors | ||
) |
|
overridedefault |
|
virtual |
Definition at line 97 of file seasonality.cpp.
|
virtual |
inspectors
Definition at line 110 of file seasonality.cpp.
|
virtual |
|
virtual |
The factor returned is NOT normalized relative to ANYTHING.
Reimplemented in KerkhofSeasonality.
Definition at line 145 of file seasonality.cpp.
|
overridevirtual |
Implements Seasonality.
Definition at line 123 of file seasonality.cpp.
|
overridevirtual |
Implements Seasonality.
Definition at line 136 of file seasonality.cpp.
|
overridevirtual |
It is possible for multi-year seasonalities to be inconsistent with the inflation term structure they are given to. This method enables testing - but programmers are not required to implement it. E.g. for price seasonality the corrections at whole years after the inflation curve base date should be the same or else there can be an inconsistency with quoted instruments. Alternatively, the seasonality can be set before the inflation curve is bootstrapped.
Reimplemented from Seasonality.
Definition at line 64 of file seasonality.cpp.
|
protectedvirtual |
Definition at line 36 of file seasonality.cpp.
|
protectedvirtual |
Reimplemented in KerkhofSeasonality.
Definition at line 191 of file seasonality.cpp.
|
private |
Definition at line 122 of file seasonality.hpp.
|
private |
Definition at line 123 of file seasonality.hpp.
|
private |
Definition at line 124 of file seasonality.hpp.