module Bindings.Gsl.QuasiRandomSequences where
import Foreign.Ptr (Ptr,FunPtr,plusPtr)
import Foreign.Ptr (wordPtrToPtr,castPtrToFunPtr)
import Foreign.Storable
import Foreign.C.Types
import Foreign.C.String (CString,CStringLen,CWString,CWStringLen)
import Foreign.Marshal.Alloc (alloca)
import Foreign.Marshal.Array (peekArray,pokeArray)
import Data.Int
import Data.Word
data C'gsl_qrng_type = C'gsl_qrng_type{
c'gsl_qrng_type'name :: CString,
c'gsl_qrng_type'max_dimension :: CUInt,
c'gsl_qrng_type'state_size :: FunPtr (CUInt -> IO CSize),
c'gsl_qrng_type'init_state :: FunPtr (Ptr () -> CUInt -> IO CInt),
c'gsl_qrng_type'get :: FunPtr (Ptr () -> CUInt -> Ptr CDouble -> IO CInt)
} deriving (Eq,Show)
p'gsl_qrng_type'name p = plusPtr p 0
p'gsl_qrng_type'name :: Ptr (C'gsl_qrng_type) -> Ptr (CString)
p'gsl_qrng_type'max_dimension p = plusPtr p 4
p'gsl_qrng_type'max_dimension :: Ptr (C'gsl_qrng_type) -> Ptr (CUInt)
p'gsl_qrng_type'state_size p = plusPtr p 8
p'gsl_qrng_type'state_size :: Ptr (C'gsl_qrng_type) -> Ptr (FunPtr (CUInt -> IO CSize))
p'gsl_qrng_type'init_state p = plusPtr p 12
p'gsl_qrng_type'init_state :: Ptr (C'gsl_qrng_type) -> Ptr (FunPtr (Ptr () -> CUInt -> IO CInt))
p'gsl_qrng_type'get p = plusPtr p 16
p'gsl_qrng_type'get :: Ptr (C'gsl_qrng_type) -> Ptr (FunPtr (Ptr () -> CUInt -> Ptr CDouble -> IO CInt))
instance Storable C'gsl_qrng_type where
sizeOf _ = 20
alignment _ = 4
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
v3 <- peekByteOff p 12
v4 <- peekByteOff p 16
return $ C'gsl_qrng_type v0 v1 v2 v3 v4
poke p (C'gsl_qrng_type v0 v1 v2 v3 v4) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
pokeByteOff p 12 v3
pokeByteOff p 16 v4
return ()
data C'gsl_qrng = C'gsl_qrng{
c'gsl_qrng'type :: Ptr C'gsl_qrng_type,
c'gsl_qrng'dimension :: CUInt,
c'gsl_qrng'state_size :: CSize,
c'gsl_qrng'state :: Ptr ()
} deriving (Eq,Show)
p'gsl_qrng'type p = plusPtr p 0
p'gsl_qrng'type :: Ptr (C'gsl_qrng) -> Ptr (Ptr C'gsl_qrng_type)
p'gsl_qrng'dimension p = plusPtr p 4
p'gsl_qrng'dimension :: Ptr (C'gsl_qrng) -> Ptr (CUInt)
p'gsl_qrng'state_size p = plusPtr p 8
p'gsl_qrng'state_size :: Ptr (C'gsl_qrng) -> Ptr (CSize)
p'gsl_qrng'state p = plusPtr p 12
p'gsl_qrng'state :: Ptr (C'gsl_qrng) -> Ptr (Ptr ())
instance Storable C'gsl_qrng where
sizeOf _ = 16
alignment _ = 4
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
v3 <- peekByteOff p 12
return $ C'gsl_qrng v0 v1 v2 v3
poke p (C'gsl_qrng v0 v1 v2 v3) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
pokeByteOff p 12 v3
return ()
foreign import ccall "&gsl_qrng_niederreiter_2" p'gsl_qrng_niederreiter_2
:: Ptr (Ptr gsl_qrng_type)
foreign import ccall "&gsl_qrng_sobol" p'gsl_qrng_sobol
:: Ptr (Ptr gsl_qrng_type)
foreign import ccall "&gsl_qrng_halton" p'gsl_qrng_halton
:: Ptr (Ptr gsl_qrng_type)
foreign import ccall "&gsl_qrng_reversehalton" p'gsl_qrng_reversehalton
:: Ptr (Ptr gsl_qrng_type)
foreign import ccall "gsl_qrng_alloc" c'gsl_qrng_alloc
:: Ptr C'gsl_qrng_type -> CUInt -> IO (Ptr C'gsl_qrng)
foreign import ccall "&gsl_qrng_alloc" p'gsl_qrng_alloc
:: FunPtr (Ptr C'gsl_qrng_type -> CUInt -> IO (Ptr C'gsl_qrng))
foreign import ccall "gsl_qrng_memcpy" c'gsl_qrng_memcpy
:: Ptr C'gsl_qrng -> Ptr C'gsl_qrng -> IO CInt
foreign import ccall "&gsl_qrng_memcpy" p'gsl_qrng_memcpy
:: FunPtr (Ptr C'gsl_qrng -> Ptr C'gsl_qrng -> IO CInt)
foreign import ccall "gsl_qrng_clone" c'gsl_qrng_clone
:: Ptr C'gsl_qrng -> IO (Ptr C'gsl_qrng)
foreign import ccall "&gsl_qrng_clone" p'gsl_qrng_clone
:: FunPtr (Ptr C'gsl_qrng -> IO (Ptr C'gsl_qrng))
foreign import ccall "gsl_qrng_free" c'gsl_qrng_free
:: Ptr C'gsl_qrng -> IO ()
foreign import ccall "&gsl_qrng_free" p'gsl_qrng_free
:: FunPtr (Ptr C'gsl_qrng -> IO ())
foreign import ccall "gsl_qrng_init" c'gsl_qrng_init
:: Ptr C'gsl_qrng -> IO ()
foreign import ccall "&gsl_qrng_init" p'gsl_qrng_init
:: FunPtr (Ptr C'gsl_qrng -> IO ())
foreign import ccall "gsl_qrng_name" c'gsl_qrng_name
:: Ptr C'gsl_qrng -> IO CString
foreign import ccall "&gsl_qrng_name" p'gsl_qrng_name
:: FunPtr (Ptr C'gsl_qrng -> IO CString)
foreign import ccall "gsl_qrng_size" c'gsl_qrng_size
:: Ptr C'gsl_qrng -> IO CSize
foreign import ccall "&gsl_qrng_size" p'gsl_qrng_size
:: FunPtr (Ptr C'gsl_qrng -> IO CSize)
foreign import ccall "gsl_qrng_state" c'gsl_qrng_state
:: Ptr C'gsl_qrng -> IO (Ptr ())
foreign import ccall "&gsl_qrng_state" p'gsl_qrng_state
:: FunPtr (Ptr C'gsl_qrng -> IO (Ptr ()))
foreign import ccall "gsl_qrng_get" c'gsl_qrng_get
:: Ptr C'gsl_qrng -> Ptr CDouble -> IO CInt
foreign import ccall "&gsl_qrng_get" p'gsl_qrng_get
:: FunPtr (Ptr C'gsl_qrng -> Ptr CDouble -> IO CInt)