module Main where import Music.Prelude.Basic toLydian :: Score BasicNote -> Score BasicNote toLydian = pitches' %~ (\p -> if ((p::Behavior Pitch) ! 0) == ((c::Behavior Pitch) ! 0) then cs else p) subj1 = (^/2) $ (legato.accent) (b_ |> c) |> (legato.accent) (c |> b_^*2) |> legato (scat [b_, c, d]) |> b_ |> c |> b_^*2 |> legato (scat [e, d, b_, c]) |> b_^*2 |> scat [d, e, b_] |> c^*2 |> b_ pres1 = subj1^*(2/2) pres2 = subj1^*(2/2) delay 2 (subj1^*(3/2)) part1 = pres1 |> pres2 part2 = pres1 |> pres2 music = asScore $ clef CClef $ level pp $ compress 2 $ part1 |> toLydian part2 main :: IO () main = open music