{-# LINE 1 "src/Data/Number/Flint/Support/Mpf/Mat/FFI.hsc" #-}
module Data.Number.Flint.Support.Mpf.Mat.FFI (
  
    MpfMat (..)
  , CMpfMat (..)
  , newMpfMat
  , withMpfMat
  , withNewMpfMat
  
  , mpf_mat_init
  , mpf_mat_clear
  
  , mpf_mat_set
  , mpf_mat_swap
  , mpf_mat_swap_entrywise
  , mpf_mat_entry
  , mpf_mat_zero
  , mpf_mat_one
  
  , mpf_mat_randtest
  
  , mpf_mat_print
  
  , mpf_mat_equal
  , mpf_mat_approx_equal
  , mpf_mat_is_zero
  , mpf_mat_is_empty
  , mpf_mat_is_square
  
  , mpf_mat_mul
  
  , mpf_mat_gso
  , mpf_mat_qr
) where 
import Foreign.C.Types
import Foreign.Ptr
import Foreign.ForeignPtr
import Foreign.Storable
import Foreign.Marshal.Array
import Data.Number.Flint.Flint
data MpfMat = MpfMat {-# UNPACK #-} !(ForeignPtr CMpfMat)
data CMpfMat = CMpfMat (Ptr CMpf) CLong CLong (Ptr (Ptr CMpf))
instance Storable CMpfMat where
  {-# INLINE sizeOf #-}
  sizeOf :: CMpfMat -> Int
sizeOf CMpfMat
_ = (Int
40)
{-# LINE 62 "src/Data/Number/Flint/Support/Mpf/Mat/FFI.hsc" #-}
  {-# INLINE alignment #-}
  alignment :: CMpfMat -> Int
alignment CMpfMat
_ = Int
8
{-# LINE 64 "src/Data/Number/Flint/Support/Mpf/Mat/FFI.hsc" #-}
  peek ptr = CMpfMat
    <$> (\hsc_ptr -> peekByteOff hsc_ptr 0) ptr
{-# LINE 66 "src/Data/Number/Flint/Support/Mpf/Mat/FFI.hsc" #-}
    <*> (\hsc_ptr -> peekByteOff hsc_ptr 8) ptr
{-# LINE 67 "src/Data/Number/Flint/Support/Mpf/Mat/FFI.hsc" #-}
    <*> (\hsc_ptr -> peekByteOff hsc_ptr 16) ptr
{-# LINE 68 "src/Data/Number/Flint/Support/Mpf/Mat/FFI.hsc" #-}
    <*> (\hsc_ptr -> peekByteOff hsc_ptr 32) ptr
{-# LINE 69 "src/Data/Number/Flint/Support/Mpf/Mat/FFI.hsc" #-}
  poke = error "CMpfMat.poke: Not defined."
newMpfMat :: CLong -> CLong -> CFBitCnt -> IO MpfMat
newMpfMat CLong
rows CLong
cols CFBitCnt
prec = do
  ForeignPtr CMpfMat
x <- IO (ForeignPtr CMpfMat)
forall a. Storable a => IO (ForeignPtr a)
mallocForeignPtr
  ForeignPtr CMpfMat -> (Ptr CMpfMat -> IO ()) -> IO ()
forall a b. ForeignPtr a -> (Ptr a -> IO b) -> IO b
withForeignPtr ForeignPtr CMpfMat
x ((Ptr CMpfMat -> IO ()) -> IO ())
-> (Ptr CMpfMat -> IO ()) -> IO ()
forall a b. (a -> b) -> a -> b
$ \Ptr CMpfMat
x -> Ptr CMpfMat -> CLong -> CLong -> CFBitCnt -> IO ()
mpf_mat_init Ptr CMpfMat
x CLong
rows CLong
cols CFBitCnt
prec
  FinalizerPtr CMpfMat -> ForeignPtr CMpfMat -> IO ()
forall a. FinalizerPtr a -> ForeignPtr a -> IO ()
addForeignPtrFinalizer FinalizerPtr CMpfMat
p_mpf_mat_clear ForeignPtr CMpfMat
x
  MpfMat -> IO MpfMat
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (MpfMat -> IO MpfMat) -> MpfMat -> IO MpfMat
forall a b. (a -> b) -> a -> b
$ ForeignPtr CMpfMat -> MpfMat
MpfMat ForeignPtr CMpfMat
x
{-# INLINE withMpfMat #-}
withMpfMat :: MpfMat -> (Ptr CMpfMat -> IO a) -> IO (MpfMat, a)
withMpfMat (MpfMat ForeignPtr CMpfMat
x) Ptr CMpfMat -> IO a
f = do
  ForeignPtr CMpfMat
-> (Ptr CMpfMat -> IO (MpfMat, a)) -> IO (MpfMat, a)
forall a b. ForeignPtr a -> (Ptr a -> IO b) -> IO b
withForeignPtr ForeignPtr CMpfMat
x ((Ptr CMpfMat -> IO (MpfMat, a)) -> IO (MpfMat, a))
-> (Ptr CMpfMat -> IO (MpfMat, a)) -> IO (MpfMat, a)
forall a b. (a -> b) -> a -> b
$ \Ptr CMpfMat
px -> Ptr CMpfMat -> IO a
f Ptr CMpfMat
px IO a -> (a -> IO (MpfMat, a)) -> IO (MpfMat, a)
forall a b. IO a -> (a -> IO b) -> IO b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= (MpfMat, a) -> IO (MpfMat, a)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ((MpfMat, a) -> IO (MpfMat, a))
-> (a -> (MpfMat, a)) -> a -> IO (MpfMat, a)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ForeignPtr CMpfMat -> MpfMat
MpfMat ForeignPtr CMpfMat
x,)
withNewMpfMat :: CLong
-> CLong -> CFBitCnt -> (Ptr CMpfMat -> IO a) -> IO (MpfMat, a)
withNewMpfMat CLong
rows CLong
cols CFBitCnt
prec Ptr CMpfMat -> IO a
f = do
  MpfMat
x <- CLong -> CLong -> CFBitCnt -> IO MpfMat
newMpfMat CLong
rows CLong
cols CFBitCnt
prec
  MpfMat -> (Ptr CMpfMat -> IO a) -> IO (MpfMat, a)
forall {a}. MpfMat -> (Ptr CMpfMat -> IO a) -> IO (MpfMat, a)
withMpfMat MpfMat
x Ptr CMpfMat -> IO a
f
  
foreign import ccall "mpf_mat.h mpf_mat_init"
  mpf_mat_init :: Ptr CMpfMat -> CLong -> CLong -> CFBitCnt -> IO ()
foreign import ccall "mpf_mat.h mpf_mat_clear"
  mpf_mat_clear :: Ptr CMpfMat -> IO ()
foreign import ccall "mpf_mat.h &mpf_mat_clear"
  p_mpf_mat_clear :: FunPtr (Ptr CMpfMat -> IO ())
foreign import ccall "mpf_mat.h mpf_mat_set"
  mpf_mat_set :: Ptr CMpfMat -> Ptr CMpfMat -> IO ()
foreign import ccall "mpf_mat.h mpf_mat_swap"
  mpf_mat_swap :: Ptr CMpfMat -> Ptr CMpfMat -> IO ()
foreign import ccall "mpf_mat.h mpf_mat_swap_entrywise"
  mpf_mat_swap_entrywise :: Ptr CMpfMat -> Ptr CMpfMat -> IO ()
mpf_mat_entry :: Ptr CMpfMat -> CLong -> CLong -> IO (Ptr CMpf)
mpf_mat_entry :: Ptr CMpfMat -> CLong -> CLong -> IO (Ptr CMpf)
mpf_mat_entry Ptr CMpfMat
mat CLong
i CLong
j = do
  CMpfMat Ptr CMpf
entries CLong
r CLong
c Ptr (Ptr CMpf)
rows <- Ptr CMpfMat -> IO CMpfMat
forall a. Storable a => Ptr a -> IO a
peek Ptr CMpfMat
mat
  Ptr CMpf -> IO (Ptr CMpf)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (Ptr CMpf -> IO (Ptr CMpf)) -> Ptr CMpf -> IO (Ptr CMpf)
forall a b. (a -> b) -> a -> b
$ Ptr CMpf
entries Ptr CMpf -> Int -> Ptr CMpf
forall a. Storable a => Ptr a -> Int -> Ptr a
`advancePtr` (CLong -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral (CLong
iCLong -> CLong -> CLong
forall a. Num a => a -> a -> a
*CLong
c CLong -> CLong -> CLong
forall a. Num a => a -> a -> a
+ CLong
j))
foreign import ccall "mpf_mat.h mpf_mat_zero"
  mpf_mat_zero :: Ptr CMpfMat -> IO ()
foreign import ccall "mpf_mat.h mpf_mat_one"
  mpf_mat_one :: Ptr CMpfMat -> IO ()
foreign import ccall "mpf_mat.h mpf_mat_randtest"
  mpf_mat_randtest :: Ptr CMpfMat -> Ptr CFRandState -> CFBitCnt -> IO ()
foreign import ccall "mpf_mat.h mpf_mat_print"
  mpf_mat_print :: Ptr CMpfMat -> IO ()
foreign import ccall "mpf_mat.h mpf_mat_equal"
  mpf_mat_equal :: Ptr CMpfMat -> Ptr CMpfMat -> IO CInt
foreign import ccall "mpf_mat.h mpf_mat_approx_equal"
  mpf_mat_approx_equal :: Ptr CMpfMat -> Ptr CMpfMat -> CFBitCnt -> IO CInt
foreign import ccall "mpf_mat.h mpf_mat_is_zero"
  mpf_mat_is_zero :: Ptr CMpfMat -> IO CInt
foreign import ccall "mpf_mat.h mpf_mat_is_empty"
  mpf_mat_is_empty :: Ptr CMpfMat -> IO CInt
foreign import ccall "mpf_mat.h mpf_mat_is_square"
  mpf_mat_is_square :: Ptr CMpfMat -> IO CInt
foreign import ccall "mpf_mat.h mpf_mat_mul"
  mpf_mat_mul :: Ptr CMpfMat -> Ptr CMpfMat -> Ptr CMpfMat -> IO ()
foreign import ccall "mpf_mat.h mpf_mat_gso"
  mpf_mat_gso :: Ptr CMpfMat -> Ptr CMpfMat -> IO ()
foreign import ccall "mpf_mat.h mpf_mat_qr"
  mpf_mat_qr :: Ptr CMpfMat -> Ptr CMpfMat -> Ptr CMpfMat -> IO ()