Logo
Fully annotated reference manual - version 1.8.12
Loading...
Searching...
No Matches
eqbspiecewiseconstantparametrization.cpp
Go to the documentation of this file.
1/*
2 Copyright (C) 2016 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
20
21namespace QuantExt {
22
24 const Currency& currency, const std::string& eqName, const Handle<Quote>& eqSpotToday,
25 const Handle<Quote>& fxSpotToday, const Array& times, const Array& sigma,
26 const Handle<YieldTermStructure>& eqIrCurveToday, const Handle<YieldTermStructure>& eqDivYieldCurveToday)
27 : EqBsParametrization(currency, eqName, eqSpotToday, fxSpotToday, eqIrCurveToday, eqDivYieldCurveToday),
30}
31
33 const Currency& currency, const std::string& eqName, const Handle<Quote>& eqSpotToday,
34 const Handle<Quote>& fxSpotToday, const std::vector<Date>& dates, const Array& sigma,
35 const Handle<YieldTermStructure>& domesticTermStructure, const Handle<YieldTermStructure>& eqIrCurveToday,
36 const Handle<YieldTermStructure>& eqDivYieldCurveToday)
37 : EqBsParametrization(currency, eqName, eqSpotToday, fxSpotToday, eqIrCurveToday, eqDivYieldCurveToday),
38 PiecewiseConstantHelper1(dates, domesticTermStructure) {
40}
41
43 QL_REQUIRE(PiecewiseConstantHelper1::t().size() + 1 == sigma.size(),
44 "alpha size (" << sigma.size() << ") inconsistent to times size ("
45 << PiecewiseConstantHelper1::t().size() << ")");
46
47 // store raw parameter values
48 for (Size i = 0; i < PiecewiseConstantHelper1::y_->size(); ++i) {
49 PiecewiseConstantHelper1::y_->setParam(i, inverse(0, sigma[i]));
50 }
51 update();
52}
53
54} // namespace QuantExt
EQ Black Scholes parametrizations.
Real inverse(const Size i, const Real y) const override
EqBsPiecewiseConstantParametrization(const Currency &currency, const std::string &eqName, const Handle< Quote > &eqSpotToday, const Handle< Quote > &fxSpotToday, const Array &times, const Array &sigma, const Handle< YieldTermStructure > &eqIrCurveToday, const Handle< YieldTermStructure > &eqDivYieldCurveToday)
const QuantLib::ext::shared_ptr< PseudoParameter > y_
piecewise constant model parametrization