module Reactive.Banana.MIDI.Guitar where
import qualified Reactive.Banana.MIDI.Pitch as Pitch
import Sound.MIDI.Message.Channel.Voice (Pitch, toPitch, )
import qualified Data.List.Key as Key
import Data.Maybe (mapMaybe, )
mapChordToString ::
(Pitch.C pitch) =>
[Pitch] -> [pitch] -> [pitch]
mapChordToString strings chord =
mapMaybe (choosePitchForString chord) strings
choosePitchForString ::
(Pitch.C pitch) =>
[pitch] -> Pitch -> Maybe pitch
choosePitchForString chord string =
let roundDown x d = x - mod x d
minAbove x =
Pitch.increase
(- roundDown (Pitch.subtract string (Pitch.extract x)) 12) x
in Key.maximum (fmap Pitch.extract) $ map minAbove chord
stringPitches :: [Pitch]
stringPitches =
reverse $ map toPitch [40, 45, 50, 55, 59, 64]