1/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2
3/*
4Copyright (C) 2010 Adrian O' Neill
5
6This file is part of QuantLib, a free-software/open-source library
7for financial quantitative analysts and developers - http://quantlib.org/
8
9QuantLib is free software: you can redistribute it and/or modify it
10under the terms of the QuantLib license. You should have received a
11copy of the license along with this program; if not, please email
12<quantlib-dev@lists.sf.net>. The license is also available online at
13<http://quantlib.org/license.shtml>.
14
15This program is distributed in the hope that it will be useful, but WITHOUT
16ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
17FOR A PARTICULAR PURPOSE. See the license for more details.
18*/
19
20#include <ql/experimental/variancegamma/variancegammamodel.hpp>
21#include <ql/quotes/simplequote.hpp>
22
23namespace QuantLib {
24
25 VarianceGammaModel::VarianceGammaModel(
26 const ext::shared_ptr<VarianceGammaProcess> & process)
27 : CalibratedModel(3), process_(process) {
28 arguments_[0] = ConstantParameter(process->sigma(),
29 PositiveConstraint());
30 arguments_[1] = ConstantParameter(process->nu(),
31 PositiveConstraint());
32 arguments_[2] = ConstantParameter(process->theta(),
33 NoConstraint());
34
35 VarianceGammaModel::generateArguments();
36
37 registerWith(h: process_->riskFreeRate());
38 registerWith(h: process_->dividendYield());
39 registerWith(h: process_->s0());
40 }
41
42 void VarianceGammaModel::generateArguments() {
43 process_.reset(p: new VarianceGammaProcess(process_->s0(),
44 process_->dividendYield(),
45 process_->riskFreeRate(),
46 sigma(), nu(), theta()));
47 }
48
49}
50
51

source code of quantlib/ql/experimental/variancegamma/variancegammamodel.cpp