module Bindings.Gsl.OneDimensionalRootFinding 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.MathematicalFunctions
data C'gsl_root_fsolver_type = C'gsl_root_fsolver_type{
c'gsl_root_fsolver_type'name :: CString,
c'gsl_root_fsolver_type'size :: CSize,
c'gsl_root_fsolver_type'set :: FunPtr (Ptr () -> Ptr C'gsl_function -> Ptr CDouble -> CDouble -> CDouble -> IO CInt),
c'gsl_root_fsolver_type'iterate :: FunPtr (Ptr () -> Ptr C'gsl_function -> Ptr CDouble -> Ptr CDouble -> Ptr CDouble -> IO CInt)
} deriving (Eq,Show)
p'gsl_root_fsolver_type'name p = plusPtr p 0
p'gsl_root_fsolver_type'name :: Ptr (C'gsl_root_fsolver_type) -> Ptr (CString)
p'gsl_root_fsolver_type'size p = plusPtr p 4
p'gsl_root_fsolver_type'size :: Ptr (C'gsl_root_fsolver_type) -> Ptr (CSize)
p'gsl_root_fsolver_type'set p = plusPtr p 8
p'gsl_root_fsolver_type'set :: Ptr (C'gsl_root_fsolver_type) -> Ptr (FunPtr (Ptr () -> Ptr C'gsl_function -> Ptr CDouble -> CDouble -> CDouble -> IO CInt))
p'gsl_root_fsolver_type'iterate p = plusPtr p 12
p'gsl_root_fsolver_type'iterate :: Ptr (C'gsl_root_fsolver_type) -> Ptr (FunPtr (Ptr () -> Ptr C'gsl_function -> Ptr CDouble -> Ptr CDouble -> Ptr CDouble -> IO CInt))
instance Storable C'gsl_root_fsolver_type 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_root_fsolver_type v0 v1 v2 v3
poke p (C'gsl_root_fsolver_type v0 v1 v2 v3) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
pokeByteOff p 12 v3
return ()
data C'gsl_root_fsolver = C'gsl_root_fsolver{
c'gsl_root_fsolver'type :: Ptr C'gsl_root_fsolver_type,
c'gsl_root_fsolver'function :: Ptr C'gsl_function,
c'gsl_root_fsolver'root :: CDouble,
c'gsl_root_fsolver'x_lower :: CDouble,
c'gsl_root_fsolver'x_upper :: CDouble,
c'gsl_root_fsolver'state :: Ptr ()
} deriving (Eq,Show)
p'gsl_root_fsolver'type p = plusPtr p 0
p'gsl_root_fsolver'type :: Ptr (C'gsl_root_fsolver) -> Ptr (Ptr C'gsl_root_fsolver_type)
p'gsl_root_fsolver'function p = plusPtr p 4
p'gsl_root_fsolver'function :: Ptr (C'gsl_root_fsolver) -> Ptr (Ptr C'gsl_function)
p'gsl_root_fsolver'root p = plusPtr p 8
p'gsl_root_fsolver'root :: Ptr (C'gsl_root_fsolver) -> Ptr (CDouble)
p'gsl_root_fsolver'x_lower p = plusPtr p 16
p'gsl_root_fsolver'x_lower :: Ptr (C'gsl_root_fsolver) -> Ptr (CDouble)
p'gsl_root_fsolver'x_upper p = plusPtr p 24
p'gsl_root_fsolver'x_upper :: Ptr (C'gsl_root_fsolver) -> Ptr (CDouble)
p'gsl_root_fsolver'state p = plusPtr p 32
p'gsl_root_fsolver'state :: Ptr (C'gsl_root_fsolver) -> Ptr (Ptr ())
instance Storable C'gsl_root_fsolver where
sizeOf _ = 36
alignment _ = 4
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
v3 <- peekByteOff p 16
v4 <- peekByteOff p 24
v5 <- peekByteOff p 32
return $ C'gsl_root_fsolver v0 v1 v2 v3 v4 v5
poke p (C'gsl_root_fsolver 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 24 v4
pokeByteOff p 32 v5
return ()
data C'gsl_root_fdfsolver_type = C'gsl_root_fdfsolver_type{
c'gsl_root_fdfsolver_type'name :: CString,
c'gsl_root_fdfsolver_type'size :: CSize,
c'gsl_root_fdfsolver_type'set :: FunPtr (Ptr () -> Ptr C'gsl_function_fdf -> Ptr CDouble -> IO CInt),
c'gsl_root_fdfsolver_type'iterate :: FunPtr (Ptr () -> Ptr C'gsl_function_fdf -> Ptr CDouble -> IO CInt)
} deriving (Eq,Show)
p'gsl_root_fdfsolver_type'name p = plusPtr p 0
p'gsl_root_fdfsolver_type'name :: Ptr (C'gsl_root_fdfsolver_type) -> Ptr (CString)
p'gsl_root_fdfsolver_type'size p = plusPtr p 4
p'gsl_root_fdfsolver_type'size :: Ptr (C'gsl_root_fdfsolver_type) -> Ptr (CSize)
p'gsl_root_fdfsolver_type'set p = plusPtr p 8
p'gsl_root_fdfsolver_type'set :: Ptr (C'gsl_root_fdfsolver_type) -> Ptr (FunPtr (Ptr () -> Ptr C'gsl_function_fdf -> Ptr CDouble -> IO CInt))
p'gsl_root_fdfsolver_type'iterate p = plusPtr p 12
p'gsl_root_fdfsolver_type'iterate :: Ptr (C'gsl_root_fdfsolver_type) -> Ptr (FunPtr (Ptr () -> Ptr C'gsl_function_fdf -> Ptr CDouble -> IO CInt))
instance Storable C'gsl_root_fdfsolver_type 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_root_fdfsolver_type v0 v1 v2 v3
poke p (C'gsl_root_fdfsolver_type v0 v1 v2 v3) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
pokeByteOff p 12 v3
return ()
data C'gsl_root_fdfsolver = C'gsl_root_fdfsolver{
c'gsl_root_fdfsolver'type :: Ptr C'gsl_root_fdfsolver_type,
c'gsl_root_fdfsolver'fdf :: Ptr C'gsl_function_fdf,
c'gsl_root_fdfsolver'root :: CDouble,
c'gsl_root_fdfsolver'state :: Ptr ()
} deriving (Eq,Show)
p'gsl_root_fdfsolver'type p = plusPtr p 0
p'gsl_root_fdfsolver'type :: Ptr (C'gsl_root_fdfsolver) -> Ptr (Ptr C'gsl_root_fdfsolver_type)
p'gsl_root_fdfsolver'fdf p = plusPtr p 4
p'gsl_root_fdfsolver'fdf :: Ptr (C'gsl_root_fdfsolver) -> Ptr (Ptr C'gsl_function_fdf)
p'gsl_root_fdfsolver'root p = plusPtr p 8
p'gsl_root_fdfsolver'root :: Ptr (C'gsl_root_fdfsolver) -> Ptr (CDouble)
p'gsl_root_fdfsolver'state p = plusPtr p 16
p'gsl_root_fdfsolver'state :: Ptr (C'gsl_root_fdfsolver) -> Ptr (Ptr ())
instance Storable C'gsl_root_fdfsolver where
sizeOf _ = 20
alignment _ = 4
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
v3 <- peekByteOff p 16
return $ C'gsl_root_fdfsolver v0 v1 v2 v3
poke p (C'gsl_root_fdfsolver v0 v1 v2 v3) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
pokeByteOff p 16 v3
return ()
foreign import ccall "gsl_root_fsolver_alloc" c'gsl_root_fsolver_alloc
:: Ptr C'gsl_root_fsolver_type -> IO (Ptr C'gsl_root_fsolver)
foreign import ccall "&gsl_root_fsolver_alloc" p'gsl_root_fsolver_alloc
:: FunPtr (Ptr C'gsl_root_fsolver_type -> IO (Ptr C'gsl_root_fsolver))
foreign import ccall "gsl_root_fsolver_free" c'gsl_root_fsolver_free
:: Ptr C'gsl_root_fsolver -> IO ()
foreign import ccall "&gsl_root_fsolver_free" p'gsl_root_fsolver_free
:: FunPtr (Ptr C'gsl_root_fsolver -> IO ())
foreign import ccall "gsl_root_fsolver_set" c'gsl_root_fsolver_set
:: Ptr C'gsl_root_fsolver -> Ptr C'gsl_function -> CDouble -> CDouble -> IO CInt
foreign import ccall "&gsl_root_fsolver_set" p'gsl_root_fsolver_set
:: FunPtr (Ptr C'gsl_root_fsolver -> Ptr C'gsl_function -> CDouble -> CDouble -> IO CInt)
foreign import ccall "gsl_root_fsolver_iterate" c'gsl_root_fsolver_iterate
:: Ptr C'gsl_root_fsolver -> IO CInt
foreign import ccall "&gsl_root_fsolver_iterate" p'gsl_root_fsolver_iterate
:: FunPtr (Ptr C'gsl_root_fsolver -> IO CInt)
foreign import ccall "gsl_root_fsolver_name" c'gsl_root_fsolver_name
:: Ptr C'gsl_root_fsolver -> IO CString
foreign import ccall "&gsl_root_fsolver_name" p'gsl_root_fsolver_name
:: FunPtr (Ptr C'gsl_root_fsolver -> IO CString)
foreign import ccall "gsl_root_fsolver_root" c'gsl_root_fsolver_root
:: Ptr C'gsl_root_fsolver -> IO CDouble
foreign import ccall "&gsl_root_fsolver_root" p'gsl_root_fsolver_root
:: FunPtr (Ptr C'gsl_root_fsolver -> IO CDouble)
foreign import ccall "gsl_root_fsolver_x_lower" c'gsl_root_fsolver_x_lower
:: Ptr C'gsl_root_fsolver -> IO CDouble
foreign import ccall "&gsl_root_fsolver_x_lower" p'gsl_root_fsolver_x_lower
:: FunPtr (Ptr C'gsl_root_fsolver -> IO CDouble)
foreign import ccall "gsl_root_fsolver_x_upper" c'gsl_root_fsolver_x_upper
:: Ptr C'gsl_root_fsolver -> IO CDouble
foreign import ccall "&gsl_root_fsolver_x_upper" p'gsl_root_fsolver_x_upper
:: FunPtr (Ptr C'gsl_root_fsolver -> IO CDouble)
foreign import ccall "gsl_root_fdfsolver_alloc" c'gsl_root_fdfsolver_alloc
:: Ptr C'gsl_root_fdfsolver_type -> IO (Ptr C'gsl_root_fdfsolver)
foreign import ccall "&gsl_root_fdfsolver_alloc" p'gsl_root_fdfsolver_alloc
:: FunPtr (Ptr C'gsl_root_fdfsolver_type -> IO (Ptr C'gsl_root_fdfsolver))
foreign import ccall "gsl_root_fdfsolver_set" c'gsl_root_fdfsolver_set
:: Ptr C'gsl_root_fdfsolver -> Ptr C'gsl_function_fdf -> CDouble -> IO CInt
foreign import ccall "&gsl_root_fdfsolver_set" p'gsl_root_fdfsolver_set
:: FunPtr (Ptr C'gsl_root_fdfsolver -> Ptr C'gsl_function_fdf -> CDouble -> IO CInt)
foreign import ccall "gsl_root_fdfsolver_iterate" c'gsl_root_fdfsolver_iterate
:: Ptr C'gsl_root_fdfsolver -> IO CInt
foreign import ccall "&gsl_root_fdfsolver_iterate" p'gsl_root_fdfsolver_iterate
:: FunPtr (Ptr C'gsl_root_fdfsolver -> IO CInt)
foreign import ccall "gsl_root_fdfsolver_free" c'gsl_root_fdfsolver_free
:: Ptr C'gsl_root_fdfsolver -> IO ()
foreign import ccall "&gsl_root_fdfsolver_free" p'gsl_root_fdfsolver_free
:: FunPtr (Ptr C'gsl_root_fdfsolver -> IO ())
foreign import ccall "gsl_root_fdfsolver_name" c'gsl_root_fdfsolver_name
:: Ptr C'gsl_root_fdfsolver -> IO CString
foreign import ccall "&gsl_root_fdfsolver_name" p'gsl_root_fdfsolver_name
:: FunPtr (Ptr C'gsl_root_fdfsolver -> IO CString)
foreign import ccall "gsl_root_fdfsolver_root" c'gsl_root_fdfsolver_root
:: Ptr C'gsl_root_fdfsolver -> IO CDouble
foreign import ccall "&gsl_root_fdfsolver_root" p'gsl_root_fdfsolver_root
:: FunPtr (Ptr C'gsl_root_fdfsolver -> IO CDouble)
foreign import ccall "gsl_root_test_interval" c'gsl_root_test_interval
:: CDouble -> CDouble -> CDouble -> CDouble -> IO CInt
foreign import ccall "&gsl_root_test_interval" p'gsl_root_test_interval
:: FunPtr (CDouble -> CDouble -> CDouble -> CDouble -> IO CInt)
foreign import ccall "gsl_root_test_residual" c'gsl_root_test_residual
:: CDouble -> CDouble -> IO CInt
foreign import ccall "&gsl_root_test_residual" p'gsl_root_test_residual
:: FunPtr (CDouble -> CDouble -> IO CInt)
foreign import ccall "gsl_root_test_delta" c'gsl_root_test_delta
:: CDouble -> CDouble -> CDouble -> CDouble -> IO CInt
foreign import ccall "&gsl_root_test_delta" p'gsl_root_test_delta
:: FunPtr (CDouble -> CDouble -> CDouble -> CDouble -> IO CInt)
foreign import ccall "&gsl_root_fsolver_bisection" p'gsl_root_fsolver_bisection
:: Ptr (Ptr C'gsl_root_fsolver_type)
foreign import ccall "&gsl_root_fsolver_brent" p'gsl_root_fsolver_brent
:: Ptr (Ptr C'gsl_root_fsolver_type)
foreign import ccall "&gsl_root_fsolver_falsepos" p'gsl_root_fsolver_falsepos
:: Ptr (Ptr C'gsl_root_fsolver_type)
foreign import ccall "&gsl_root_fdfsolver_newton" p'gsl_root_fdfsolver_newton
:: Ptr (Ptr C'gsl_root_fdfsolver_type)
foreign import ccall "&gsl_root_fdfsolver_secant" p'gsl_root_fdfsolver_secant
:: Ptr (Ptr C'gsl_root_fdfsolver_type)
foreign import ccall "&gsl_root_fdfsolver_steffenson" p'gsl_root_fdfsolver_steffenson
:: Ptr (Ptr C'gsl_root_fdfsolver_type)