{-# LINE 1 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

{-# LINE 2 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

{-# LINE 3 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

-- | <http://www.gnu.org/software/gsl/manual/html_node/Multidimensional-Root_002dFinding.html>

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

{-# LINE 8 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
import Bindings.Gsl.VectorsAndMatrices.DataTypes

data C'gsl_multiroot_function = C'gsl_multiroot_function{
{-# LINE 11 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

  c'gsl_multiroot_function'f :: FunPtr ( Ptr C'gsl_vector -> Ptr () -> Ptr C'gsl_vector -> IO CInt)
{-# LINE 12 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_function'n :: CSize
{-# LINE 13 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_function'params :: Ptr ()
{-# LINE 14 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

 } 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 ()

{-# LINE 15 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

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

{-# LINE 17 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

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)

{-# LINE 19 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

data C'gsl_multiroot_fsolver_type = C'gsl_multiroot_fsolver_type{
{-# LINE 21 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

  c'gsl_multiroot_fsolver_type'name :: CString
{-# LINE 22 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fsolver_type'size :: CSize
{-# LINE 23 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fsolver_type'alloc :: FunPtr (Ptr () -> CSize -> IO CInt)
{-# LINE 24 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  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)
{-# LINE 25 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  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)
{-# LINE 26 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fsolver_type'free :: FunPtr (Ptr () -> IO ())
{-# LINE 27 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

 } 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 ()

{-# LINE 28 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

data C'gsl_multiroot_fsolver = C'gsl_multiroot_fsolver{
{-# LINE 30 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

  c'gsl_multiroot_fsolver'type :: Ptr C'gsl_multiroot_fsolver_type
{-# LINE 31 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fsolver'function :: Ptr C'gsl_multiroot_function
{-# LINE 32 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fsolver'x :: Ptr C'gsl_vector
{-# LINE 33 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fsolver'f :: Ptr C'gsl_vector
{-# LINE 34 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fsolver'dx :: Ptr C'gsl_vector
{-# LINE 35 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fsolver'state :: Ptr ()
{-# LINE 36 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

 } 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 ()

{-# LINE 37 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

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))

{-# LINE 39 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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 ())

{-# LINE 40 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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)

{-# LINE 41 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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)

{-# LINE 42 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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)

{-# LINE 43 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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))

{-# LINE 44 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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))

{-# LINE 45 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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))

{-# LINE 46 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

data C'gsl_multiroot_function_fdf = C'gsl_multiroot_function_fdf{
{-# LINE 48 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

  c'gsl_multiroot_function_fdf'f :: FunPtr ( Ptr C'gsl_vector -> Ptr () -> Ptr C'gsl_vector -> IO CInt)
{-# LINE 49 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_function_fdf'df :: FunPtr ( Ptr C'gsl_vector -> Ptr () -> Ptr C'gsl_matrix -> IO CInt)
{-# LINE 50 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_function_fdf'fdf :: FunPtr ( Ptr C'gsl_vector -> Ptr () -> Ptr C'gsl_vector -> Ptr C'gsl_matrix -> IO CInt)
{-# LINE 51 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_function_fdf'n :: CSize
{-# LINE 52 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_function_fdf'params :: Ptr ()
{-# LINE 53 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

 } 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 ()

{-# LINE 54 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

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

{-# LINE 56 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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

{-# LINE 57 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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

{-# LINE 58 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

data C'gsl_multiroot_fdfsolver_type = C'gsl_multiroot_fdfsolver_type{
{-# LINE 60 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

  c'gsl_multiroot_fdfsolver_type'name :: CString
{-# LINE 61 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fdfsolver_type'size :: CSize
{-# LINE 62 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fdfsolver_type'alloc :: FunPtr (Ptr () -> CSize -> IO CInt)
{-# LINE 63 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  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)
{-# LINE 64 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  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)
{-# LINE 65 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fdfsolver_type'free :: FunPtr (Ptr () -> IO ())
{-# LINE 66 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

 } 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 ()

{-# LINE 67 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

data C'gsl_multiroot_fdfsolver = C'gsl_multiroot_fdfsolver{
{-# LINE 69 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

  c'gsl_multiroot_fdfsolver'type :: Ptr C'gsl_multiroot_fdfsolver_type
{-# LINE 70 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fdfsolver'fdf :: Ptr C'gsl_multiroot_function_fdf
{-# LINE 71 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fdfsolver'x :: Ptr C'gsl_vector
{-# LINE 72 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fdfsolver'f :: Ptr C'gsl_vector
{-# LINE 73 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fdfsolver'J :: Ptr C'gsl_matrix
{-# LINE 74 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fdfsolver'dx :: Ptr C'gsl_vector
{-# LINE 75 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
,
  c'gsl_multiroot_fdfsolver'state :: Ptr ()
{-# LINE 76 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

 } 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 ()

{-# LINE 77 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

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))

{-# LINE 79 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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)

{-# LINE 80 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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)

{-# LINE 81 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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 ())

{-# LINE 82 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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)

{-# LINE 83 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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))

{-# LINE 84 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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))

{-# LINE 85 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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))

{-# LINE 86 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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)

{-# LINE 87 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
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)

{-# LINE 88 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}

foreign import ccall "&gsl_multiroot_fsolver_dnewton" p'gsl_multiroot_fsolver_dnewton
  :: Ptr (Ptr gsl_multiroot_fsolver_type)

{-# LINE 90 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
foreign import ccall "&gsl_multiroot_fsolver_broyden" p'gsl_multiroot_fsolver_broyden
  :: Ptr (Ptr gsl_multiroot_fsolver_type)

{-# LINE 91 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
foreign import ccall "&gsl_multiroot_fsolver_hybrid" p'gsl_multiroot_fsolver_hybrid
  :: Ptr (Ptr gsl_multiroot_fsolver_type)

{-# LINE 92 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
foreign import ccall "&gsl_multiroot_fsolver_hybrids" p'gsl_multiroot_fsolver_hybrids
  :: Ptr (Ptr gsl_multiroot_fsolver_type)

{-# LINE 93 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
foreign import ccall "&gsl_multiroot_fdfsolver_newton" p'gsl_multiroot_fdfsolver_newton
  :: Ptr (Ptr gsl_multiroot_fdfsolver_type)

{-# LINE 94 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
foreign import ccall "&gsl_multiroot_fdfsolver_gnewton" p'gsl_multiroot_fdfsolver_gnewton
  :: Ptr (Ptr gsl_multiroot_fdfsolver_type)

{-# LINE 95 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
foreign import ccall "&gsl_multiroot_fdfsolver_hybridj" p'gsl_multiroot_fdfsolver_hybridj
  :: Ptr (Ptr gsl_multiroot_fdfsolver_type)

{-# LINE 96 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}
foreign import ccall "&gsl_multiroot_fdfsolver_hybridsj" p'gsl_multiroot_fdfsolver_hybridsj
  :: Ptr (Ptr gsl_multiroot_fdfsolver_type)

{-# LINE 97 "src/Bindings/Gsl/MultidimensionalRootFinding.hsc" #-}