org.quantlib.InvCumulativeSobolGaussianRsg Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of quantlib Show documentation
Show all versions of quantlib Show documentation
Java language binding for QuantLib
/* ----------------------------------------------------------------------------
* This file was automatically generated by SWIG (https://www.swig.org).
* Version 4.2.1
*
* Do not make changes to this file unless you know what you are doing - modify
* the SWIG interface file instead.
* ----------------------------------------------------------------------------- */
package org.quantlib;
public class InvCumulativeSobolGaussianRsg implements org.quantlib.helpers.QuantLibJNIHelpers.AutoCloseable {
private transient long swigCPtr;
protected transient boolean swigCMemOwn;
protected InvCumulativeSobolGaussianRsg(long cPtr, boolean cMemoryOwn) {
swigCMemOwn = cMemoryOwn;
swigCPtr = cPtr;
}
protected static long getCPtr(InvCumulativeSobolGaussianRsg obj) {
return (obj == null) ? 0 : obj.swigCPtr;
}
protected static long swigRelease(InvCumulativeSobolGaussianRsg obj) {
long ptr = 0;
if (obj != null) {
if (!obj.swigCMemOwn)
throw new RuntimeException("Cannot release ownership as memory is not owned");
ptr = obj.swigCPtr;
obj.swigCMemOwn = false;
obj.delete();
}
return ptr;
}
@SuppressWarnings({"deprecation", "removal"})
protected void finalize() {
delete();
}
public synchronized void delete() {
if (swigCPtr != 0) {
if (swigCMemOwn) {
swigCMemOwn = false;
QuantLibJNI.delete_InvCumulativeSobolGaussianRsg(swigCPtr);
}
swigCPtr = 0;
}
}
public InvCumulativeSobolGaussianRsg(SobolRsg uniformSequenceGenerator) {
this(QuantLibJNI.new_InvCumulativeSobolGaussianRsg__SWIG_0(SobolRsg.getCPtr(uniformSequenceGenerator), uniformSequenceGenerator), true);
}
public InvCumulativeSobolGaussianRsg(SobolRsg uniformSequenceGenerator, InverseCumulativeNormal inverseCumulative) {
this(QuantLibJNI.new_InvCumulativeSobolGaussianRsg__SWIG_1(SobolRsg.getCPtr(uniformSequenceGenerator), uniformSequenceGenerator, InverseCumulativeNormal.getCPtr(inverseCumulative), inverseCumulative), true);
}
public SampleRealVector nextSequence() {
return new SampleRealVector(QuantLibJNI.InvCumulativeSobolGaussianRsg_nextSequence(swigCPtr, this), false);
}
public long dimension() {
return QuantLibJNI.InvCumulativeSobolGaussianRsg_dimension(swigCPtr, this);
}
}