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 FdmStepConditionComposite extends FdmStepCondition implements org.quantlib.helpers.QuantLibJNIHelpers.AutoCloseable { 012 private transient long swigCPtr; 013 private transient boolean swigCMemOwnDerived; 014 015 protected FdmStepConditionComposite(long cPtr, boolean cMemoryOwn) { 016 super(QuantLibJNI.FdmStepConditionComposite_SWIGSmartPtrUpcast(cPtr), true); 017 swigCMemOwnDerived = cMemoryOwn; 018 swigCPtr = cPtr; 019 } 020 021 protected static long getCPtr(FdmStepConditionComposite 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_FdmStepConditionComposite(swigCPtr); 040 } 041 swigCPtr = 0; 042 } 043 super.delete(); 044 } 045 046 public FdmStepConditionComposite(DoubleVector stoppingTimes, FdmStepConditionVector conditions) { 047 this(QuantLibJNI.new_FdmStepConditionComposite(DoubleVector.getCPtr(stoppingTimes), stoppingTimes, FdmStepConditionVector.getCPtr(conditions), conditions), true); 048 } 049 050 public DoubleVector stoppingTimes() { 051 return new DoubleVector(QuantLibJNI.FdmStepConditionComposite_stoppingTimes(swigCPtr, this), false); 052 } 053 054 public FdmStepConditionVector conditions() { 055 return new FdmStepConditionVector(QuantLibJNI.FdmStepConditionComposite_conditions(swigCPtr, this), false); 056 } 057 058 public static FdmStepConditionComposite joinConditions(FdmSnapshotCondition c1, FdmStepConditionComposite c2) { 059 long cPtr = QuantLibJNI.FdmStepConditionComposite_joinConditions(FdmSnapshotCondition.getCPtr(c1), c1, FdmStepConditionComposite.getCPtr(c2), c2); 060 return (cPtr == 0) ? null : new FdmStepConditionComposite(cPtr, true); 061 } 062 063 public static FdmStepConditionComposite vanillaComposite(DividendSchedule schedule, Exercise exercise, FdmMesher mesher, FdmInnerValueCalculator calculator, Date refDate, DayCounter dayCounter) { 064 long cPtr = QuantLibJNI.FdmStepConditionComposite_vanillaComposite(DividendSchedule.getCPtr(schedule), schedule, Exercise.getCPtr(exercise), exercise, FdmMesher.getCPtr(mesher), mesher, FdmInnerValueCalculator.getCPtr(calculator), calculator, Date.getCPtr(refDate), refDate, DayCounter.getCPtr(dayCounter), dayCounter); 065 return (cPtr == 0) ? null : new FdmStepConditionComposite(cPtr, true); 066 } 067 068}