001/* ----------------------------------------------------------------------------
002 * This file was automatically generated by SWIG (https://www.swig.org).
003 * Version 4.1.1
004 *
005 * Do not make changes to this file unless you know what you are doing - modify
006 * the SWIG interface file instead.
007 * ----------------------------------------------------------------------------- */
008
009package org.quantlib;
010
011public class BlackVolTermStructureHandle implements org.quantlib.helpers.QuantLibJNIHelpers.AutoCloseable {
012  private transient long swigCPtr;
013  protected transient boolean swigCMemOwn;
014
015  protected BlackVolTermStructureHandle(long cPtr, boolean cMemoryOwn) {
016    swigCMemOwn = cMemoryOwn;
017    swigCPtr = cPtr;
018  }
019
020  protected static long getCPtr(BlackVolTermStructureHandle obj) {
021    return (obj == null) ? 0 : obj.swigCPtr;
022  }
023
024  protected static long swigRelease(BlackVolTermStructureHandle obj) {
025    long ptr = 0;
026    if (obj != null) {
027      if (!obj.swigCMemOwn)
028        throw new RuntimeException("Cannot release ownership as memory is not owned");
029      ptr = obj.swigCPtr;
030      obj.swigCMemOwn = false;
031      obj.delete();
032    }
033    return ptr;
034  }
035
036  @SuppressWarnings("deprecation")
037  protected void finalize() {
038    delete();
039  }
040
041  public synchronized void delete() {
042    if (swigCPtr != 0) {
043      if (swigCMemOwn) {
044        swigCMemOwn = false;
045        QuantLibJNI.delete_BlackVolTermStructureHandle(swigCPtr);
046      }
047      swigCPtr = 0;
048    }
049  }
050
051  public BlackVolTermStructureHandle(BlackVolTermStructure arg0) {
052    this(QuantLibJNI.new_BlackVolTermStructureHandle__SWIG_0(BlackVolTermStructure.getCPtr(arg0), arg0), true);
053  }
054
055  public BlackVolTermStructureHandle() {
056    this(QuantLibJNI.new_BlackVolTermStructureHandle__SWIG_1(), true);
057  }
058
059  public BlackVolTermStructure __deref__() {
060    long cPtr = QuantLibJNI.BlackVolTermStructureHandle___deref__(swigCPtr, this);
061    return (cPtr == 0) ? null : new BlackVolTermStructure(cPtr, true);
062  }
063
064  public BlackVolTermStructure currentLink() {
065    long cPtr = QuantLibJNI.BlackVolTermStructureHandle_currentLink(swigCPtr, this);
066    return (cPtr == 0) ? null : new BlackVolTermStructure(cPtr, true);
067  }
068
069  public boolean empty() {
070    return QuantLibJNI.BlackVolTermStructureHandle_empty(swigCPtr, this);
071  }
072
073  public Observable asObservable() {
074    long cPtr = QuantLibJNI.BlackVolTermStructureHandle_asObservable(swigCPtr, this);
075    return (cPtr == 0) ? null : new Observable(cPtr, true);
076  }
077
078  public double blackVol(Date arg0, double strike, boolean extrapolate) {
079    return QuantLibJNI.BlackVolTermStructureHandle_blackVol__SWIG_0(swigCPtr, this, Date.getCPtr(arg0), arg0, strike, extrapolate);
080  }
081
082  public double blackVol(Date arg0, double strike) {
083    return QuantLibJNI.BlackVolTermStructureHandle_blackVol__SWIG_1(swigCPtr, this, Date.getCPtr(arg0), arg0, strike);
084  }
085
086  public double blackVol(double arg0, double strike, boolean extrapolate) {
087    return QuantLibJNI.BlackVolTermStructureHandle_blackVol__SWIG_2(swigCPtr, this, arg0, strike, extrapolate);
088  }
089
090  public double blackVol(double arg0, double strike) {
091    return QuantLibJNI.BlackVolTermStructureHandle_blackVol__SWIG_3(swigCPtr, this, arg0, strike);
092  }
093
094  public double blackVariance(Date arg0, double strike, boolean extrapolate) {
095    return QuantLibJNI.BlackVolTermStructureHandle_blackVariance__SWIG_0(swigCPtr, this, Date.getCPtr(arg0), arg0, strike, extrapolate);
096  }
097
098  public double blackVariance(Date arg0, double strike) {
099    return QuantLibJNI.BlackVolTermStructureHandle_blackVariance__SWIG_1(swigCPtr, this, Date.getCPtr(arg0), arg0, strike);
100  }
101
102  public double blackVariance(double arg0, double strike, boolean extrapolate) {
103    return QuantLibJNI.BlackVolTermStructureHandle_blackVariance__SWIG_2(swigCPtr, this, arg0, strike, extrapolate);
104  }
105
106  public double blackVariance(double arg0, double strike) {
107    return QuantLibJNI.BlackVolTermStructureHandle_blackVariance__SWIG_3(swigCPtr, this, arg0, strike);
108  }
109
110  public double blackForwardVol(Date arg0, Date arg1, double strike, boolean extrapolate) {
111    return QuantLibJNI.BlackVolTermStructureHandle_blackForwardVol__SWIG_0(swigCPtr, this, Date.getCPtr(arg0), arg0, Date.getCPtr(arg1), arg1, strike, extrapolate);
112  }
113
114  public double blackForwardVol(Date arg0, Date arg1, double strike) {
115    return QuantLibJNI.BlackVolTermStructureHandle_blackForwardVol__SWIG_1(swigCPtr, this, Date.getCPtr(arg0), arg0, Date.getCPtr(arg1), arg1, strike);
116  }
117
118  public double blackForwardVol(double arg0, double arg1, double strike, boolean extrapolate) {
119    return QuantLibJNI.BlackVolTermStructureHandle_blackForwardVol__SWIG_2(swigCPtr, this, arg0, arg1, strike, extrapolate);
120  }
121
122  public double blackForwardVol(double arg0, double arg1, double strike) {
123    return QuantLibJNI.BlackVolTermStructureHandle_blackForwardVol__SWIG_3(swigCPtr, this, arg0, arg1, strike);
124  }
125
126  public double blackForwardVariance(Date arg0, Date arg1, double strike, boolean extrapolate) {
127    return QuantLibJNI.BlackVolTermStructureHandle_blackForwardVariance__SWIG_0(swigCPtr, this, Date.getCPtr(arg0), arg0, Date.getCPtr(arg1), arg1, strike, extrapolate);
128  }
129
130  public double blackForwardVariance(Date arg0, Date arg1, double strike) {
131    return QuantLibJNI.BlackVolTermStructureHandle_blackForwardVariance__SWIG_1(swigCPtr, this, Date.getCPtr(arg0), arg0, Date.getCPtr(arg1), arg1, strike);
132  }
133
134  public double blackForwardVariance(double arg0, double arg1, double strike, boolean extrapolate) {
135    return QuantLibJNI.BlackVolTermStructureHandle_blackForwardVariance__SWIG_2(swigCPtr, this, arg0, arg1, strike, extrapolate);
136  }
137
138  public double blackForwardVariance(double arg0, double arg1, double strike) {
139    return QuantLibJNI.BlackVolTermStructureHandle_blackForwardVariance__SWIG_3(swigCPtr, this, arg0, arg1, strike);
140  }
141
142  public double minStrike() {
143    return QuantLibJNI.BlackVolTermStructureHandle_minStrike(swigCPtr, this);
144  }
145
146  public double maxStrike() {
147    return QuantLibJNI.BlackVolTermStructureHandle_maxStrike(swigCPtr, this);
148  }
149
150  public DayCounter dayCounter() {
151    return new DayCounter(QuantLibJNI.BlackVolTermStructureHandle_dayCounter(swigCPtr, this), true);
152  }
153
154  public double timeFromReference(Date date) {
155    return QuantLibJNI.BlackVolTermStructureHandle_timeFromReference(swigCPtr, this, Date.getCPtr(date), date);
156  }
157
158  public Calendar calendar() {
159    return new Calendar(QuantLibJNI.BlackVolTermStructureHandle_calendar(swigCPtr, this), true);
160  }
161
162  public Date referenceDate() {
163    return new Date(QuantLibJNI.BlackVolTermStructureHandle_referenceDate(swigCPtr, this), true);
164  }
165
166  public Date maxDate() {
167    return new Date(QuantLibJNI.BlackVolTermStructureHandle_maxDate(swigCPtr, this), true);
168  }
169
170  public double maxTime() {
171    return QuantLibJNI.BlackVolTermStructureHandle_maxTime(swigCPtr, this);
172  }
173
174  public void enableExtrapolation() {
175    QuantLibJNI.BlackVolTermStructureHandle_enableExtrapolation(swigCPtr, this);
176  }
177
178  public void disableExtrapolation() {
179    QuantLibJNI.BlackVolTermStructureHandle_disableExtrapolation(swigCPtr, this);
180  }
181
182  public boolean allowsExtrapolation() {
183    return QuantLibJNI.BlackVolTermStructureHandle_allowsExtrapolation(swigCPtr, this);
184  }
185
186}