Logo
Fully annotated reference manual - version 1.8.12
Loading...
Searching...
No Matches
adjusteddefaultcurve.hpp
Go to the documentation of this file.
1/*
2 Copyright (C) 2021 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 adjusteddefaultcurve.hpp
20 \brief default curve with SP(t) = exp(-int_0^t m * h(s) ds), with a multiplier m and source curve defining h(s)
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 AdjustedDefaultCurve(const Handle<DefaultProbabilityTermStructure>& source, const Handle<Quote>& multiplier)
34 : SurvivalProbabilityStructure(source->dayCounter()), source_(source), multiplier_(multiplier) {
35 registerWith(source);
36 registerWith(multiplier);
37 enableExtrapolation(source->allowsExtrapolation());
38 }
39 Date maxDate() const override { return source_->maxDate(); }
40 const Date& referenceDate() const override { return source_->referenceDate(); }
41
42protected:
43 Real survivalProbabilityImpl(Time t) const override {
44 return std::pow(source_->survivalProbability(t), multiplier_->value());
45 }
46 void update() override { SurvivalProbabilityStructure::update(); }
47 const Handle<DefaultProbabilityTermStructure> source_;
48 const Handle<Quote> multiplier_;
49};
50
51} // namespace QuantExt
AdjustedDefaultCurve(const Handle< DefaultProbabilityTermStructure > &source, const Handle< Quote > &multiplier)
const Date & referenceDate() const override
const Handle< DefaultProbabilityTermStructure > source_
Real survivalProbabilityImpl(Time t) const override