:{ -- sets the amount of operator 'op' in the superfm output mix -- (1 <= op <= 6) fmamp :: Int -> Pattern Double -> ControlPattern fmamp op = pF ("amp" ++ show op) -- sets the ratio for operator 'op'. -- the frequency is note * ratio + detune Hz -- (1 <= op <= 6) fmratio :: Int -> Pattern Double -> ControlPattern fmratio op = pF ("ratio" ++ show op) -- set the detune for operator 'op' fmdetune :: Int -> Pattern Double -> ControlPattern fmdetune op = pF ("detune" ++ show op) -- set the modulation of oerator opa by operator opb -- if opa == opb, then the modulation amount is multiplied by the -- 'feedback' parameter fmmod :: Int -> Int -> Pattern Double -> ControlPattern fmmod opa opb = pF ("mod" ++ show opa ++ show opb) -- feedback fmfeedback :: Pattern Double -> ControlPattern fmfeedback = pF "feedback" -- Envelope definition: each operator has an envelop with 4 steps fmeglevel :: Int -> Int -> Pattern Double -> ControlPattern fmeglevel op step = pF ("eglevel" ++ show op ++ show step) -- Envelope definition: sets the rate at which the envelope moves -- between steps. Low numbers are slow, high numbers are fast. fmegrate :: Int -> Int -> Pattern Double -> ControlPattern fmegrate op step = pF ("egrate" ++ show op ++ show step) -- Array functions fmparam function (x:xs) = foldr (#) (function 1 x) (zipWith function [2..] xs) lfma = fmparam fmamp lfmr = fmparam fmratio lfmd = fmparam fmdetune lfmer op = fmparam (fmegrate op) lfmel op = fmparam (fmeglevel op) }