/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* Copyright (C) 2003 Ferdinando Ametrano Copyright (C) 2001, 2002, 2003 Sadruddin Rejeb Copyright (C) 2004, 2005 StatPro Italia srl 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 . The license is also available online at . 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. */ #include namespace QuantLib { Merton76Process::Merton76Process( const Handle& stateVariable, const Handle& dividendTS, const Handle& riskFreeTS, const Handle& blackVolTS, const Handle& jumpInt, const Handle& logJMean, const Handle& logJVol, const boost::shared_ptr& disc) : blackProcess_(new BlackScholesMertonProcess(stateVariable, dividendTS, riskFreeTS, blackVolTS, disc)), jumpIntensity_(jumpInt), logMeanJump_(logJMean), logJumpVolatility_(logJVol) { registerWith(blackProcess_); registerWith(jumpIntensity_); registerWith(logMeanJump_); registerWith(logJumpVolatility_); } Real Merton76Process::x0() const { return blackProcess_->x0(); } Time Merton76Process::time(const Date& d) const { return blackProcess_->time(d); } const Handle& Merton76Process::stateVariable() const { return blackProcess_->stateVariable(); } const Handle& Merton76Process::dividendYield() const { return blackProcess_->dividendYield(); } const Handle& Merton76Process::riskFreeRate() const { return blackProcess_->riskFreeRate(); } const Handle& Merton76Process::blackVolatility() const { return blackProcess_->blackVolatility(); } const Handle& Merton76Process::jumpIntensity() const { return jumpIntensity_; } const Handle& Merton76Process::logMeanJump() const { return logMeanJump_; } const Handle& Merton76Process::logJumpVolatility() const { return logJumpVolatility_; } }