module Bindings.Gsl.MultidimensionalRootFinding 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
import Bindings.Gsl.VectorsAndMatrices.DataTypes
data C'gsl_multiroot_function = C'gsl_multiroot_function{
c'gsl_multiroot_function'f :: FunPtr ( Ptr C'gsl_vector -> Ptr () -> Ptr C'gsl_vector -> IO CInt)
,
c'gsl_multiroot_function'n :: CSize
,
c'gsl_multiroot_function'params :: Ptr ()
} deriving (Eq,Show)
instance Storable C'gsl_multiroot_function where
sizeOf _ = 12
alignment = sizeOf
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
return $ C'gsl_multiroot_function v0 v1 v2
poke p (C'gsl_multiroot_function v0 v1 v2) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
return ()
foreign import ccall "inline_GSL_MULTIROOT_FN_EVAL" c'GSL_MULTIROOT_FN_EVAL
:: Ptr C'gsl_multiroot_function -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> IO CInt
foreign import ccall "gsl_multiroot_fdjacobian" c'gsl_multiroot_fdjacobian
:: Ptr C'gsl_multiroot_function -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> CDouble -> Ptr C'gsl_matrix -> IO CInt
foreign import ccall "&gsl_multiroot_fdjacobian" p'gsl_multiroot_fdjacobian
:: FunPtr (Ptr C'gsl_multiroot_function -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> CDouble -> Ptr C'gsl_matrix -> IO CInt)
data C'gsl_multiroot_fsolver_type = C'gsl_multiroot_fsolver_type{
c'gsl_multiroot_fsolver_type'name :: CString
,
c'gsl_multiroot_fsolver_type'size :: CSize
,
c'gsl_multiroot_fsolver_type'alloc :: FunPtr (Ptr () -> CSize -> IO CInt)
,
c'gsl_multiroot_fsolver_type'set :: FunPtr (Ptr () -> Ptr C'gsl_multiroot_function -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> IO CInt)
,
c'gsl_multiroot_fsolver_type'iterate :: FunPtr (Ptr () -> Ptr C'gsl_multiroot_function -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> IO CInt)
,
c'gsl_multiroot_fsolver_type'free :: FunPtr (Ptr () -> IO ())
} deriving (Eq,Show)
instance Storable C'gsl_multiroot_fsolver_type where
sizeOf _ = 24
alignment = sizeOf
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
v3 <- peekByteOff p 12
v4 <- peekByteOff p 16
v5 <- peekByteOff p 20
return $ C'gsl_multiroot_fsolver_type v0 v1 v2 v3 v4 v5
poke p (C'gsl_multiroot_fsolver_type v0 v1 v2 v3 v4 v5) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
pokeByteOff p 12 v3
pokeByteOff p 16 v4
pokeByteOff p 20 v5
return ()
data C'gsl_multiroot_fsolver = C'gsl_multiroot_fsolver{
c'gsl_multiroot_fsolver'type :: Ptr C'gsl_multiroot_fsolver_type
,
c'gsl_multiroot_fsolver'function :: Ptr C'gsl_multiroot_function
,
c'gsl_multiroot_fsolver'x :: Ptr C'gsl_vector
,
c'gsl_multiroot_fsolver'f :: Ptr C'gsl_vector
,
c'gsl_multiroot_fsolver'dx :: Ptr C'gsl_vector
,
c'gsl_multiroot_fsolver'state :: Ptr ()
} deriving (Eq,Show)
instance Storable C'gsl_multiroot_fsolver where
sizeOf _ = 24
alignment = sizeOf
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
v3 <- peekByteOff p 12
v4 <- peekByteOff p 16
v5 <- peekByteOff p 20
return $ C'gsl_multiroot_fsolver v0 v1 v2 v3 v4 v5
poke p (C'gsl_multiroot_fsolver v0 v1 v2 v3 v4 v5) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
pokeByteOff p 12 v3
pokeByteOff p 16 v4
pokeByteOff p 20 v5
return ()
foreign import ccall "gsl_multiroot_fsolver_alloc" c'gsl_multiroot_fsolver_alloc
:: Ptr C'gsl_multiroot_fsolver_type -> CSize -> IO (Ptr C'gsl_multiroot_fsolver)
foreign import ccall "&gsl_multiroot_fsolver_alloc" p'gsl_multiroot_fsolver_alloc
:: FunPtr (Ptr C'gsl_multiroot_fsolver_type -> CSize -> IO (Ptr C'gsl_multiroot_fsolver))
foreign import ccall "gsl_multiroot_fsolver_free" c'gsl_multiroot_fsolver_free
:: Ptr C'gsl_multiroot_fsolver -> IO ()
foreign import ccall "&gsl_multiroot_fsolver_free" p'gsl_multiroot_fsolver_free
:: FunPtr (Ptr C'gsl_multiroot_fsolver -> IO ())
foreign import ccall "gsl_multiroot_fsolver_set" c'gsl_multiroot_fsolver_set
:: Ptr C'gsl_multiroot_fsolver -> Ptr C'gsl_multiroot_function -> Ptr C'gsl_vector -> IO CInt
foreign import ccall "&gsl_multiroot_fsolver_set" p'gsl_multiroot_fsolver_set
:: FunPtr (Ptr C'gsl_multiroot_fsolver -> Ptr C'gsl_multiroot_function -> Ptr C'gsl_vector -> IO CInt)
foreign import ccall "gsl_multiroot_fsolver_iterate" c'gsl_multiroot_fsolver_iterate
:: Ptr C'gsl_multiroot_fsolver -> IO CInt
foreign import ccall "&gsl_multiroot_fsolver_iterate" p'gsl_multiroot_fsolver_iterate
:: FunPtr (Ptr C'gsl_multiroot_fsolver -> IO CInt)
foreign import ccall "gsl_multiroot_fsolver_name" c'gsl_multiroot_fsolver_name
:: Ptr C'gsl_multiroot_fsolver -> IO CString
foreign import ccall "&gsl_multiroot_fsolver_name" p'gsl_multiroot_fsolver_name
:: FunPtr (Ptr C'gsl_multiroot_fsolver -> IO CString)
foreign import ccall "gsl_multiroot_fsolver_root" c'gsl_multiroot_fsolver_root
:: Ptr C'gsl_multiroot_fsolver -> IO (Ptr C'gsl_vector)
foreign import ccall "&gsl_multiroot_fsolver_root" p'gsl_multiroot_fsolver_root
:: FunPtr (Ptr C'gsl_multiroot_fsolver -> IO (Ptr C'gsl_vector))
foreign import ccall "gsl_multiroot_fsolver_dx" c'gsl_multiroot_fsolver_dx
:: Ptr C'gsl_multiroot_fsolver -> IO (Ptr C'gsl_vector)
foreign import ccall "&gsl_multiroot_fsolver_dx" p'gsl_multiroot_fsolver_dx
:: FunPtr (Ptr C'gsl_multiroot_fsolver -> IO (Ptr C'gsl_vector))
foreign import ccall "gsl_multiroot_fsolver_f" c'gsl_multiroot_fsolver_f
:: Ptr C'gsl_multiroot_fsolver -> IO (Ptr C'gsl_vector)
foreign import ccall "&gsl_multiroot_fsolver_f" p'gsl_multiroot_fsolver_f
:: FunPtr (Ptr C'gsl_multiroot_fsolver -> IO (Ptr C'gsl_vector))
data C'gsl_multiroot_function_fdf = C'gsl_multiroot_function_fdf{
c'gsl_multiroot_function_fdf'f :: FunPtr ( Ptr C'gsl_vector -> Ptr () -> Ptr C'gsl_vector -> IO CInt)
,
c'gsl_multiroot_function_fdf'df :: FunPtr ( Ptr C'gsl_vector -> Ptr () -> Ptr C'gsl_matrix -> IO CInt)
,
c'gsl_multiroot_function_fdf'fdf :: FunPtr ( Ptr C'gsl_vector -> Ptr () -> Ptr C'gsl_vector -> Ptr C'gsl_matrix -> IO CInt)
,
c'gsl_multiroot_function_fdf'n :: CSize
,
c'gsl_multiroot_function_fdf'params :: Ptr ()
} deriving (Eq,Show)
instance Storable C'gsl_multiroot_function_fdf where
sizeOf _ = 20
alignment = sizeOf
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_multiroot_function_fdf v0 v1 v2 v3 v4
poke p (C'gsl_multiroot_function_fdf 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 ()
foreign import ccall "inline_GSL_MULTIROOT_FN_EVAL_F" c'GSL_MULTIROOT_FN_EVAL_F
:: Ptr C'gsl_multiroot_function_fdf -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> IO CInt
foreign import ccall "inline_GSL_MULTIROOT_FN_EVAL_DF" c'GSL_MULTIROOT_FN_EVAL_DF
:: Ptr C'gsl_multiroot_function_fdf -> Ptr C'gsl_vector -> Ptr C'gsl_matrix -> IO CInt
foreign import ccall "inline_GSL_MULTIROOT_FN_EVAL_F_DF" c'GSL_MULTIROOT_FN_EVAL_F_DF
:: Ptr C'gsl_multiroot_function_fdf -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> Ptr C'gsl_matrix -> IO CInt
data C'gsl_multiroot_fdfsolver_type = C'gsl_multiroot_fdfsolver_type{
c'gsl_multiroot_fdfsolver_type'name :: CString
,
c'gsl_multiroot_fdfsolver_type'size :: CSize
,
c'gsl_multiroot_fdfsolver_type'alloc :: FunPtr (Ptr () -> CSize -> IO CInt)
,
c'gsl_multiroot_fdfsolver_type'set :: FunPtr (Ptr () -> Ptr C'gsl_multiroot_function_fdf -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> Ptr C'gsl_matrix -> Ptr C'gsl_vector -> IO CInt)
,
c'gsl_multiroot_fdfsolver_type'iterate :: FunPtr (Ptr () -> Ptr C'gsl_multiroot_function_fdf -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> Ptr C'gsl_matrix -> Ptr C'gsl_vector -> IO CInt)
,
c'gsl_multiroot_fdfsolver_type'free :: FunPtr (Ptr () -> IO ())
} deriving (Eq,Show)
instance Storable C'gsl_multiroot_fdfsolver_type where
sizeOf _ = 24
alignment = sizeOf
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
v3 <- peekByteOff p 12
v4 <- peekByteOff p 16
v5 <- peekByteOff p 20
return $ C'gsl_multiroot_fdfsolver_type v0 v1 v2 v3 v4 v5
poke p (C'gsl_multiroot_fdfsolver_type v0 v1 v2 v3 v4 v5) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
pokeByteOff p 12 v3
pokeByteOff p 16 v4
pokeByteOff p 20 v5
return ()
data C'gsl_multiroot_fdfsolver = C'gsl_multiroot_fdfsolver{
c'gsl_multiroot_fdfsolver'type :: Ptr C'gsl_multiroot_fdfsolver_type
,
c'gsl_multiroot_fdfsolver'fdf :: Ptr C'gsl_multiroot_function_fdf
,
c'gsl_multiroot_fdfsolver'x :: Ptr C'gsl_vector
,
c'gsl_multiroot_fdfsolver'f :: Ptr C'gsl_vector
,
c'gsl_multiroot_fdfsolver'J :: Ptr C'gsl_matrix
,
c'gsl_multiroot_fdfsolver'dx :: Ptr C'gsl_vector
,
c'gsl_multiroot_fdfsolver'state :: Ptr ()
} deriving (Eq,Show)
instance Storable C'gsl_multiroot_fdfsolver where
sizeOf _ = 28
alignment = sizeOf
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
v3 <- peekByteOff p 12
v4 <- peekByteOff p 16
v5 <- peekByteOff p 20
v6 <- peekByteOff p 24
return $ C'gsl_multiroot_fdfsolver v0 v1 v2 v3 v4 v5 v6
poke p (C'gsl_multiroot_fdfsolver v0 v1 v2 v3 v4 v5 v6) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
pokeByteOff p 12 v3
pokeByteOff p 16 v4
pokeByteOff p 20 v5
pokeByteOff p 24 v6
return ()
foreign import ccall "gsl_multiroot_fdfsolver_alloc" c'gsl_multiroot_fdfsolver_alloc
:: Ptr C'gsl_multiroot_fdfsolver_type -> CSize -> IO (Ptr C'gsl_multiroot_fdfsolver)
foreign import ccall "&gsl_multiroot_fdfsolver_alloc" p'gsl_multiroot_fdfsolver_alloc
:: FunPtr (Ptr C'gsl_multiroot_fdfsolver_type -> CSize -> IO (Ptr C'gsl_multiroot_fdfsolver))
foreign import ccall "gsl_multiroot_fdfsolver_set" c'gsl_multiroot_fdfsolver_set
:: Ptr C'gsl_multiroot_fdfsolver -> Ptr C'gsl_multiroot_function_fdf -> Ptr C'gsl_vector -> IO CInt
foreign import ccall "&gsl_multiroot_fdfsolver_set" p'gsl_multiroot_fdfsolver_set
:: FunPtr (Ptr C'gsl_multiroot_fdfsolver -> Ptr C'gsl_multiroot_function_fdf -> Ptr C'gsl_vector -> IO CInt)
foreign import ccall "gsl_multiroot_fdfsolver_iterate" c'gsl_multiroot_fdfsolver_iterate
:: Ptr C'gsl_multiroot_fdfsolver -> IO CInt
foreign import ccall "&gsl_multiroot_fdfsolver_iterate" p'gsl_multiroot_fdfsolver_iterate
:: FunPtr (Ptr C'gsl_multiroot_fdfsolver -> IO CInt)
foreign import ccall "gsl_multiroot_fdfsolver_free" c'gsl_multiroot_fdfsolver_free
:: Ptr C'gsl_multiroot_fdfsolver -> IO ()
foreign import ccall "&gsl_multiroot_fdfsolver_free" p'gsl_multiroot_fdfsolver_free
:: FunPtr (Ptr C'gsl_multiroot_fdfsolver -> IO ())
foreign import ccall "gsl_multiroot_fdfsolver_name" c'gsl_multiroot_fdfsolver_name
:: Ptr C'gsl_multiroot_fdfsolver -> IO CString
foreign import ccall "&gsl_multiroot_fdfsolver_name" p'gsl_multiroot_fdfsolver_name
:: FunPtr (Ptr C'gsl_multiroot_fdfsolver -> IO CString)
foreign import ccall "gsl_multiroot_fdfsolver_root" c'gsl_multiroot_fdfsolver_root
:: Ptr C'gsl_multiroot_fdfsolver -> IO (Ptr C'gsl_vector)
foreign import ccall "&gsl_multiroot_fdfsolver_root" p'gsl_multiroot_fdfsolver_root
:: FunPtr (Ptr C'gsl_multiroot_fdfsolver -> IO (Ptr C'gsl_vector))
foreign import ccall "gsl_multiroot_fdfsolver_dx" c'gsl_multiroot_fdfsolver_dx
:: Ptr C'gsl_multiroot_fdfsolver -> IO (Ptr C'gsl_vector)
foreign import ccall "&gsl_multiroot_fdfsolver_dx" p'gsl_multiroot_fdfsolver_dx
:: FunPtr (Ptr C'gsl_multiroot_fdfsolver -> IO (Ptr C'gsl_vector))
foreign import ccall "gsl_multiroot_fdfsolver_f" c'gsl_multiroot_fdfsolver_f
:: Ptr C'gsl_multiroot_fdfsolver -> IO (Ptr C'gsl_vector)
foreign import ccall "&gsl_multiroot_fdfsolver_f" p'gsl_multiroot_fdfsolver_f
:: FunPtr (Ptr C'gsl_multiroot_fdfsolver -> IO (Ptr C'gsl_vector))
foreign import ccall "gsl_multiroot_test_delta" c'gsl_multiroot_test_delta
:: Ptr C'gsl_vector -> Ptr C'gsl_vector -> CDouble -> CDouble -> IO CInt
foreign import ccall "&gsl_multiroot_test_delta" p'gsl_multiroot_test_delta
:: FunPtr (Ptr C'gsl_vector -> Ptr C'gsl_vector -> CDouble -> CDouble -> IO CInt)
foreign import ccall "gsl_multiroot_test_residual" c'gsl_multiroot_test_residual
:: Ptr C'gsl_vector -> CDouble -> IO CInt
foreign import ccall "&gsl_multiroot_test_residual" p'gsl_multiroot_test_residual
:: FunPtr (Ptr C'gsl_vector -> CDouble -> IO CInt)
foreign import ccall "&gsl_multiroot_fsolver_dnewton" p'gsl_multiroot_fsolver_dnewton
:: Ptr (Ptr gsl_multiroot_fsolver_type)
foreign import ccall "&gsl_multiroot_fsolver_broyden" p'gsl_multiroot_fsolver_broyden
:: Ptr (Ptr gsl_multiroot_fsolver_type)
foreign import ccall "&gsl_multiroot_fsolver_hybrid" p'gsl_multiroot_fsolver_hybrid
:: Ptr (Ptr gsl_multiroot_fsolver_type)
foreign import ccall "&gsl_multiroot_fsolver_hybrids" p'gsl_multiroot_fsolver_hybrids
:: Ptr (Ptr gsl_multiroot_fsolver_type)
foreign import ccall "&gsl_multiroot_fdfsolver_newton" p'gsl_multiroot_fdfsolver_newton
:: Ptr (Ptr gsl_multiroot_fdfsolver_type)
foreign import ccall "&gsl_multiroot_fdfsolver_gnewton" p'gsl_multiroot_fdfsolver_gnewton
:: Ptr (Ptr gsl_multiroot_fdfsolver_type)
foreign import ccall "&gsl_multiroot_fdfsolver_hybridj" p'gsl_multiroot_fdfsolver_hybridj
:: Ptr (Ptr gsl_multiroot_fdfsolver_type)
foreign import ccall "&gsl_multiroot_fdfsolver_hybridsj" p'gsl_multiroot_fdfsolver_hybridsj
:: Ptr (Ptr gsl_multiroot_fdfsolver_type)