#include <ql/experimental/processes/extouwithjumpsprocess.hpp>
Inheritance diagram for ExtOUWithJumpsProcess:Public Member Functions | |
| ExtOUWithJumpsProcess (const boost::shared_ptr< ExtendedOrnsteinUhlenbeckProcess > &process, Real Y0, Real beta, Real jumpIntensity, Real eta) | |
| Size | size () const |
| returns the number of dimensions of the stochastic process | |
| Size | factors () const |
| returns the number of independent factors of the process | |
| Disposable< Array > | initialValues () const |
| returns the initial values of the state variables | |
| Disposable< Array > | drift (Time t, const Array &x) const |
| returns the drift part of the equation, i.e., \( \mu(t, \mathrm{x}_t) \) | |
| Disposable< Matrix > | diffusion (Time t, const Array &x) const |
| returns the diffusion part of the equation, i.e. \( \sigma(t, \mathrm{x}_t) \) | |
| Disposable< Array > | evolve (Time t0, const Array &x0, Time dt, const Array &dw) const |
| boost::shared_ptr< ExtendedOrnsteinUhlenbeckProcess > | getExtendedOrnsteinUhlenbeckProcess () const |
| Real | beta () const |
| Real | eta () const |
| Real | jumpIntensity () const |
Public Member Functions inherited from StochasticProcess | |
| virtual Disposable< Array > | expectation (Time t0, const Array &x0, Time dt) const |
| virtual Disposable< Matrix > | stdDeviation (Time t0, const Array &x0, Time dt) const |
| virtual Disposable< Matrix > | covariance (Time t0, const Array &x0, Time dt) const |
| virtual Disposable< Array > | apply (const Array &x0, const Array &dx) const |
| virtual Time | time (const Date &) const |
| void | update () |
Public Member Functions inherited from Observer | |
| Observer (const Observer &) | |
| Observer & | operator= (const Observer &) |
| std::pair< iterator, bool > | registerWith (const boost::shared_ptr< Observable > &) |
| void | registerWithObservables (const boost::shared_ptr< Observer > &) |
| Size | unregisterWith (const boost::shared_ptr< Observable > &) |
| void | unregisterWithAll () |
Public Member Functions inherited from Observable | |
| Observable (const Observable &) | |
| Observable & | operator= (const Observable &) |
| void | notifyObservers () |
Additional Inherited Members | |
Public Types inherited from Observer | |
| typedef std::set< boost::shared_ptr< Observable > > | set_type |
| typedef set_type::iterator | iterator |
Protected Member Functions inherited from StochasticProcess | |
| StochasticProcess (const boost::shared_ptr< discretization > &) | |
Protected Attributes inherited from StochasticProcess | |
| boost::shared_ptr< discretization > | discretization_ |
This class describes a Ornstein Uhlenbeck model plus exp jump, an extension of the Lucia and Schwartz model
\[ \begin{array}{rcl} S &=& exp(X_t + Y_t) \\ dX_t &=& \alpha(\mu(t)-X_t)dt + \sigma dW_t \\ dY_t &=& -\beta Y_{t-}dt + J_tdN_t \\ \omega(J)&=& \eta_u e^{-\eta_u J} \end{array} \]
References: T. Kluge, 2008. Pricing Swing Options and other Electricity Derivatives, http://eprints.maths.ox.ac.uk/246/1/kluge.pdf
B. Hambly, S. Howison, T. Kluge, Modelling spikes and pricing swing options in electricity markets, http://people.maths.ox.ac.uk/hambly/PDF/Papers/elec.pdf
returns the asset value after a time interval \( \Delta t \) according to the given discretization. By default, it returns
\[ E(\mathrm{x}_0,t_0,\Delta t) + S(\mathrm{x}_0,t_0,\Delta t) \cdot \Delta \mathrm{w} \]
where \( E \) is the expectation and \( S \) the standard deviation.
Reimplemented from StochasticProcess.