module Bindings.Gsl.MultidimensionalMinimization 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_multimin_function = C'gsl_multimin_function{
c'gsl_multimin_function'f :: FunPtr (Ptr C'gsl_vector -> Ptr () -> IO CDouble),
c'gsl_multimin_function'n :: CSize,
c'gsl_multimin_function'params :: Ptr ()
} deriving (Eq,Show)
p'gsl_multimin_function'f p = plusPtr p 0
p'gsl_multimin_function'f :: Ptr (C'gsl_multimin_function) -> Ptr (FunPtr (Ptr C'gsl_vector -> Ptr () -> IO CDouble))
p'gsl_multimin_function'n p = plusPtr p 4
p'gsl_multimin_function'n :: Ptr (C'gsl_multimin_function) -> Ptr (CSize)
p'gsl_multimin_function'params p = plusPtr p 8
p'gsl_multimin_function'params :: Ptr (C'gsl_multimin_function) -> Ptr (Ptr ())
instance Storable C'gsl_multimin_function where
sizeOf _ = 12
alignment _ = 4
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
return $ C'gsl_multimin_function v0 v1 v2
poke p (C'gsl_multimin_function v0 v1 v2) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
return ()
foreign import ccall "inline_GSL_MULTIMIN_FN_EVAL" c'GSL_MULTIMIN_FN_EVAL
:: Ptr C'gsl_multimin_function -> Ptr C'gsl_vector -> IO CDouble
data C'gsl_multimin_function_fdf = C'gsl_multimin_function_fdf{
c'gsl_multimin_function_fdf'f :: FunPtr (Ptr C'gsl_vector -> Ptr () -> IO CDouble),
c'gsl_multimin_function_fdf'df :: FunPtr (Ptr C'gsl_vector -> Ptr () -> Ptr C'gsl_vector -> IO ()),
c'gsl_multimin_function_fdf'fdf :: FunPtr (Ptr C'gsl_vector -> Ptr () -> Ptr CDouble -> Ptr C'gsl_vector -> IO ()),
c'gsl_multimin_function_fdf'n :: CSize,
c'gsl_multimin_function_fdf'params :: Ptr ()
} deriving (Eq,Show)
p'gsl_multimin_function_fdf'f p = plusPtr p 0
p'gsl_multimin_function_fdf'f :: Ptr (C'gsl_multimin_function_fdf) -> Ptr (FunPtr (Ptr C'gsl_vector -> Ptr () -> IO CDouble))
p'gsl_multimin_function_fdf'df p = plusPtr p 4
p'gsl_multimin_function_fdf'df :: Ptr (C'gsl_multimin_function_fdf) -> Ptr (FunPtr (Ptr C'gsl_vector -> Ptr () -> Ptr C'gsl_vector -> IO ()))
p'gsl_multimin_function_fdf'fdf p = plusPtr p 8
p'gsl_multimin_function_fdf'fdf :: Ptr (C'gsl_multimin_function_fdf) -> Ptr (FunPtr (Ptr C'gsl_vector -> Ptr () -> Ptr CDouble -> Ptr C'gsl_vector -> IO ()))
p'gsl_multimin_function_fdf'n p = plusPtr p 12
p'gsl_multimin_function_fdf'n :: Ptr (C'gsl_multimin_function_fdf) -> Ptr (CSize)
p'gsl_multimin_function_fdf'params p = plusPtr p 16
p'gsl_multimin_function_fdf'params :: Ptr (C'gsl_multimin_function_fdf) -> Ptr (Ptr ())
instance Storable C'gsl_multimin_function_fdf 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_multimin_function_fdf v0 v1 v2 v3 v4
poke p (C'gsl_multimin_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_MULTIMIN_FN_EVAL_F" c'GSL_MULTIMIN_FN_EVAL_F
:: Ptr C'gsl_multimin_function_fdf -> Ptr C'gsl_vector -> IO CDouble
foreign import ccall "inline_GSL_MULTIMIN_FN_EVAL_DF" c'GSL_MULTIMIN_FN_EVAL_DF
:: Ptr C'gsl_multimin_function_fdf -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> IO ()
foreign import ccall "inline_GSL_MULTIMIN_FN_EVAL_F_DF" c'GSL_MULTIMIN_FN_EVAL_F_DF
:: Ptr C'gsl_multimin_function_fdf -> Ptr C'gsl_vector -> Ptr CDouble -> Ptr C'gsl_vector -> IO ()
foreign import ccall "gsl_multimin_diff" c'gsl_multimin_diff
:: Ptr C'gsl_multimin_function -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> IO CInt
foreign import ccall "&gsl_multimin_diff" p'gsl_multimin_diff
:: FunPtr (Ptr C'gsl_multimin_function -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> IO CInt)
data C'gsl_multimin_fminimizer_type = C'gsl_multimin_fminimizer_type{
c'gsl_multimin_fminimizer_type'name :: CString,
c'gsl_multimin_fminimizer_type'size :: CSize,
c'gsl_multimin_fminimizer_type'alloc :: FunPtr (Ptr () -> CSize -> IO CInt),
c'gsl_multimin_fminimizer_type'set :: FunPtr (Ptr () -> Ptr C'gsl_multimin_function -> Ptr C'gsl_vector -> Ptr CDouble -> Ptr C'gsl_vector -> IO CInt),
c'gsl_multimin_fminimizer_type'iterate :: FunPtr (Ptr () -> Ptr C'gsl_multimin_function -> Ptr C'gsl_vector -> Ptr CDouble -> Ptr CDouble -> IO CInt),
c'gsl_multimin_fminimizer_type'free :: FunPtr (Ptr () -> IO ())
} deriving (Eq,Show)
p'gsl_multimin_fminimizer_type'name p = plusPtr p 0
p'gsl_multimin_fminimizer_type'name :: Ptr (C'gsl_multimin_fminimizer_type) -> Ptr (CString)
p'gsl_multimin_fminimizer_type'size p = plusPtr p 4
p'gsl_multimin_fminimizer_type'size :: Ptr (C'gsl_multimin_fminimizer_type) -> Ptr (CSize)
p'gsl_multimin_fminimizer_type'alloc p = plusPtr p 8
p'gsl_multimin_fminimizer_type'alloc :: Ptr (C'gsl_multimin_fminimizer_type) -> Ptr (FunPtr (Ptr () -> CSize -> IO CInt))
p'gsl_multimin_fminimizer_type'set p = plusPtr p 12
p'gsl_multimin_fminimizer_type'set :: Ptr (C'gsl_multimin_fminimizer_type) -> Ptr (FunPtr (Ptr () -> Ptr C'gsl_multimin_function -> Ptr C'gsl_vector -> Ptr CDouble -> Ptr C'gsl_vector -> IO CInt))
p'gsl_multimin_fminimizer_type'iterate p = plusPtr p 16
p'gsl_multimin_fminimizer_type'iterate :: Ptr (C'gsl_multimin_fminimizer_type) -> Ptr (FunPtr (Ptr () -> Ptr C'gsl_multimin_function -> Ptr C'gsl_vector -> Ptr CDouble -> Ptr CDouble -> IO CInt))
p'gsl_multimin_fminimizer_type'free p = plusPtr p 20
p'gsl_multimin_fminimizer_type'free :: Ptr (C'gsl_multimin_fminimizer_type) -> Ptr (FunPtr (Ptr () -> IO ()))
instance Storable C'gsl_multimin_fminimizer_type where
sizeOf _ = 24
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
v5 <- peekByteOff p 20
return $ C'gsl_multimin_fminimizer_type v0 v1 v2 v3 v4 v5
poke p (C'gsl_multimin_fminimizer_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_multimin_fminimizer = C'gsl_multimin_fminimizer{
c'gsl_multimin_fminimizer'type :: Ptr C'gsl_multimin_fminimizer_type,
c'gsl_multimin_fminimizer'f :: Ptr C'gsl_multimin_function,
c'gsl_multimin_fminimizer'fval :: CDouble,
c'gsl_multimin_fminimizer'x :: Ptr C'gsl_vector,
c'gsl_multimin_fminimizer'size :: CDouble,
c'gsl_multimin_fminimizer'state :: Ptr ()
} deriving (Eq,Show)
p'gsl_multimin_fminimizer'type p = plusPtr p 0
p'gsl_multimin_fminimizer'type :: Ptr (C'gsl_multimin_fminimizer) -> Ptr (Ptr C'gsl_multimin_fminimizer_type)
p'gsl_multimin_fminimizer'f p = plusPtr p 4
p'gsl_multimin_fminimizer'f :: Ptr (C'gsl_multimin_fminimizer) -> Ptr (Ptr C'gsl_multimin_function)
p'gsl_multimin_fminimizer'fval p = plusPtr p 8
p'gsl_multimin_fminimizer'fval :: Ptr (C'gsl_multimin_fminimizer) -> Ptr (CDouble)
p'gsl_multimin_fminimizer'x p = plusPtr p 16
p'gsl_multimin_fminimizer'x :: Ptr (C'gsl_multimin_fminimizer) -> Ptr (Ptr C'gsl_vector)
p'gsl_multimin_fminimizer'size p = plusPtr p 20
p'gsl_multimin_fminimizer'size :: Ptr (C'gsl_multimin_fminimizer) -> Ptr (CDouble)
p'gsl_multimin_fminimizer'state p = plusPtr p 28
p'gsl_multimin_fminimizer'state :: Ptr (C'gsl_multimin_fminimizer) -> Ptr (Ptr ())
instance Storable C'gsl_multimin_fminimizer where
sizeOf _ = 32
alignment _ = 4
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
v3 <- peekByteOff p 16
v4 <- peekByteOff p 20
v5 <- peekByteOff p 28
return $ C'gsl_multimin_fminimizer v0 v1 v2 v3 v4 v5
poke p (C'gsl_multimin_fminimizer v0 v1 v2 v3 v4 v5) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
pokeByteOff p 16 v3
pokeByteOff p 20 v4
pokeByteOff p 28 v5
return ()
foreign import ccall "gsl_multimin_fminimizer_alloc" c'gsl_multimin_fminimizer_alloc
:: Ptr C'gsl_multimin_fminimizer_type -> CSize -> IO (Ptr C'gsl_multimin_fminimizer)
foreign import ccall "&gsl_multimin_fminimizer_alloc" p'gsl_multimin_fminimizer_alloc
:: FunPtr (Ptr C'gsl_multimin_fminimizer_type -> CSize -> IO (Ptr C'gsl_multimin_fminimizer))
foreign import ccall "gsl_multimin_fminimizer_set" c'gsl_multimin_fminimizer_set
:: Ptr C'gsl_multimin_fminimizer -> Ptr C'gsl_multimin_function -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> IO CInt
foreign import ccall "&gsl_multimin_fminimizer_set" p'gsl_multimin_fminimizer_set
:: FunPtr (Ptr C'gsl_multimin_fminimizer -> Ptr C'gsl_multimin_function -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> IO CInt)
foreign import ccall "gsl_multimin_fminimizer_free" c'gsl_multimin_fminimizer_free
:: Ptr C'gsl_multimin_fminimizer -> IO ()
foreign import ccall "&gsl_multimin_fminimizer_free" p'gsl_multimin_fminimizer_free
:: FunPtr (Ptr C'gsl_multimin_fminimizer -> IO ())
foreign import ccall "gsl_multimin_fminimizer_name" c'gsl_multimin_fminimizer_name
:: Ptr C'gsl_multimin_fminimizer -> IO CString
foreign import ccall "&gsl_multimin_fminimizer_name" p'gsl_multimin_fminimizer_name
:: FunPtr (Ptr C'gsl_multimin_fminimizer -> IO CString)
foreign import ccall "gsl_multimin_fminimizer_iterate" c'gsl_multimin_fminimizer_iterate
:: Ptr C'gsl_multimin_fminimizer -> IO CInt
foreign import ccall "&gsl_multimin_fminimizer_iterate" p'gsl_multimin_fminimizer_iterate
:: FunPtr (Ptr C'gsl_multimin_fminimizer -> IO CInt)
foreign import ccall "gsl_multimin_fminimizer_x" c'gsl_multimin_fminimizer_x
:: Ptr C'gsl_multimin_fminimizer -> IO (Ptr C'gsl_vector)
foreign import ccall "&gsl_multimin_fminimizer_x" p'gsl_multimin_fminimizer_x
:: FunPtr (Ptr C'gsl_multimin_fminimizer -> IO (Ptr C'gsl_vector))
foreign import ccall "gsl_multimin_fminimizer_minimum" c'gsl_multimin_fminimizer_minimum
:: Ptr C'gsl_multimin_fminimizer -> IO CDouble
foreign import ccall "&gsl_multimin_fminimizer_minimum" p'gsl_multimin_fminimizer_minimum
:: FunPtr (Ptr C'gsl_multimin_fminimizer -> IO CDouble)
foreign import ccall "gsl_multimin_fminimizer_size" c'gsl_multimin_fminimizer_size
:: Ptr C'gsl_multimin_fminimizer -> IO CDouble
foreign import ccall "&gsl_multimin_fminimizer_size" p'gsl_multimin_fminimizer_size
:: FunPtr (Ptr C'gsl_multimin_fminimizer -> IO CDouble)
foreign import ccall "gsl_multimin_test_gradient" c'gsl_multimin_test_gradient
:: Ptr C'gsl_vector -> CDouble -> IO CInt
foreign import ccall "&gsl_multimin_test_gradient" p'gsl_multimin_test_gradient
:: FunPtr (Ptr C'gsl_vector -> CDouble -> IO CInt)
foreign import ccall "gsl_multimin_test_size" c'gsl_multimin_test_size
:: CDouble -> CDouble -> IO CInt
foreign import ccall "&gsl_multimin_test_size" p'gsl_multimin_test_size
:: FunPtr (CDouble -> CDouble -> IO CInt)
data C'gsl_multimin_fdfminimizer_type = C'gsl_multimin_fdfminimizer_type{
c'gsl_multimin_fdfminimizer_type'name :: CString,
c'gsl_multimin_fdfminimizer_type'size :: CSize,
c'gsl_multimin_fdfminimizer_type'alloc :: FunPtr (Ptr () -> CSize -> IO CInt),
c'gsl_multimin_fdfminimizer_type'set :: FunPtr (Ptr () -> Ptr C'gsl_multimin_function_fdf -> Ptr C'gsl_vector -> Ptr CDouble -> Ptr C'gsl_vector -> CDouble -> CDouble -> IO CInt),
c'gsl_multimin_fdfminimizer_type'iterate :: FunPtr (Ptr () -> Ptr C'gsl_multimin_function_fdf -> Ptr C'gsl_vector -> Ptr CDouble -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> IO CInt),
c'gsl_multimin_fdfminimizer_type'restart :: FunPtr (Ptr () -> IO CInt),
c'gsl_multimin_fdfminimizer_type'free :: FunPtr (Ptr () -> IO ())
} deriving (Eq,Show)
p'gsl_multimin_fdfminimizer_type'name p = plusPtr p 0
p'gsl_multimin_fdfminimizer_type'name :: Ptr (C'gsl_multimin_fdfminimizer_type) -> Ptr (CString)
p'gsl_multimin_fdfminimizer_type'size p = plusPtr p 4
p'gsl_multimin_fdfminimizer_type'size :: Ptr (C'gsl_multimin_fdfminimizer_type) -> Ptr (CSize)
p'gsl_multimin_fdfminimizer_type'alloc p = plusPtr p 8
p'gsl_multimin_fdfminimizer_type'alloc :: Ptr (C'gsl_multimin_fdfminimizer_type) -> Ptr (FunPtr (Ptr () -> CSize -> IO CInt))
p'gsl_multimin_fdfminimizer_type'set p = plusPtr p 12
p'gsl_multimin_fdfminimizer_type'set :: Ptr (C'gsl_multimin_fdfminimizer_type) -> Ptr (FunPtr (Ptr () -> Ptr C'gsl_multimin_function_fdf -> Ptr C'gsl_vector -> Ptr CDouble -> Ptr C'gsl_vector -> CDouble -> CDouble -> IO CInt))
p'gsl_multimin_fdfminimizer_type'iterate p = plusPtr p 16
p'gsl_multimin_fdfminimizer_type'iterate :: Ptr (C'gsl_multimin_fdfminimizer_type) -> Ptr (FunPtr (Ptr () -> Ptr C'gsl_multimin_function_fdf -> Ptr C'gsl_vector -> Ptr CDouble -> Ptr C'gsl_vector -> Ptr C'gsl_vector -> IO CInt))
p'gsl_multimin_fdfminimizer_type'restart p = plusPtr p 20
p'gsl_multimin_fdfminimizer_type'restart :: Ptr (C'gsl_multimin_fdfminimizer_type) -> Ptr (FunPtr (Ptr () -> IO CInt))
p'gsl_multimin_fdfminimizer_type'free p = plusPtr p 24
p'gsl_multimin_fdfminimizer_type'free :: Ptr (C'gsl_multimin_fdfminimizer_type) -> Ptr (FunPtr (Ptr () -> IO ()))
instance Storable C'gsl_multimin_fdfminimizer_type where
sizeOf _ = 28
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
v5 <- peekByteOff p 20
v6 <- peekByteOff p 24
return $ C'gsl_multimin_fdfminimizer_type v0 v1 v2 v3 v4 v5 v6
poke p (C'gsl_multimin_fdfminimizer_type 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 ()
data C'gsl_multimin_fdfminimizer = C'gsl_multimin_fdfminimizer{
c'gsl_multimin_fdfminimizer'type :: Ptr C'gsl_multimin_fdfminimizer_type,
c'gsl_multimin_fdfminimizer'fdf :: Ptr C'gsl_multimin_function_fdf,
c'gsl_multimin_fdfminimizer'f :: CDouble,
c'gsl_multimin_fdfminimizer'x :: Ptr C'gsl_vector,
c'gsl_multimin_fdfminimizer'gradient :: Ptr C'gsl_vector,
c'gsl_multimin_fdfminimizer'dx :: Ptr C'gsl_vector,
c'gsl_multimin_fdfminimizer'state :: Ptr ()
} deriving (Eq,Show)
p'gsl_multimin_fdfminimizer'type p = plusPtr p 0
p'gsl_multimin_fdfminimizer'type :: Ptr (C'gsl_multimin_fdfminimizer) -> Ptr (Ptr C'gsl_multimin_fdfminimizer_type)
p'gsl_multimin_fdfminimizer'fdf p = plusPtr p 4
p'gsl_multimin_fdfminimizer'fdf :: Ptr (C'gsl_multimin_fdfminimizer) -> Ptr (Ptr C'gsl_multimin_function_fdf)
p'gsl_multimin_fdfminimizer'f p = plusPtr p 8
p'gsl_multimin_fdfminimizer'f :: Ptr (C'gsl_multimin_fdfminimizer) -> Ptr (CDouble)
p'gsl_multimin_fdfminimizer'x p = plusPtr p 16
p'gsl_multimin_fdfminimizer'x :: Ptr (C'gsl_multimin_fdfminimizer) -> Ptr (Ptr C'gsl_vector)
p'gsl_multimin_fdfminimizer'gradient p = plusPtr p 20
p'gsl_multimin_fdfminimizer'gradient :: Ptr (C'gsl_multimin_fdfminimizer) -> Ptr (Ptr C'gsl_vector)
p'gsl_multimin_fdfminimizer'dx p = plusPtr p 24
p'gsl_multimin_fdfminimizer'dx :: Ptr (C'gsl_multimin_fdfminimizer) -> Ptr (Ptr C'gsl_vector)
p'gsl_multimin_fdfminimizer'state p = plusPtr p 28
p'gsl_multimin_fdfminimizer'state :: Ptr (C'gsl_multimin_fdfminimizer) -> Ptr (Ptr ())
instance Storable C'gsl_multimin_fdfminimizer where
sizeOf _ = 32
alignment _ = 4
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
v3 <- peekByteOff p 16
v4 <- peekByteOff p 20
v5 <- peekByteOff p 24
v6 <- peekByteOff p 28
return $ C'gsl_multimin_fdfminimizer v0 v1 v2 v3 v4 v5 v6
poke p (C'gsl_multimin_fdfminimizer v0 v1 v2 v3 v4 v5 v6) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
pokeByteOff p 16 v3
pokeByteOff p 20 v4
pokeByteOff p 24 v5
pokeByteOff p 28 v6
return ()
foreign import ccall "gsl_multimin_fdfminimizer_alloc" c'gsl_multimin_fdfminimizer_alloc
:: Ptr C'gsl_multimin_fdfminimizer_type -> CSize -> IO (Ptr C'gsl_multimin_fdfminimizer)
foreign import ccall "&gsl_multimin_fdfminimizer_alloc" p'gsl_multimin_fdfminimizer_alloc
:: FunPtr (Ptr C'gsl_multimin_fdfminimizer_type -> CSize -> IO (Ptr C'gsl_multimin_fdfminimizer))
foreign import ccall "gsl_multimin_fdfminimizer_set" c'gsl_multimin_fdfminimizer_set
:: Ptr C'gsl_multimin_fdfminimizer -> Ptr C'gsl_multimin_function_fdf -> Ptr C'gsl_vector -> CDouble -> CDouble -> IO CInt
foreign import ccall "&gsl_multimin_fdfminimizer_set" p'gsl_multimin_fdfminimizer_set
:: FunPtr (Ptr C'gsl_multimin_fdfminimizer -> Ptr C'gsl_multimin_function_fdf -> Ptr C'gsl_vector -> CDouble -> CDouble -> IO CInt)
foreign import ccall "gsl_multimin_fdfminimizer_free" c'gsl_multimin_fdfminimizer_free
:: Ptr C'gsl_multimin_fdfminimizer -> IO ()
foreign import ccall "&gsl_multimin_fdfminimizer_free" p'gsl_multimin_fdfminimizer_free
:: FunPtr (Ptr C'gsl_multimin_fdfminimizer -> IO ())
foreign import ccall "gsl_multimin_fdfminimizer_name" c'gsl_multimin_fdfminimizer_name
:: Ptr C'gsl_multimin_fdfminimizer -> IO CString
foreign import ccall "&gsl_multimin_fdfminimizer_name" p'gsl_multimin_fdfminimizer_name
:: FunPtr (Ptr C'gsl_multimin_fdfminimizer -> IO CString)
foreign import ccall "gsl_multimin_fdfminimizer_iterate" c'gsl_multimin_fdfminimizer_iterate
:: Ptr C'gsl_multimin_fdfminimizer -> IO CInt
foreign import ccall "&gsl_multimin_fdfminimizer_iterate" p'gsl_multimin_fdfminimizer_iterate
:: FunPtr (Ptr C'gsl_multimin_fdfminimizer -> IO CInt)
foreign import ccall "gsl_multimin_fdfminimizer_restart" c'gsl_multimin_fdfminimizer_restart
:: Ptr C'gsl_multimin_fdfminimizer -> IO CInt
foreign import ccall "&gsl_multimin_fdfminimizer_restart" p'gsl_multimin_fdfminimizer_restart
:: FunPtr (Ptr C'gsl_multimin_fdfminimizer -> IO CInt)
foreign import ccall "gsl_multimin_fdfminimizer_x" c'gsl_multimin_fdfminimizer_x
:: Ptr C'gsl_multimin_fdfminimizer -> IO (Ptr C'gsl_vector)
foreign import ccall "&gsl_multimin_fdfminimizer_x" p'gsl_multimin_fdfminimizer_x
:: FunPtr (Ptr C'gsl_multimin_fdfminimizer -> IO (Ptr C'gsl_vector))
foreign import ccall "gsl_multimin_fdfminimizer_dx" c'gsl_multimin_fdfminimizer_dx
:: Ptr C'gsl_multimin_fdfminimizer -> IO (Ptr C'gsl_vector)
foreign import ccall "&gsl_multimin_fdfminimizer_dx" p'gsl_multimin_fdfminimizer_dx
:: FunPtr (Ptr C'gsl_multimin_fdfminimizer -> IO (Ptr C'gsl_vector))
foreign import ccall "gsl_multimin_fdfminimizer_gradient" c'gsl_multimin_fdfminimizer_gradient
:: Ptr C'gsl_multimin_fdfminimizer -> IO (Ptr C'gsl_vector)
foreign import ccall "&gsl_multimin_fdfminimizer_gradient" p'gsl_multimin_fdfminimizer_gradient
:: FunPtr (Ptr C'gsl_multimin_fdfminimizer -> IO (Ptr C'gsl_vector))
foreign import ccall "gsl_multimin_fdfminimizer_minimum" c'gsl_multimin_fdfminimizer_minimum
:: Ptr C'gsl_multimin_fdfminimizer -> IO CDouble
foreign import ccall "&gsl_multimin_fdfminimizer_minimum" p'gsl_multimin_fdfminimizer_minimum
:: FunPtr (Ptr C'gsl_multimin_fdfminimizer -> IO CDouble)
foreign import ccall "&gsl_multimin_fdfminimizer_steepest_descent" p'gsl_multimin_fdfminimizer_steepest_descent
:: Ptr (Ptr gsl_multimin_fdfminimizer_type)
foreign import ccall "&gsl_multimin_fdfminimizer_conjugate_pr" p'gsl_multimin_fdfminimizer_conjugate_pr
:: Ptr (Ptr gsl_multimin_fdfminimizer_type)
foreign import ccall "&gsl_multimin_fdfminimizer_conjugate_fr" p'gsl_multimin_fdfminimizer_conjugate_fr
:: Ptr (Ptr gsl_multimin_fdfminimizer_type)
foreign import ccall "&gsl_multimin_fdfminimizer_vector_bfgs" p'gsl_multimin_fdfminimizer_vector_bfgs
:: Ptr (Ptr gsl_multimin_fdfminimizer_type)
foreign import ccall "&gsl_multimin_fdfminimizer_vector_bfgs2" p'gsl_multimin_fdfminimizer_vector_bfgs2
:: Ptr (Ptr gsl_multimin_fdfminimizer_type)
foreign import ccall "&gsl_multimin_fminimizer_nmsimplex" p'gsl_multimin_fminimizer_nmsimplex
:: Ptr (Ptr gsl_multimin_fminimizer_type)
foreign import ccall "&gsl_multimin_fminimizer_nmsimplex2" p'gsl_multimin_fminimizer_nmsimplex2
:: Ptr (Ptr gsl_multimin_fminimizer_type)