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
|
/* ----------------------------------------------------------------------------
* This file was automatically generated by SWIG (http://www.swig.org).
* Version 1.3.40
*
* Do not make changes to this file unless you know what you are doing--modify
* the SWIG interface file instead.
* ----------------------------------------------------------------------------- */
namespace QuantLib {
using System;
using System.Runtime.InteropServices;
public class BoxMullerLecuyerGaussianRng : IDisposable {
private HandleRef swigCPtr;
protected bool swigCMemOwn;
internal BoxMullerLecuyerGaussianRng(IntPtr cPtr, bool cMemoryOwn) {
swigCMemOwn = cMemoryOwn;
swigCPtr = new HandleRef(this, cPtr);
}
internal static HandleRef getCPtr(BoxMullerLecuyerGaussianRng obj) {
return (obj == null) ? new HandleRef(null, IntPtr.Zero) : obj.swigCPtr;
}
~BoxMullerLecuyerGaussianRng() {
Dispose();
}
public virtual void Dispose() {
lock(this) {
if (swigCPtr.Handle != IntPtr.Zero) {
if (swigCMemOwn) {
swigCMemOwn = false;
NQuantLibcPINVOKE.delete_BoxMullerLecuyerGaussianRng(swigCPtr);
}
swigCPtr = new HandleRef(null, IntPtr.Zero);
}
GC.SuppressFinalize(this);
}
}
public BoxMullerLecuyerGaussianRng(LecuyerUniformRng rng) : this(NQuantLibcPINVOKE.new_BoxMullerLecuyerGaussianRng(LecuyerUniformRng.getCPtr(rng)), true) {
if (NQuantLibcPINVOKE.SWIGPendingException.Pending) throw NQuantLibcPINVOKE.SWIGPendingException.Retrieve();
}
public SampleNumber next() {
SampleNumber ret = new SampleNumber(NQuantLibcPINVOKE.BoxMullerLecuyerGaussianRng_next(swigCPtr), true);
if (NQuantLibcPINVOKE.SWIGPendingException.Pending) throw NQuantLibcPINVOKE.SWIGPendingException.Retrieve();
return ret;
}
}
}
|