{-# INCLUDE <bindings.dsl.h> #-}
{-# INCLUDE <gsl/gsl_wavelet.h> #-}
{-# INCLUDE <gsl/gsl_wavelet2d.h> #-}
{-# LINE 1 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}

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

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

{-# LINE 4 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}

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

module Bindings.Gsl.WaveletTransforms 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.Array (peekArray,pokeArray)
import Data.Int
import Data.Word

{-# LINE 9 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
import Bindings.Gsl.VectorsAndMatrices.DataTypes

type C'gsl_wavelet_direction = CInt

{-# LINE 12 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}

c'gsl_wavelet_forward = 1
c'gsl_wavelet_forward :: (Num a) => a

{-# LINE 14 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
c'gsl_wavelet_backward = -1
c'gsl_wavelet_backward :: (Num a) => a

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

data C'gsl_wavelet_type = C'gsl_wavelet_type{
{-# LINE 17 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}

  c'gsl_wavelet_type'name :: CString
{-# LINE 18 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
,
  c'gsl_wavelet_type'init :: FunPtr ( Ptr (Ptr CDouble) -> Ptr (Ptr CDouble) -> Ptr (Ptr CDouble) -> Ptr (Ptr CDouble) -> Ptr CSize -> Ptr CSize -> CSize -> IO CInt)
{-# LINE 19 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}

 } deriving (Eq,Show)
instance Storable C'gsl_wavelet_type where
  sizeOf _ = 8
  alignment = sizeOf
  peek p = do
    v0 <- peekByteOff p 0
    v1 <- peekByteOff p 4
    return $ C'gsl_wavelet_type v0 v1
  poke p (C'gsl_wavelet_type v0 v1) = do
    pokeByteOff p 0 v0
    pokeByteOff p 4 v1
    return ()

{-# LINE 20 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}

data C'gsl_wavelet = C'gsl_wavelet{
{-# LINE 22 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}

  c'gsl_wavelet'type :: Ptr C'gsl_wavelet_type
{-# LINE 23 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
,
  c'gsl_wavelet'h1 :: Ptr CDouble
{-# LINE 24 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
,
  c'gsl_wavelet'g1 :: Ptr CDouble
{-# LINE 25 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
,
  c'gsl_wavelet'h2 :: Ptr CDouble
{-# LINE 26 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
,
  c'gsl_wavelet'g2 :: Ptr CDouble
{-# LINE 27 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
,
  c'gsl_wavelet'nc :: CSize
{-# LINE 28 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
,
  c'gsl_wavelet'offset :: CSize
{-# LINE 29 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}

 } deriving (Eq,Show)
instance Storable C'gsl_wavelet 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_wavelet v0 v1 v2 v3 v4 v5 v6
  poke p (C'gsl_wavelet 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 30 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}

data C'gsl_wavelet_workspace = C'gsl_wavelet_workspace{
{-# LINE 32 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}

  c'gsl_wavelet_workspace'scratch :: Ptr CDouble
{-# LINE 33 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
,
  c'gsl_wavelet_workspace'n :: CSize
{-# LINE 34 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}

 } deriving (Eq,Show)
instance Storable C'gsl_wavelet_workspace where
  sizeOf _ = 8
  alignment = sizeOf
  peek p = do
    v0 <- peekByteOff p 0
    v1 <- peekByteOff p 4
    return $ C'gsl_wavelet_workspace v0 v1
  poke p (C'gsl_wavelet_workspace v0 v1) = do
    pokeByteOff p 0 v0
    pokeByteOff p 4 v1
    return ()

{-# LINE 35 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}

foreign import ccall "&gsl_wavelet_daubechies" p'gsl_wavelet_daubechies
  :: Ptr (Ptr gsl_wavelet_type)

{-# LINE 37 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "&gsl_wavelet_daubechies_centered" p'gsl_wavelet_daubechies_centered
  :: Ptr (Ptr gsl_wavelet_type)

{-# LINE 38 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "&gsl_wavelet_haar" p'gsl_wavelet_haar
  :: Ptr (Ptr gsl_wavelet_type)

{-# LINE 39 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "&gsl_wavelet_haar_centered" p'gsl_wavelet_haar_centered
  :: Ptr (Ptr gsl_wavelet_type)

{-# LINE 40 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "&gsl_wavelet_bspline" p'gsl_wavelet_bspline
  :: Ptr (Ptr gsl_wavelet_type)

{-# LINE 41 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "&gsl_wavelet_bspline_centered" p'gsl_wavelet_bspline_centered
  :: Ptr (Ptr gsl_wavelet_type)

{-# LINE 42 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}

foreign import ccall "gsl_wavelet_alloc" c'gsl_wavelet_alloc
  :: Ptr C'gsl_wavelet_type -> CSize -> IO (Ptr C'gsl_wavelet)
foreign import ccall "&gsl_wavelet_alloc" p'gsl_wavelet_alloc
  :: FunPtr (Ptr C'gsl_wavelet_type -> CSize -> IO (Ptr C'gsl_wavelet))

{-# LINE 44 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet_free" c'gsl_wavelet_free
  :: Ptr C'gsl_wavelet -> IO ()
foreign import ccall "&gsl_wavelet_free" p'gsl_wavelet_free
  :: FunPtr (Ptr C'gsl_wavelet -> IO ())

{-# LINE 45 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet_name" c'gsl_wavelet_name
  :: Ptr C'gsl_wavelet -> IO CString
foreign import ccall "&gsl_wavelet_name" p'gsl_wavelet_name
  :: FunPtr (Ptr C'gsl_wavelet -> IO CString)

{-# LINE 46 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet_workspace_alloc" c'gsl_wavelet_workspace_alloc
  :: CSize -> IO (Ptr C'gsl_wavelet_workspace)
foreign import ccall "&gsl_wavelet_workspace_alloc" p'gsl_wavelet_workspace_alloc
  :: FunPtr (CSize -> IO (Ptr C'gsl_wavelet_workspace))

{-# LINE 47 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet_workspace_free" c'gsl_wavelet_workspace_free
  :: Ptr C'gsl_wavelet_workspace -> IO ()
foreign import ccall "&gsl_wavelet_workspace_free" p'gsl_wavelet_workspace_free
  :: FunPtr (Ptr C'gsl_wavelet_workspace -> IO ())

{-# LINE 48 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet_transform" c'gsl_wavelet_transform
  :: Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> C'gsl_wavelet_direction -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet_transform" p'gsl_wavelet_transform
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> C'gsl_wavelet_direction -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 49 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet_transform_forward" c'gsl_wavelet_transform_forward
  :: Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet_transform_forward" p'gsl_wavelet_transform_forward
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 50 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet_transform_inverse" c'gsl_wavelet_transform_inverse
  :: Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet_transform_inverse" p'gsl_wavelet_transform_inverse
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 51 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet2d_transform" c'gsl_wavelet2d_transform
  :: Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> CSize -> C'gsl_wavelet_direction -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet2d_transform" p'gsl_wavelet2d_transform
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> CSize -> C'gsl_wavelet_direction -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 52 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet2d_transform_forward" c'gsl_wavelet2d_transform_forward
  :: Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> CSize -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet2d_transform_forward" p'gsl_wavelet2d_transform_forward
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> CSize -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 53 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet2d_transform_inverse" c'gsl_wavelet2d_transform_inverse
  :: Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> CSize -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet2d_transform_inverse" p'gsl_wavelet2d_transform_inverse
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> CSize -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 54 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet2d_nstransform" c'gsl_wavelet2d_nstransform
  :: Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> CSize -> C'gsl_wavelet_direction -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet2d_nstransform" p'gsl_wavelet2d_nstransform
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> CSize -> C'gsl_wavelet_direction -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 55 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet2d_nstransform_forward" c'gsl_wavelet2d_nstransform_forward
  :: Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> CSize -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet2d_nstransform_forward" p'gsl_wavelet2d_nstransform_forward
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> CSize -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 56 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet2d_nstransform_inverse" c'gsl_wavelet2d_nstransform_inverse
  :: Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> CSize -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet2d_nstransform_inverse" p'gsl_wavelet2d_nstransform_inverse
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr CDouble -> CSize -> CSize -> CSize -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 57 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet2d_transform_matrix" c'gsl_wavelet2d_transform_matrix
  :: Ptr C'gsl_wavelet -> Ptr C'gsl_matrix -> C'gsl_wavelet_direction -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet2d_transform_matrix" p'gsl_wavelet2d_transform_matrix
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr C'gsl_matrix -> C'gsl_wavelet_direction -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 58 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet2d_transform_matrix_forward" c'gsl_wavelet2d_transform_matrix_forward
  :: Ptr C'gsl_wavelet -> Ptr C'gsl_matrix -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet2d_transform_matrix_forward" p'gsl_wavelet2d_transform_matrix_forward
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr C'gsl_matrix -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 59 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet2d_transform_matrix_inverse" c'gsl_wavelet2d_transform_matrix_inverse
  :: Ptr C'gsl_wavelet -> Ptr C'gsl_matrix -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet2d_transform_matrix_inverse" p'gsl_wavelet2d_transform_matrix_inverse
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr C'gsl_matrix -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 60 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet2d_nstransform_matrix" c'gsl_wavelet2d_nstransform_matrix
  :: Ptr C'gsl_wavelet -> Ptr C'gsl_matrix -> C'gsl_wavelet_direction -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet2d_nstransform_matrix" p'gsl_wavelet2d_nstransform_matrix
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr C'gsl_matrix -> C'gsl_wavelet_direction -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 61 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet2d_nstransform_matrix_forward" c'gsl_wavelet2d_nstransform_matrix_forward
  :: Ptr C'gsl_wavelet -> Ptr C'gsl_matrix -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet2d_nstransform_matrix_forward" p'gsl_wavelet2d_nstransform_matrix_forward
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr C'gsl_matrix -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 62 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}
foreign import ccall "gsl_wavelet2d_nstransform_matrix_inverse" c'gsl_wavelet2d_nstransform_matrix_inverse
  :: Ptr C'gsl_wavelet -> Ptr C'gsl_matrix -> Ptr C'gsl_wavelet_workspace -> IO CInt
foreign import ccall "&gsl_wavelet2d_nstransform_matrix_inverse" p'gsl_wavelet2d_nstransform_matrix_inverse
  :: FunPtr (Ptr C'gsl_wavelet -> Ptr C'gsl_matrix -> Ptr C'gsl_wavelet_workspace -> IO CInt)

{-# LINE 63 "src/Bindings/Gsl/WaveletTransforms.hsc" #-}