Logo
Fully annotated reference manual - version 1.8.12
Loading...
Searching...
No Matches
amccalculator.hpp
Go to the documentation of this file.
1/*
2 Copyright (C) 2017 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 amccalculator.hpp
20 \brief interface for amc calculator
21*/
22
23#pragma once
24
27
28#include <ql/currency.hpp>
29#include <ql/math/array.hpp>
30#include <ql/methods/montecarlo/multipath.hpp>
31
32namespace QuantExt {
33
34/*! amc interface */
36public:
37 virtual ~AmcCalculator() {}
38
39 /*! currency of simulated npvs */
40 virtual QuantLib::Currency npvCurrency() = 0;
41
42 /*! - simulate paths on given times and return simulated npvs for all paths
43 - relevantPathIndex gives the relevant entries in the paths that should be simulated in the end
44 - relevantTimeIndex gives the corrosponding time indexes for a sticky closeOut run
45 - if stickyCloseOutRun is true, the simulation times should be taken relevantTimeIndexes
46 */
47 virtual std::vector<QuantExt::RandomVariable>
48 simulatePath(const std::vector<QuantLib::Real>& pathTimes,
49 std::vector<std::vector<QuantExt::RandomVariable>>& paths,
50 const std::vector<size_t>& relevantPathIndex,
51 const std::vector<size_t>& relevantTimeIndex) = 0;
52};
53
54} // namespace QuantExt
virtual std::vector< QuantExt::RandomVariable > simulatePath(const std::vector< QuantLib::Real > &pathTimes, std::vector< std::vector< QuantExt::RandomVariable > > &paths, const std::vector< size_t > &relevantPathIndex, const std::vector< size_t > &relevantTimeIndex)=0
virtual QuantLib::Currency npvCurrency()=0
crossasset model state process