-- vla-adttn-sharc (rd) import Data.List {- base -} import Sound.Analysis.SHARC {- hsharc -} import Sound.OSC {- hosc -} import Sound.SC3.ID {- hsc3 -} import Sound.SC3.Lang.Pattern {- hsc3-lang -} type R = Double type R3 = (R,R,R) spectra :: [Instrument] -> String -> Int -> [R3] spectra sh nm j = let Just i = find ((== nm) . instrument_id) sh in note_spectra (note_normalise (notes i !! j)) vla :: Transport m => FilePath -> m [R3] vla fn = do Right sh <- liftIO (read_sharc fn) return (spectra sh "viola_vibrato" 0) unp :: R3 -> [R] unp (_,i,j) = [i,j] vla_prep :: [R3] -> [R] vla_prep = concatMap unp -- fr = freq,dt = detune vla_partial :: UGen -> UGen -> UGen -> UGen -> UGen -> UGen vla_partial fr rise fall dt n = let m = n * 2 ampl = bufRdN 1 KR 0 m NoLoop ph = bufRdN 1 KR 0 (m + 1) NoLoop o = let dt' = lfNoise1 'α' KR 1 * dt + 1.0 in fSinOsc AR (fr * (n + 1) * dt') ph e = linen (impulse KR 0 0) (rise * rand 'β' 0.75 1.25) ampl (fall * rand 'γ' 0.75 1.25) DoNothing in o * e vla_plyr :: UGen -> UGen vla_plyr n = let a = control KR "amp" 0.1 f = control KR "freq" 129.897 rs = control KR "rise" 0.1 fa = control KR "fall" 0.5 l = control KR "loc" 0.0 dt = control KR "dt" 0.001 s = sum (map (vla_partial f rs fa dt) [0 .. n - 1]) e = detectSilence s 0.001 0.2 RemoveSynth in mrg2 (pan2 s l a) e plyr36 :: Synthdef plyr36 = synthdef "plyr36" (out 0 (vla_plyr 36)) pattern :: [P_Bind] pattern = [(K_instr,pinstr "plyr36") ,(K_param "loc",pwhite 'δ' (-1) 1 inf) ,(K_amp,pwhite 'ε' 0.05 0.1 inf) ,(K_degree,prand 'ζ' [0,1,2,3,4,5,6,7,8] inf) ,(K_octave,prand 'η' [2,3] inf) ,(K_param "dt",pwhite 'θ' 0.001 0.005 inf) ,(K_param "rise",pwhite 'ι' 1 2 inf) ,(K_param "fall",pwhite 'κ' 4 7 inf) ,(K_dur,prand 'λ' [3,5] inf)] act :: Transport m => FilePath -> m () act fn = do v <- vla fn _ <- async (b_alloc_setn1 0 0 (vla_prep v)) _ <- async (d_recv plyr36) play (pbind pattern) main :: IO () main = withSC3 (act "/home/rohan/data/sharc/sharc.xml")