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 BlackIborCouponPricer extends IborCouponPricer implements org.quantlib.helpers.QuantLibJNIHelpers.AutoCloseable {
012  private transient long swigCPtr;
013  private transient boolean swigCMemOwnDerived;
014
015  protected BlackIborCouponPricer(long cPtr, boolean cMemoryOwn) {
016    super(QuantLibJNI.BlackIborCouponPricer_SWIGSmartPtrUpcast(cPtr), true);
017    swigCMemOwnDerived = cMemoryOwn;
018    swigCPtr = cPtr;
019  }
020
021  protected static long getCPtr(BlackIborCouponPricer obj) {
022    return (obj == null) ? 0 : obj.swigCPtr;
023  }
024
025  protected void swigSetCMemOwn(boolean own) {
026    swigCMemOwnDerived = own;
027    super.swigSetCMemOwn(own);
028  }
029
030  @SuppressWarnings("deprecation")
031  protected void finalize() {
032    delete();
033  }
034
035  public synchronized void delete() {
036    if (swigCPtr != 0) {
037      if (swigCMemOwnDerived) {
038        swigCMemOwnDerived = false;
039        QuantLibJNI.delete_BlackIborCouponPricer(swigCPtr);
040      }
041      swigCPtr = 0;
042    }
043    super.delete();
044  }
045
046  public BlackIborCouponPricer(OptionletVolatilityStructureHandle v, BlackIborCouponPricer.TimingAdjustment timingAdjustment, QuoteHandle correlation, OptionalBool useIndexedCoupon) {
047    this(QuantLibJNI.new_BlackIborCouponPricer__SWIG_0(OptionletVolatilityStructureHandle.getCPtr(v), v, timingAdjustment.swigValue(), QuoteHandle.getCPtr(correlation), correlation, OptionalBool.getCPtr(useIndexedCoupon), useIndexedCoupon), true);
048  }
049
050  public BlackIborCouponPricer(OptionletVolatilityStructureHandle v, BlackIborCouponPricer.TimingAdjustment timingAdjustment, QuoteHandle correlation) {
051    this(QuantLibJNI.new_BlackIborCouponPricer__SWIG_1(OptionletVolatilityStructureHandle.getCPtr(v), v, timingAdjustment.swigValue(), QuoteHandle.getCPtr(correlation), correlation), true);
052  }
053
054  public BlackIborCouponPricer(OptionletVolatilityStructureHandle v, BlackIborCouponPricer.TimingAdjustment timingAdjustment) {
055    this(QuantLibJNI.new_BlackIborCouponPricer__SWIG_2(OptionletVolatilityStructureHandle.getCPtr(v), v, timingAdjustment.swigValue()), true);
056  }
057
058  public BlackIborCouponPricer(OptionletVolatilityStructureHandle v) {
059    this(QuantLibJNI.new_BlackIborCouponPricer__SWIG_3(OptionletVolatilityStructureHandle.getCPtr(v), v), true);
060  }
061
062  public BlackIborCouponPricer() {
063    this(QuantLibJNI.new_BlackIborCouponPricer__SWIG_4(), true);
064  }
065
066  public final static class TimingAdjustment {
067    public final static BlackIborCouponPricer.TimingAdjustment Black76 = new BlackIborCouponPricer.TimingAdjustment("Black76");
068    public final static BlackIborCouponPricer.TimingAdjustment BivariateLognormal = new BlackIborCouponPricer.TimingAdjustment("BivariateLognormal");
069
070    public final int swigValue() {
071      return swigValue;
072    }
073
074    public String toString() {
075      return swigName;
076    }
077
078    public static TimingAdjustment swigToEnum(int swigValue) {
079      if (swigValue < swigValues.length && swigValue >= 0 && swigValues[swigValue].swigValue == swigValue)
080        return swigValues[swigValue];
081      for (int i = 0; i < swigValues.length; i++)
082        if (swigValues[i].swigValue == swigValue)
083          return swigValues[i];
084      throw new IllegalArgumentException("No enum " + TimingAdjustment.class + " with value " + swigValue);
085    }
086
087    private TimingAdjustment(String swigName) {
088      this.swigName = swigName;
089      this.swigValue = swigNext++;
090    }
091
092    private TimingAdjustment(String swigName, int swigValue) {
093      this.swigName = swigName;
094      this.swigValue = swigValue;
095      swigNext = swigValue+1;
096    }
097
098    private TimingAdjustment(String swigName, TimingAdjustment swigEnum) {
099      this.swigName = swigName;
100      this.swigValue = swigEnum.swigValue;
101      swigNext = this.swigValue+1;
102    }
103
104    private static TimingAdjustment[] swigValues = { Black76, BivariateLognormal };
105    private static int swigNext = 0;
106    private final int swigValue;
107    private final String swigName;
108  }
109
110}