Coverage Report

Created: 2025-08-11 06:28

/src/quantlib/ql/instruments/twoassetcorrelationoption.hpp
Line
Count
Source (jump to first uncovered line)
1
/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2
3
/*
4
 Copyright (C) 2014 Master IMAFA - Polytech'Nice Sophia - Université de Nice Sophia Antipolis
5
6
 This file is part of QuantLib, a free-software/open-source library
7
 for financial quantitative analysts and developers - http://quantlib.org/
8
9
 QuantLib is free software: you can redistribute it and/or modify it
10
 under the terms of the QuantLib license.  You should have received a
11
 copy 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
15
 This program is distributed in the hope that it will be useful, but WITHOUT
16
 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
17
 FOR A PARTICULAR PURPOSE.  See the license for more details.
18
*/
19
20
/*! \file twoassetcorrelationoption.hpp
21
    \brief Two-asset correlation option
22
*/
23
24
#ifndef quantlib_two_asset_correlation_option_hpp
25
#define quantlib_two_asset_correlation_option_hpp
26
27
#include <ql/instruments/multiassetoption.hpp>
28
#include <ql/instruments/payoffs.hpp>
29
30
namespace QuantLib {
31
32
    //! Two-asset correlation %option
33
    /*! This option pays a payoff based on the value at exercise of
34
        the second asset and its corresponding strike, but only if the
35
        first instrument is also in the money with respect to its own
36
        strike; if not, the payoff is 0.
37
38
        \ingroup instruments
39
    */
40
    class TwoAssetCorrelationOption : public MultiAssetOption {
41
      public:
42
        class arguments;
43
        class engine;
44
        TwoAssetCorrelationOption(Option::Type type,
45
                                  Real strike1,
46
                                  Real strike2,
47
                                  const ext::shared_ptr<Exercise>&);
48
        void setupArguments(PricingEngine::arguments*) const override;
49
50
      protected:
51
        Real X2_;
52
    };
53
54
    //! %Arguments for two-asset correlation %option
55
    class TwoAssetCorrelationOption::arguments
56
        : public MultiAssetOption::arguments {
57
      public:
58
0
        arguments() : X2(Null<Real>()) {}
59
0
        void validate() const override {
60
0
            MultiAssetOption::arguments::validate();
61
0
            QL_REQUIRE(X2 != Null<Real>(), "no X2 given");
62
0
        }
63
        Real X2;
64
    };
65
66
    //! Base class for two-asset correlation %option engines
67
    class TwoAssetCorrelationOption::engine
68
        : public GenericEngine<TwoAssetCorrelationOption::arguments,
69
                               TwoAssetCorrelationOption::results> {};
70
71
}
72
73
74
#endif