QuantLib: a free/open-source library for quantitative finance
Reference manual - version 1.40
Loading...
Searching...
No Matches
MCEuropeanHestonEngine< RNG, S, P > Class Template Reference

Monte Carlo Heston-model engine for European options. More...

#include <ql/pricingengines/vanilla/mceuropeanhestonengine.hpp>

Inheritance diagram for MCEuropeanHestonEngine< RNG, S, P >:

Public Types

typedef MCVanillaEngine< MultiVariate, RNG, S >::path_pricer_type path_pricer_type
Public Types inherited from McSimulation< MultiVariate, PseudoRandom, Statistics >
typedef MonteCarloModel< MultiVariate, PseudoRandom, Statistics >::path_generator_type path_generator_type
typedef MonteCarloModel< MultiVariate, PseudoRandom, Statistics >::path_pricer_type path_pricer_type
typedef MonteCarloModel< MultiVariate, PseudoRandom, Statistics >::stats_type stats_type
typedef MonteCarloModel< MultiVariate, PseudoRandom, Statistics >::result_type result_type

Public Member Functions

 MCEuropeanHestonEngine (const ext::shared_ptr< P > &, Size timeSteps, Size timeStepsPerYear, bool antitheticVariate, Size requiredSamples, Real requiredTolerance, Size maxSamples, BigNatural seed)
Public Member Functions inherited from MCVanillaEngine< MultiVariate, PseudoRandom, Statistics >
void calculate () const override
Public Member Functions inherited from McSimulation< MultiVariate, PseudoRandom, Statistics >
result_type value (Real tolerance, Size maxSamples=QL_MAX_INTEGER, Size minSamples=1023) const
 add samples until the required absolute tolerance is reached
result_type valueWithSamples (Size samples) const
 simulate a fixed number of samples
result_type errorEstimate () const
 error estimated using the samples simulated so far
const stats_typesampleAccumulator () const
 access to the sample accumulator for richer statistics
void calculate (Real requiredTolerance, Size requiredSamples, Size maxSamples) const
 basic calculate method provided to inherited pricing engines

Protected Member Functions

ext::shared_ptr< path_pricer_typepathPricer () const override
Protected Member Functions inherited from MCVanillaEngine< MultiVariate, PseudoRandom, Statistics >
 MCVanillaEngine (ext::shared_ptr< StochasticProcess >, Size timeSteps, Size timeStepsPerYear, bool brownianBridge, bool antitheticVariate, bool controlVariate, Size requiredSamples, Real requiredTolerance, Size maxSamples, BigNatural seed)
TimeGrid timeGrid () const override
ext::shared_ptr< path_generator_typepathGenerator () const override
result_type controlVariateValue () const override
Protected Member Functions inherited from McSimulation< MultiVariate, PseudoRandom, Statistics >
 McSimulation (bool antitheticVariate, bool controlVariate)
virtual ext::shared_ptr< path_pricer_typecontrolPathPricer () const
virtual ext::shared_ptr< path_generator_typecontrolPathGenerator () const
virtual ext::shared_ptr< PricingEnginecontrolPricingEngine () const

Additional Inherited Members

Protected Types inherited from MCVanillaEngine< MultiVariate, PseudoRandom, Statistics >
typedef McSimulation< MultiVariate, PseudoRandom, Statistics >::path_generator_type path_generator_type
typedef McSimulation< MultiVariate, PseudoRandom, Statistics >::path_pricer_type path_pricer_type
typedef McSimulation< MultiVariate, PseudoRandom, Statistics >::stats_type stats_type
typedef McSimulation< MultiVariate, PseudoRandom, Statistics >::result_type result_type
Static Protected Member Functions inherited from McSimulation< MultiVariate, PseudoRandom, Statistics >
static Real maxError (const Sequence &sequence)
Protected Attributes inherited from MCVanillaEngine< MultiVariate, PseudoRandom, Statistics >
ext::shared_ptr< StochasticProcessprocess_
Size timeSteps_
Size timeStepsPerYear_
Size requiredSamples_
Size maxSamples_
Real requiredTolerance_
bool brownianBridge_
BigNatural seed_
Protected Attributes inherited from McSimulation< MultiVariate, PseudoRandom, Statistics >
ext::shared_ptr< MonteCarloModel< MultiVariate, PseudoRandom, Statistics > > mcModel_
bool antitheticVariate_
bool controlVariate_

Detailed Description

template<class RNG = PseudoRandom, class S = Statistics, class P = HestonProcess>
class QuantLib::MCEuropeanHestonEngine< RNG, S, P >

Monte Carlo Heston-model engine for European options.

Tests
the correctness of the returned value is tested by reproducing results available in web/literature

Member Function Documentation

◆ pathPricer()

template<class RNG, class S, class P>
ext::shared_ptr< typename MCEuropeanHestonEngine< RNG, S, P >::path_pricer_type > pathPricer ( ) const
overrideprotectedvirtual