File: softbarrieroption.hpp

package info (click to toggle)
quantlib 1.41-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 41,480 kB
  • sloc: cpp: 400,885; makefile: 6,547; python: 214; sh: 150; lisp: 86
file content (84 lines) | stat: -rw-r--r-- 2,895 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */

/*
 Copyright (C) 2025 William Day

 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
 <quantlib-dev@lists.sf.net>. The license is also available online at
 <https://www.quantlib.org/license.shtml>.

 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.
*/

/*! \file softbarrieroption.hpp
    \brief Soft Barrier european option on a single asset
*/

#ifndef quantlib_soft_barrier_option_hpp
#define quantlib_soft_barrier_option_hpp

#include <ql/instruments/oneassetoption.hpp>
#include <ql/instruments/payoffs.hpp>
#include <ql/instruments/barriertype.hpp>

namespace QuantLib {

    class GeneralizedBlackScholesProcess;

    //! Soft barrier option on a single asset
    /*! A soft barrier option gets knocked in/out proportionally over the barrier range instead of being knocked in/out in full at a hard barrier.
        It is currently only available with European payoff stylet

        \ingroup instruments
    */
    class SoftBarrierOption : public OneAssetOption {
      public:
        class arguments;
        class engine;

        SoftBarrierOption(Barrier::Type barrierType,
                          Real barrier_lo,
                          Real barrier_hi,
                          const ext::shared_ptr<StrikedTypePayoff>& payoff,
                          const ext::shared_ptr<Exercise>& exercise);

        void setupArguments(PricingEngine::arguments*) const override;

        Volatility impliedVolatility(
             Real price,
             const ext::shared_ptr<GeneralizedBlackScholesProcess>& process,
             Real accuracy = 1.0e-4,
             Size maxEvaluations = 100,
             Volatility minVol = 1e-6, // 0 vol values can make the soft barrier formula produce NaN results
             Volatility maxVol = 4.0) const;

      private:
        Barrier::Type barrierType_;
        Real barrier_lo_;
        Real barrier_hi_;
    };

    // Arguments for soft barrier option calc
    class SoftBarrierOption::arguments : public OneAssetOption::arguments {
      public:
        arguments();
        Barrier::Type barrierType;
        Real barrier_lo;
        Real barrier_hi;
    };

    // Base class for soft barrier option engines
    class SoftBarrierOption::engine
        : public GenericEngine<SoftBarrierOption::arguments,
                               SoftBarrierOption::results> {};

}

#endif