Synthetic Collateralized Debt Obligation. More...
#include <qle/instruments/syntheticcdo.hpp>
Classes | |
class | arguments |
class | engine |
CDO base engine. More... | |
class | results |
Public Member Functions | |
SyntheticCDO (const QuantLib::ext::shared_ptr< QuantExt::Basket > &basket, Protection::Side side, const Schedule &schedule, Rate upfrontRate, Rate runningRate, const DayCounter &dayCounter, BusinessDayConvention paymentConvention, bool settlesAccrual=true, const QuantLib::CreditDefaultSwap::ProtectionPaymentTime protectionPaymentTime=QuantLib::CreditDefaultSwap::ProtectionPaymentTime::atDefault, Date protectionStart=Date(), Date upfrontDate=Date(), boost::optional< Real > notional=boost::none, Real recoveryRate=Null< Real >(), const DayCounter &lastPeriodDayCounter=DayCounter()) | |
const QuantLib::ext::shared_ptr< QuantExt::Basket > & | basket () const |
bool | isExpired () const override |
Rate | fairPremium () const |
Rate | fairUpfrontPremium () const |
Rate | premiumValue () const |
Rate | protectionValue () const |
Real | premiumLegNPV () const |
Real | protectionLegNPV () const |
Real | recoveryRate () const |
Returns the recovery rate for fixed recovery CDO, otherwise returns Null<Real>() More... | |
Real | remainingNotional () const |
Real | leverageFactor () const |
const Date & | maturity () const |
Last protection date. More... | |
Real | implicitCorrelation (const std::vector< Real > &recoveries, const Handle< YieldTermStructure > &discountCurve, Real targetNPV=0., Real accuracy=1.0e-3) const |
std::vector< Real > | expectedTrancheLoss () const |
Size | error () const |
void | setupArguments (PricingEngine::arguments *) const override |
void | fetchResults (const PricingEngine::results *) const override |
Private Member Functions | |
void | setupExpired () const override |
Private Attributes | |
QuantLib::ext::shared_ptr< QuantExt::Basket > | basket_ |
Protection::Side | side_ |
Leg | normalizedLeg_ |
Rate | upfrontRate_ |
Rate | runningRate_ |
const Real | leverageFactor_ |
DayCounter | dayCounter_ |
BusinessDayConvention | paymentConvention_ |
bool | settlesAccrual_ |
QuantLib::CreditDefaultSwap::ProtectionPaymentTime | protectionPaymentTime_ |
Date | protectionStart_ |
Date | upfrontDate_ |
QuantLib::ext::shared_ptr< CashFlow > | upfrontPayment_ |
QuantLib::ext::shared_ptr< CashFlow > | accrualRebate_ |
QuantLib::ext::shared_ptr< CashFlow > | accrualRebateCurrent_ |
Real | recoveryRate_ |
Real | premiumValue_ |
Real | protectionValue_ |
Real | upfrontPremiumValue_ |
Real | remainingNotional_ |
Size | error_ |
std::vector< Real > | expectedTrancheLoss_ |
Synthetic Collateralized Debt Obligation.
The instrument prices a mezzanine CDO tranche with loss given default between attachment point \( D_1\) and detachment point \( D_2 > D_1 \).
For purchased protection, the instrument value is given by the difference of the protection value \( V_1 \) and premium value \( V_2 \),
\[ V = V_1 - V_2. \]
The protection leg is priced as follows:
\[ Pay(L) = min (D_1, LGD) - min (D_2, LGD) = \left\{ \begin{array}{lcl} \displaystyle 0 &;& LGD < D_1 \\ \displaystyle LGD - D_1 &;& D_1 \leq LGD \leq D_2 \\ \displaystyle D_2 - D_1 &;& LGD > D_2 \end{array} \right. \]
\[ V_1 \:=\: \sum_{i=1}^N (E_i - E_{i-1}) \cdot d_i \]
where \( d_i\) is the discount factor at time/date \( t_i \)The premium is paid on the protected notional amount, initially \( D_2 - D_1. \) This notional amount is reduced by the expected protection payments \( E_i \) at times \( t_i, \) so that the premium value is calculated as
\[ V_2 =m \, \cdot \sum_{i=1}^N \,(D_2 - D_1 - E_i) \cdot \Delta_{i-1,i}\,d_i \]
where \( m \) is the premium rate, \( \Delta_{i-1, i}\) is the day count fraction between date/time \( t_{i-1}\) and \( t_i.\)
The construction of the portfolio loss distribution \( E_i \) is based on the probability bucketing algorithm described in
John Hull and Alan White, "Valuation of a CDO and nth to default CDS without Monte Carlo simulation", Journal of Derivatives 12, 2, 2004
The pricing algorithm allows for varying notional amounts and default termstructures of the underlyings.
Definition at line 108 of file syntheticcdo.hpp.
SyntheticCDO | ( | const QuantLib::ext::shared_ptr< QuantExt::Basket > & | basket, |
Protection::Side | side, | ||
const Schedule & | schedule, | ||
Rate | upfrontRate, | ||
Rate | runningRate, | ||
const DayCounter & | dayCounter, | ||
BusinessDayConvention | paymentConvention, | ||
bool | settlesAccrual = true , |
||
const QuantLib::CreditDefaultSwap::ProtectionPaymentTime | protectionPaymentTime = QuantLib::CreditDefaultSwap::ProtectionPaymentTime::atDefault , |
||
Date | protectionStart = Date() , |
||
Date | upfrontDate = Date() , |
||
boost::optional< Real > | notional = boost::none , |
||
Real | recoveryRate = Null<Real>() , |
||
const DayCounter & | lastPeriodDayCounter = DayCounter() |
||
) |
If the notional exceeds the basket inception tranche notional, the cdo is leveraged by that factor.
Definition at line 40 of file syntheticcdo.cpp.
const QuantLib::ext::shared_ptr< QuantExt::Basket > & basket | ( | ) | const |
|
override |
Definition at line 162 of file syntheticcdo.cpp.
Rate fairPremium | ( | ) | const |
Definition at line 142 of file syntheticcdo.cpp.
Rate fairUpfrontPremium | ( | ) | const |
Definition at line 147 of file syntheticcdo.cpp.
Rate premiumValue | ( | ) | const |
Rate protectionValue | ( | ) | const |
Real premiumLegNPV | ( | ) | const |
Definition at line 128 of file syntheticcdo.cpp.
Real protectionLegNPV | ( | ) | const |
Definition at line 135 of file syntheticcdo.cpp.
Real recoveryRate | ( | ) | const |
Returns the recovery rate for fixed recovery CDO, otherwise returns Null<Real>()
Definition at line 144 of file syntheticcdo.hpp.
Real remainingNotional | ( | ) | const |
Total outstanding tranche notional, not wiped out
Definition at line 168 of file syntheticcdo.cpp.
Real leverageFactor | ( | ) | const |
The number of times the contract contains the portfolio tranched notional.
Definition at line 152 of file syntheticcdo.hpp.
const Date & maturity | ( | ) | const |
Last protection date.
Definition at line 154 of file syntheticcdo.hpp.
Real implicitCorrelation | ( | const std::vector< Real > & | recoveries, |
const Handle< YieldTermStructure > & | discountCurve, | ||
Real | targetNPV = 0. , |
||
Real | accuracy = 1.0e-3 |
||
) | const |
The Gaussian Copula LHP implied correlation that makes the contract zero value. This is for a flat correlation along time and portfolio loss level.
Definition at line 259 of file syntheticcdo.cpp.
vector< Real > expectedTrancheLoss | ( | ) | const |
Expected tranche loss for all payment dates
Definition at line 152 of file syntheticcdo.cpp.
Size error | ( | ) | const |
Definition at line 157 of file syntheticcdo.cpp.
|
override |
Definition at line 173 of file syntheticcdo.cpp.
|
override |
Definition at line 195 of file syntheticcdo.cpp.
|
overrideprivate |
Definition at line 209 of file syntheticcdo.cpp.
|
private |
Definition at line 177 of file syntheticcdo.hpp.
|
private |
Definition at line 178 of file syntheticcdo.hpp.
|
private |
Definition at line 179 of file syntheticcdo.hpp.
|
private |
Definition at line 181 of file syntheticcdo.hpp.
|
private |
Definition at line 182 of file syntheticcdo.hpp.
|
private |
Definition at line 183 of file syntheticcdo.hpp.
|
private |
Definition at line 184 of file syntheticcdo.hpp.
|
private |
Definition at line 185 of file syntheticcdo.hpp.
|
private |
Definition at line 186 of file syntheticcdo.hpp.
|
private |
Definition at line 187 of file syntheticcdo.hpp.
|
private |
Definition at line 188 of file syntheticcdo.hpp.
|
private |
Definition at line 189 of file syntheticcdo.hpp.
|
private |
Definition at line 190 of file syntheticcdo.hpp.
|
private |
Definition at line 190 of file syntheticcdo.hpp.
|
private |
Definition at line 190 of file syntheticcdo.hpp.
|
private |
Definition at line 191 of file syntheticcdo.hpp.
|
mutableprivate |
Definition at line 193 of file syntheticcdo.hpp.
|
mutableprivate |
Definition at line 194 of file syntheticcdo.hpp.
|
mutableprivate |
Definition at line 195 of file syntheticcdo.hpp.
|
mutableprivate |
Definition at line 196 of file syntheticcdo.hpp.
|
mutableprivate |
Definition at line 197 of file syntheticcdo.hpp.
|
mutableprivate |
Definition at line 198 of file syntheticcdo.hpp.