Logo
Fully annotated reference manual - version 1.8.12
Loading...
Searching...
No Matches
implieddefaulttermstructure.hpp
Go to the documentation of this file.
1/*
2 Copyright (C) 2019 Quaternion Risk Management Ltd
3 All rights reserved.
4
5 This file is part of ORE, a free-software/open-source library
6 for transparent pricing and risk analysis - http://opensourcerisk.org
7
8 ORE is free software: you can redistribute it and/or modify it
9 under the terms of the Modified BSD License. You should have received a
10 copy of the license along with this program.
11 The license is also available online at <http://opensourcerisk.org>
12
13 This program is distributed on the basis that it will form a useful
14 contribution to risk analytics and model standardisation, but WITHOUT
15 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
16 FITNESS FOR A PARTICULAR PURPOSE. See the license for more details.
17*/
18
19/*! \file qle/termstructures/implieddefaulttermstructure.hpp
20 \brief implied default term structure
21 \ingroup models
22*/
23
24#pragma once
25
26#include <ql/termstructures/credit/survivalprobabilitystructure.hpp>
27
28namespace QuantExt {
29using namespace QuantLib;
30
32public:
33 ImpliedDefaultTermStructure(const Handle<DefaultProbabilityTermStructure>& t, const Date& referenceDate)
34 : SurvivalProbabilityStructure(referenceDate), t_(t) {
35 timeOffset_ = t->timeFromReference(referenceDate);
36 registerWith(t_);
37 enableExtrapolation(t_->allowsExtrapolation());
38 }
39 DayCounter dayCounter() const { return t_->dayCounter(); }
40 Calendar calendar() const { return t_->calendar(); }
41 Natural settlementDays() const { return t_->settlementDays(); }
42 Date maxDate() const { return t_->maxDate(); }
43 const std::vector<Date>& jumpDates() const { return t_->jumpDates(); }
44 const std::vector<Time>& jumpTimes() const { return t_->jumpTimes(); }
45
46private:
47 Probability survivalProbabilityImpl(Time t) const {
48 return t_->survivalProbability(t + timeOffset_) / t_->survivalProbability(t);
49 }
50 Handle<DefaultProbabilityTermStructure> t_;
52};
53} // namespace QuantExt
Handle< DefaultProbabilityTermStructure > t_
const std::vector< Time > & jumpTimes() const
const std::vector< Date > & jumpDates() const
ImpliedDefaultTermStructure(const Handle< DefaultProbabilityTermStructure > &t, const Date &referenceDate)