synthesizer-llvm-0.7.0.1: Efficient signal processing using runtime compilation

Safe HaskellNone
LanguageHaskell98

Synthesizer.LLVM.Simple.Signal

Synopsis

Documentation

data T a Source

Constructors

forall state ioContext . C state => Cons (forall r c. Phi c => ioContext -> state -> T r c (a, state)) (forall r. ioContext -> CodeGenFunction r state) (IO ioContext) (ioContext -> IO ()) 

Instances

Functor T 
Applicative T

ZipList semantics

C T 
(Field a, Real a, RationalConstant a) => Fractional (T a) 
(PseudoRing a, Real a, IntegerConstant a) => Num (T a) 
(Field a, RationalConstant a) => C (T a) 
(PseudoRing a, IntegerConstant a) => C (T a) 
Additive a => C (T a) 
type ProcessOf T = T 

data Core context initState exitState a Source

Constructors

forall state . C state => Core (forall r c. Phi c => context -> state -> T r c (a, state)) (forall r. initState -> CodeGenFunction r state) (state -> exitState) 

class Applicative signal => C signal where Source

Methods

simple :: C state => (forall r c. state -> T r c (a, state)) -> (forall r. CodeGenFunction r state) -> signal a Source

alter :: (forall context initState exitState. Core context initState exitState a0 -> Core context initState exitState a1) -> signal a0 -> signal a1 Source

Instances

C T 
C (T p) 

map :: C signal => (forall r. a -> CodeGenFunction r b) -> signal a -> signal b Source

mapAccum :: (C signal, C s) => (forall r. a -> s -> CodeGenFunction r (b, s)) -> (forall r. CodeGenFunction r s) -> signal a -> signal b Source

zipWith :: C signal => (forall r. a -> b -> CodeGenFunction r c) -> signal a -> signal b -> signal c Source

zip :: T a -> T b -> T (a, b) Source

mix :: (C signal, Additive a) => signal a -> signal a -> signal a Source

envelope :: (C signal, PseudoRing a) => signal a -> signal a -> signal a Source

envelopeStereo :: (C signal, PseudoRing a) => signal a -> signal (T a) -> signal (T a) Source

amplify :: (IsArithmetic a, IsConst a) => a -> T (Value a) -> T (Value a) Source

amplifyStereo :: (IsArithmetic a, IsConst a) => a -> T (T (Value a)) -> T (T (Value a)) Source

iterate :: (FirstClass a, Stored a ~ am, IsSized am, IsConst a) => (forall r. Value a -> CodeGenFunction r (Value a)) -> Value a -> T (Value a) Source

exponential2 :: (C a, IsArithmetic a, FirstClass a, Stored a ~ am, IsSized am, IsConst a) => a -> a -> T (Value a) Source

osciPlain :: (FirstClass t, Stored t ~ tm, IsSized tm, Fraction t, IsConst t) => (forall r. Value t -> CodeGenFunction r y) -> Value t -> Value t -> T y Source

osci :: (FirstClass t, Stored t ~ tm, IsSized tm, Fraction t, IsConst t) => (forall r. Value t -> CodeGenFunction r y) -> t -> t -> T y Source

osciSaw :: (IntegerConstant a, FirstClass a, Stored a ~ am, IsSized am, Fraction a, IsConst a) => a -> a -> T (Value a) Source

fromStorableVector :: (Storable a, MakeValueTuple a, ValueTuple a ~ value, C value) => Vector a -> T value Source

fromStorableVectorLazy :: (Storable a, MakeValueTuple a, ValueTuple a ~ value, C value) => Vector a -> T value Source

render :: (Storable a, MakeValueTuple a, ValueTuple a ~ value, C value) => Int -> T value -> Vector a Source

derefChunkPtr :: Importer (Ptr stateStruct -> Word32 -> Ptr struct -> IO Word32) Source

compileChunky :: (C value, Struct value ~ struct, C state, Struct state ~ stateStruct) => (forall r z. Phi z => state -> T r z (value, state)) -> (forall r. CodeGenFunction r state) -> IO (FunPtr (IO (Ptr stateStruct)), FunPtr (Ptr stateStruct -> IO ()), FunPtr (Ptr stateStruct -> Word32 -> Ptr struct -> IO Word32)) Source

runChunky :: (Storable a, MakeValueTuple a, ValueTuple a ~ value, C value) => ChunkSize -> T value -> IO (Vector a) Source

renderChunky :: (Storable a, MakeValueTuple a, ValueTuple a ~ value, C value) => ChunkSize -> T value -> Vector a Source