rollback (3) - Linux Manuals

rollback: Discretized asset class used by numerical methods.

NAME

QuantLib::DiscretizedAsset - Discretized asset class used by numerical methods.

SYNOPSIS


#include <ql/discretizedasset.hpp>

Inherited by DiscretizedCallableFixedRateBond, DiscretizedCapFloor, DiscretizedConvertible, DiscretizedDiscountBond, DiscretizedOption, DiscretizedSwap, and DiscretizedVanillaOption.

Public Member Functions

inspectors


Time time () const

Time & time ()

const Array & values () const

Array & values ()

const boost::shared_ptr< Lattice > & method () const

High-level interface
Users of discretized assets should use these methods in order to initialize, evolve and take the present value of the assets. They call the corresponding methods in the Lattice interface, to which we refer for documentation.


void initialize (const boost::shared_ptr< Lattice > &, Time t)

void rollback (Time to)

void partialRollback (Time to)

Real presentValue ()

Low-level interface
These methods (that developers should override when deriving from DiscretizedAsset) are to be used by numerical methods and not directly by users, with the exception of adjustValues(), preAdjustValues() and postAdjustValues() that can be used together with partialRollback().


virtual void reset (Size size)=0

void preAdjustValues ()

void postAdjustValues ()

void adjustValues ()

virtual std::vector< Time > mandatoryTimes () const =0

Protected Member Functions


bool isOnTime (Time t) const

virtual void preAdjustValuesImpl ()

virtual void postAdjustValuesImpl ()

Protected Attributes


Time time_

Time latestPreAdjustment_

Time latestPostAdjustment_

Array values_

Detailed Description

Discretized asset class used by numerical methods.

Member Function Documentation

virtual void reset (Size size) [pure virtual]

This method should initialize the asset values to an Array of the given size and with values depending on the particular asset.

Implemented in DiscretizedDiscountBond, and DiscretizedOption.

void preAdjustValues ()

This method will be invoked after rollback and before any other asset (i.e., an option on this one) has any chance to look at the values. For instance, payments happening at times already spanned by the rollback will be added here.

This method is not virtual; derived classes must override the protected preAdjustValuesImpl() method instead.

void postAdjustValues ()

This method will be invoked after rollback and after any other asset had their chance to look at the values. For instance, payments happening at the present time (and therefore not included in an option to be exercised at this time) will be added here.

This method is not virtual; derived classes must override the protected postAdjustValuesImpl() method instead.

void adjustValues ()

This method performs both pre- and post-adjustment

virtual std::vector<Time> mandatoryTimes () const [pure virtual]

This method returns the times at which the numerical method should stop while rolling back the asset. Typical examples include payment times, exercise times and such.

Note:

The returned values are not guaranteed to be sorted.

Implemented in DiscretizedDiscountBond, and DiscretizedOption.

bool isOnTime (Time t) const [protected]

This method checks whether the asset was rolled at the given time.

virtual void preAdjustValuesImpl () [protected, virtual]

This method performs the actual pre-adjustment

virtual void postAdjustValuesImpl () [protected, virtual]

This method performs the actual post-adjustment

Reimplemented in DiscretizedOption.

Author

Generated automatically by Doxygen for QuantLib from the source code.