1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
|
/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
Copyright (C) 2006 Mark Joshi
This file is part of QuantLib, a free-software/open-source library
for financial quantitative analysts and developers - http://quantlib.org/
QuantLib is free software: you can redistribute it and/or modify it
under the terms of the QuantLib license. You should have received a
copy of the license along with this program; if not, please email
<quantlib-dev@lists.sf.net>. The license is also available online at
<http://quantlib.org/license.shtml>.
This program is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. See the license for more details.
*/
#ifndef quantlib_constrained_evolver_hpp
#define quantlib_constrained_evolver_hpp
#include <ql/models/marketmodels/evolver.hpp>
#include <valarray>
namespace QuantLib {
//! Constrained market-model evolver
/*! Abstract base class. Requires extra methods above that of
marketmodelevolver to let you fix rates via importance sampling.
The evolver does the actual gritty work of evolving the forward rates
from one time to the next.
This is intended to be used for the Fries-Joshi proxy simulation
approach to Greeks
*/
class ConstrainedEvolver : public MarketModelEvolver {
public:
virtual ~ConstrainedEvolver() {}
//! call once
virtual void setConstraintType(
const std::vector<Size>& startIndexOfSwapRate,
const std::vector<Size>& EndIndexOfSwapRate) = 0;
//! call before each path
virtual void setThisConstraint(
const std::vector<Rate>& rateConstraints,
const std::valarray<bool>& isConstraintActive) = 0;
};
}
#endif
|