module CV.Bindings.Core where
import Foreign.C.Types
import CV.Bindings.Types
import CV.Image(BareImage)
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
foreign import ccall "wrapSet" c'wrapSet
:: Ptr C'CvArr -> Ptr C'CvScalar -> Ptr C'CvArr -> IO ()
foreign import ccall "&wrapSet" p'wrapSet
:: FunPtr (Ptr C'CvArr -> Ptr C'CvScalar -> Ptr C'CvArr -> IO ())
foreign import ccall "wrapSetAll" c'wrapSetAll
:: Ptr C'CvArr -> CDouble -> Ptr C'CvArr -> IO ()
foreign import ccall "&wrapSetAll" p'wrapSetAll
:: FunPtr (Ptr C'CvArr -> CDouble -> Ptr C'CvArr -> IO ())
foreign import ccall "wrapSet1" c'wrapSet1
:: Ptr C'CvArr -> CDouble -> Ptr C'CvArr -> IO ()
foreign import ccall "&wrapSet1" p'wrapSet1
:: FunPtr (Ptr C'CvArr -> CDouble -> Ptr C'CvArr -> IO ())
foreign import ccall "wrapSet2" c'wrapSet2
:: Ptr C'CvArr -> CDouble -> CDouble -> Ptr C'CvArr -> IO ()
foreign import ccall "&wrapSet2" p'wrapSet2
:: FunPtr (Ptr C'CvArr -> CDouble -> CDouble -> Ptr C'CvArr -> IO ())
foreign import ccall "wrapSet3" c'wrapSet3
:: Ptr C'CvArr -> CDouble -> CDouble -> CDouble -> Ptr C'CvArr -> IO ()
foreign import ccall "&wrapSet3" p'wrapSet3
:: FunPtr (Ptr C'CvArr -> CDouble -> CDouble -> CDouble -> Ptr C'CvArr -> IO ())
foreign import ccall "wrapSet4" c'wrapSet4
:: Ptr C'CvArr -> CDouble -> CDouble -> CDouble -> CDouble -> Ptr C'CvArr -> IO ()
foreign import ccall "&wrapSet4" p'wrapSet4
:: FunPtr (Ptr C'CvArr -> CDouble -> CDouble -> CDouble -> CDouble -> Ptr C'CvArr -> IO ())
foreign import ccall "cvSetZero" c'cvSetZero
:: Ptr BareImage -> IO ()
foreign import ccall "&cvSetZero" p'cvSetZero
:: FunPtr (Ptr BareImage -> IO ())
foreign import ccall "cvSplit" c'cvSplit
:: Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> IO ()
foreign import ccall "&cvSplit" p'cvSplit
:: FunPtr (Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> IO ())
foreign import ccall "cvMerge" c'cvMerge
:: Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> IO ()
foreign import ccall "&cvMerge" p'cvMerge
:: FunPtr (Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> IO ())
foreign import ccall "cvCartToPolar" c'cvCartToPolar
:: Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> CInt -> IO ()
foreign import ccall "&cvCartToPolar" p'cvCartToPolar
:: FunPtr (Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> CInt -> IO ())
foreign import ccall "cvPolarToCart" c'cvPolarToCart
:: Ptr C'CvArr -> Ptr C'CvArr -> Ptr C'CvArr -> Ptr C'CvArr -> CInt -> IO ()
foreign import ccall "&cvPolarToCart" p'cvPolarToCart
:: FunPtr (Ptr C'CvArr -> Ptr C'CvArr -> Ptr C'CvArr -> Ptr C'CvArr -> CInt -> IO ())
foreign import ccall "cvMinMaxLoc" c'cvMinMaxLoc
:: Ptr C'CvArr -> Ptr CDouble -> Ptr CDouble -> Ptr C'CvPoint -> Ptr C'CvPoint -> Ptr C'CvArr -> IO ()
foreign import ccall "&cvMinMaxLoc" p'cvMinMaxLoc
:: FunPtr (Ptr C'CvArr -> Ptr CDouble -> Ptr CDouble -> Ptr C'CvPoint -> Ptr C'CvPoint -> Ptr C'CvArr -> IO ())
foreign import ccall "cvAvgSdv" c'cvAvgSdv
:: Ptr BareImage -> Ptr C'CvScalar -> Ptr C'CvScalar -> Ptr C'CvArr -> IO ()
foreign import ccall "&cvAvgSdv" p'cvAvgSdv
:: FunPtr (Ptr BareImage -> Ptr C'CvScalar -> Ptr C'CvScalar -> Ptr C'CvArr -> IO ())
c'CV_C = 1
c'CV_C :: (Num a) => a
c'CV_L1 = 2
c'CV_L1 :: (Num a) => a
c'CV_L2 = 4
c'CV_L2 :: (Num a) => a
c'CV_NORM_MASK = 7
c'CV_NORM_MASK :: (Num a) => a
c'CV_RELATIVE = 8
c'CV_RELATIVE :: (Num a) => a
c'CV_DIFF = 16
c'CV_DIFF :: (Num a) => a
c'CV_MINMAX = 32
c'CV_MINMAX :: (Num a) => a
c'CV_DIFF_C = 17
c'CV_DIFF_C :: (Num a) => a
c'CV_DIFF_L1 = 18
c'CV_DIFF_L1 :: (Num a) => a
c'CV_DIFF_L2 = 20
c'CV_DIFF_L2 :: (Num a) => a
c'CV_RELATIVE_C = 9
c'CV_RELATIVE_C :: (Num a) => a
c'CV_RELATIVE_L1 = 10
c'CV_RELATIVE_L1 :: (Num a) => a
c'CV_RELATIVE_L2 = 12
c'CV_RELATIVE_L2 :: (Num a) => a
foreign import ccall "cvNormalize" c'cvNormalize
:: Ptr BareImage -> Ptr BareImage -> CDouble -> CDouble -> CInt -> Ptr BareImage -> IO ()
foreign import ccall "&cvNormalize" p'cvNormalize
:: FunPtr (Ptr BareImage -> Ptr BareImage -> CDouble -> CDouble -> CInt -> Ptr BareImage -> IO ())
c'CV_DXT_FORWARD = 0
c'CV_DXT_FORWARD :: (Num a) => a
c'CV_DXT_INVERSE = 1
c'CV_DXT_INVERSE :: (Num a) => a
c'CV_DXT_SCALE = 2
c'CV_DXT_SCALE :: (Num a) => a
c'CV_DXT_INV_SCALE = 3
c'CV_DXT_INV_SCALE :: (Num a) => a
c'CV_DXT_ROWS = 4
c'CV_DXT_ROWS :: (Num a) => a
c'CV_DXT_MUL_CONJ = 8
c'CV_DXT_MUL_CONJ :: (Num a) => a
c'CV_DXT_COMPLEX_OUTPUT = 16
c'CV_DXT_COMPLEX_OUTPUT :: (Num a) => a
c'CV_DXT_REAL_OUTPUT = 32
c'CV_DXT_REAL_OUTPUT :: (Num a) => a
c'CV_DXT_INV_REAL = 33
c'CV_DXT_INV_REAL :: (Num a) => a
c'CV_DXT_INVERSE_SCALE = 3
c'CV_DXT_INVERSE_SCALE :: (Num a) => a
foreign import ccall "cvDFT" c'cvDFT
:: Ptr BareImage -> Ptr BareImage -> CInt -> CInt -> IO ()
foreign import ccall "&cvDFT" p'cvDFT
:: FunPtr (Ptr BareImage -> Ptr BareImage -> CInt -> CInt -> IO ())
foreign import ccall "cvMulSpectrums" c'cvMulSpectrums
:: Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> CInt -> IO ()
foreign import ccall "&cvMulSpectrums" p'cvMulSpectrums
:: FunPtr (Ptr BareImage -> Ptr BareImage -> Ptr BareImage -> CInt -> IO ())
foreign import ccall "cvGetOptimalDFTSize" c'cvGetOptimalDFTSize
:: CInt -> CInt
foreign import ccall "&cvGetOptimalDFTSize" p'cvGetOptimalDFTSize
:: FunPtr (CInt -> CInt)
foreign import ccall "cvDCT" c'cvDCT
:: Ptr BareImage -> Ptr BareImage -> CInt -> IO ()
foreign import ccall "&cvDCT" p'cvDCT
:: FunPtr (Ptr BareImage -> Ptr BareImage -> CInt -> IO ())
data C'CvSeq = C'CvSeq