-- http://sccode.org/1-4QN import Control.Concurrent {- base -} import Control.Monad {- base -} import Sound.OSC {- hosc -} import Sound.SC3.ID {- hsc3 -} import Sound.SC3.Lang.Pattern {- hsc3-lang -} import qualified Sound.SC3.Lang.Random.IO as L -- > withSC3 init_b init_b :: Transport m => m Message init_b = do _ <- async (b_alloc 0 512 1) async (b_gen_sine1 0 [Normalise,Wavetable,Clear] (map recip [1,2,3,4])) -- > Sound.SC3.UGen.Dot.draw (mk_g (lfNoise0 'α')) mk_g :: (Rate -> UGen -> UGen) -> Synthdef mk_g o = let k = control KR b = k "bufnum" 0 d = k "dur" 1 r = k "rate" 1 p = k "pos" 0 sd = k "sdens" 1 ed = k "edens" 1 l = line KR sd ed d DoNothing t = o AR l e_p = envPerc (rand 'β' 0.0001 0.1) (d * rand 'γ' 0.5 4) e = envGen KR 1 1 0 1 RemoveSynth e_p g = grainBuf 2 t (1 / l) b r p 2 0 (-1) 512 in synthdef "g" (out 0 (g * e)) p1 :: [P_Bind] p1 = [(K_dur,pseq [4] inf) ,(K_param "sdens",pseq [9000,1000,500] inf / 100) ,(K_param "edens",prand 'δ' [pseq [9000,1000,500] 1 / 10 ,pseq [1] 3] inf) ,(K_param "rate",pwhite 'ε' (-10) 10 inf) ,(K_param "pos",pwhite 'ζ' (-10) 10 inf)] p2 :: [P_Bind] p2 = [(K_dur,pseq [4/3] inf) ,(K_param "sdens",pseq [9000,1000,500,25] inf) ,(K_param "edens",prand 'η' [pseq [9000,1000,500,25] 1 ,pseq [1] 4] inf) ,(K_param "rate",pwhite 'θ' (-100) 100 inf) ,(K_param "pos",pwhite 'ι' (-10) 10 inf)] push_g :: Transport m => m Message push_g = do let ph u r f = u r f 0 wd u r f = u r f 0 0 o_set = [lfNoise0 'κ',ph sinOsc,ph impulse,wd lfPulse,ph lfSaw] o <- L.choose o_set async (d_recv (mk_g o)) update_g :: Transport m => m () update_g = do _ <- push_g dt <- L.choose [1,2,4,8,16,32] wait dt main :: IO () main = do _ <- forkIO (withSC3 (reset >> init_b >> forever update_g)) audition (p_with (K_instr,pinstr "g") (ppar (map pbind [p1,p2])))