Safe Haskell | Safe |
---|---|

Language | Haskell98 |

Equal temperament tuning tables.

- octpc_to_pitch_cps_f0 :: Floating n => n -> OctPC -> (Pitch, n)
- octpc_to_pitch_cps :: Floating n => OctPC -> (Pitch, n)
- tbl_12et_f0 :: Double -> [(Pitch, Double)]
- tbl_12et :: [(Pitch, Double)]
- tbl_24et_f0 :: Double -> [(Pitch, Double)]
- tbl_24et :: [(Pitch, Double)]
- bounds_et_table :: Ord s => [(t, s)] -> s -> Maybe ((t, s), (t, s))
- bounds_12et_tone :: Double -> Maybe ((Pitch, Double), (Pitch, Double))
- type HS_R p = (Double, p, Double, Double, Cents)
- ndp :: Int -> Double -> String
- hs_r_pp :: (p -> String) -> Int -> HS_R p -> [String]
- hs_r_pitch_pp :: Int -> HS_R Pitch -> [String]
- nearest_et_table_tone :: [(p, Double)] -> Double -> HS_R p
- nearest_12et_tone :: Double -> HS_R Pitch
- nearest_24et_tone :: Double -> HS_R Pitch
- alteration_72et_monzo :: Integral n => n -> String
- pitch_72et :: (Int, Int) -> (Pitch_R, Double)
- tbl_72et :: [(Pitch_R, Double)]
- nearest_72et_tone :: Double -> HS_R Pitch_R
- type Pitch_Detune = (Pitch, Cents)
- hsr_to_pitch_detune :: HS_R Pitch -> Pitch_Detune
- nearest_pitch_detune_12et :: Double -> Pitch_Detune
- nearest_pitch_detune_24et :: Double -> Pitch_Detune
- ratio_to_pitch_detune :: (Double -> HS_R Pitch) -> OctPC -> Rational -> Pitch_Detune
- pitch_detune_to_cps :: Floating n => Pitch_Detune -> n
- ratio_to_pitch_detune_12et :: OctPC -> Rational -> Pitch_Detune
- ratio_to_pitch_detune_24et :: OctPC -> Rational -> Pitch_Detune
- pitch_detune_in_octave_nearest :: Pitch -> Pitch_Detune -> Pitch_Detune
- pitch_detune_md :: Pitch_Detune -> String
- pitch_detune_html :: Pitch_Detune -> String
- pitch_class_detune_md :: Pitch_Detune -> String
- pitch_class_detune_html :: Pitch_Detune -> String

# Documentation

tbl_12et_f0 :: Double -> [(Pitch, Double)] Source #

12-tone equal temperament table equating `Pitch`

and frequency
over range of human hearing, where `A4`

has given frequency.

tbl_12et_f0 415

tbl_12et :: [(Pitch, Double)] Source #

`tbl_12et_f0`

`440`

hz.

length tbl_12et == 132 minmax (map (round . snd) tbl_12et) == (16,31609)

tbl_24et_f0 :: Double -> [(Pitch, Double)] Source #

24-tone equal temperament variant of `tbl_12et_f0`

.

tbl_24et :: [(Pitch, Double)] Source #

`tbl_24et_f0`

`440`

.

length tbl_24et == 264 minmax (map (round . snd) tbl_24et) == (16,32535)

bounds_et_table :: Ord s => [(t, s)] -> s -> Maybe ((t, s), (t, s)) Source #

Given an `ET`

table (or like) find bounds of frequency.

import qualified Music.Theory.Tuple as T

let r = Just (T.t2_map octpc_to_pitch_cps ((3,11),(4,0))) in bounds_et_table tbl_12et 256 == r

bounds_12et_tone :: Double -> Maybe ((Pitch, Double), (Pitch, Double)) Source #

map bounds_12et_tone (hsn 17 55)

nearest_et_table_tone :: [(p, Double)] -> Double -> HS_R p Source #

Form `HS_R`

for *frequency* by consulting table.

let {f = 256 ;f' = octpc_to_cps (4,0) ;r = (f,Pitch C Natural 4,f',f-f',fratio_to_cents (f/f'))} in nearest_et_table_tone tbl_12et 256 == r

nearest_24et_tone :: Double -> HS_R Pitch Source #

`nearest_et_table_tone`

for `tbl_24et`

.

let r = "55.0 A1 55.0 0.0 0.0" in unwords (hs_r_pitch_pp 1 (nearest_24et_tone 55)) == r

# 72ET

alteration_72et_monzo :: Integral n => n -> String Source #

Monzo 72-edo HEWM notation. The domain is (-9,9). http://www.tonalsoft.com/enc/number/72edo.aspx

let r = ["+",">","^","#<","#-","#","#+","#>","#^"] in map alteration_72et_monzo [1 .. 9] == r

let r = ["-","<","v","b>","b+","b","b-","b<","bv"] in map alteration_72et_monzo [-1,-2 .. -9] == r

pitch_72et :: (Int, Int) -> (Pitch_R, Double) Source #

Given a midi note number and `1/6`

deviation determine `Pitch'`

and frequency.

let {f = pitch'_pp . fst . pitch_72et ;r = "C4 C+4 C>4 C^4 C#<4 C#-4 C#4 C#+4 C#>4 C#^4"} in unwords (map f (zip (repeat 60) [0..9])) == r

let {f = pitch'_pp . fst . pitch_72et ;r = "A4 A+4 A>4 A^4 Bb<4 Bb-4 Bb4 Bb+4 Bb>4 Bv4"} in unwords (map f (zip (repeat 69) [0..9]))

let {f = pitch'_pp . fst . pitch_72et ;r = "Bb4 Bb+4 Bb>4 Bv4 B<4 B-4 B4 B+4 B>4 B^4"} in unwords (map f (zip (repeat 70) [0..9])) == r

tbl_72et :: [(Pitch_R, Double)] Source #

72-tone equal temperament table equating `Pitch'`

and frequency
over range of human hearing, where `A4`

= `440`

hz.

length tbl_72et == 792 min_max (map (round . snd) tbl_72et) == (16,33167)

nearest_72et_tone :: Double -> HS_R Pitch_R Source #

`nearest_et_table_tone`

for `tbl_72et`

.

let r = "324.0 E<4 323.3 0.7 3.5" in unwords (hs_r_pp pitch'_pp 1 (nearest_72et_tone 324))

let {f = take 2 . hs_r_pp pitch'_pp 1 . nearest_72et_tone . snd} in mapM_ (print . unwords . f) tbl_72et

# Detune

hsr_to_pitch_detune :: HS_R Pitch -> Pitch_Detune Source #

Extract `Pitch_Detune`

from `HS_R`

.

nearest_pitch_detune_12et :: Double -> Pitch_Detune Source #

Nearest 12-ET `Pitch_Detune`

to indicated frequency (hz).

nearest_pitch_detune_12et 452.8929841231365

nearest_pitch_detune_24et :: Double -> Pitch_Detune Source #

Nearest 24-ET `Pitch_Detune`

to indicated frequency (hz).

nearest_pitch_detune_24et 452.8929841231365

ratio_to_pitch_detune :: (Double -> HS_R Pitch) -> OctPC -> Rational -> Pitch_Detune Source #

Given *near* function, *f0* and ratio derive `Pitch_Detune`

.

pitch_detune_to_cps :: Floating n => Pitch_Detune -> n Source #

Frequency (hz) of `Pitch_Detune`

.

pitch_detune_to_cps (octpc_to_pitch pc_spell_ks (4,9),50)

pitch_detune_md :: Pitch_Detune -> String Source #

Markdown pretty-printer for `Pitch_Detune`

.

pitch_detune_html :: Pitch_Detune -> String Source #

HTML pretty-printer for `Pitch_Detune`

.

pitch_class_detune_md :: Pitch_Detune -> String Source #

No-octave variant of `pitch_detune_md`

.

pitch_class_detune_html :: Pitch_Detune -> String Source #

No-octave variant of `pitch_detune_html`

.