module Numeric.Signal.Internal (
Convolvable(..),
hamming,
filter,
freqz,
hilbert,
pwelch,
complex_power
) where
import Data.Packed.Development(createVector,vec,app1,app2,app3,app4)
import Data.Packed.Vector
import Data.Packed(Container(..))
import Numeric.LinearAlgebra.Instances()
import Numeric.LinearAlgebra.Linear(Linear(..))
import Foreign
import Complex
import Foreign.C.Types
import Prelude hiding(filter)
type PD = Ptr Double
type PC = Ptr (Complex Double)
class Convolvable a where
convolve :: a -> a -> a
instance Convolvable (Vector Double) where
convolve = convolve_vector_double
convolve_vector_double c a = unsafePerformIO $ do
r <- createVector (dim a)
app3 signal_vector_double_convolve vec c vec a vec r "signalDoubleConvolve"
return r
foreign import ccall "signal-aux.h vector_double_convolve" signal_vector_double_convolve :: CInt -> PD -> CInt -> PD -> CInt -> PD -> IO CInt
instance Convolvable (Vector (Complex Double)) where
convolve = convolve_vector_complex
convolve_vector_complex c a = unsafePerformIO $ do
r <- createVector (dim a)
app3 signal_vector_complex_convolve vec c vec a vec r "signalComplexConvolve"
return r
foreign import ccall "signal-aux.h vector_complex_convolve" signal_vector_complex_convolve :: CInt -> PC -> CInt -> PC -> CInt -> PC -> IO CInt
filter :: Vector Double
-> Vector Double
-> Vector Double
-> Vector Double
filter l k v = unsafePerformIO $ do
r <- createVector (dim v)
app4 signal_filter vec l vec k vec v vec r "signalFilter"
return r
foreign import ccall "signal-aux.h filter" signal_filter :: CInt -> PD -> CInt -> PD -> CInt -> PD -> CInt -> PD -> IO CInt
hilbert :: Vector Double -> Vector (Complex Double)
hilbert v = unsafePerformIO $ do
r <- createVector (dim v)
let v' = complex v
app2 signal_hilbert vec v' vec r "hilbert"
return r
foreign import ccall "signal-aux.h hilbert" signal_hilbert :: CInt -> PC -> CInt -> PC -> IO CInt
pwelch :: Int
-> Vector Double
-> Vector Double
pwelch w v = unsafePerformIO $ do
let r = constant 0.0 ((w `div` 2) + 1)
app2 (signal_pwelch $ fromIntegral w) vec (complex v) vec r "pwelch"
return r
foreign import ccall "signal-aux.h pwelch" signal_pwelch :: CInt -> CInt -> PC -> CInt -> PD -> IO CInt
hamming :: Int
-> Vector Double
hamming l
| l == 1 = constant 1.0 1
| otherwise = unsafePerformIO $ do
r <- createVector l
app1 signal_hamming vec r "Hamming"
return r
foreign import ccall "signal-aux.h hamming" signal_hamming :: CInt -> PD -> IO CInt
freqz :: Vector Double
-> Vector Double
-> Vector Double
-> Vector Double
freqz b a w = let k = max (dim b) (dim a)
hb = polyEval (postpad b k) (exp (scale (0 :+ 1) ((complex w) :: Vector (Complex Double))))
ha = polyEval (postpad a k) (exp (scale (0 :+ 1) ((complex w) :: Vector (Complex Double))))
in complex_power (hb / ha)
postpad v n = let d = dim v
in if d < n then join [v,(constant 0.0 (nd))]
else v
polyEval :: Vector Double
-> Vector (Complex Double)
-> Vector (Complex Double)
polyEval c z = unsafePerformIO $ do
r <- createVector (dim z)
app3 signal_real_poly_complex_eval vec c vec z vec r "polyEval"
return r
foreign import ccall "signal-aux.h real_poly_complex_eval" signal_real_poly_complex_eval :: CInt -> PD -> CInt -> PC -> CInt -> PC -> IO CInt
complex_power :: Vector (Complex Double)
-> Vector Double
complex_power v = unsafePerformIO $ do
r <- createVector (dim v)
app2 signal_complex_power vec v vec r "complex_power"
return r
foreign import ccall "signal-aux.h complex_power" signal_complex_power :: CInt -> PC -> CInt -> PD -> IO CInt