-- WIP
local ET = require('Module:ET')
local rat = require('Module:Rational')
local p = {}
-- Returns a nested table of note names
-- e.g. for 12edo, intended result would be something like:
-- {
-- 0 = {"C"},
-- 1 = {"Db"},
-- 2 = {"D"},
-- 3 = {"Eb"},
-- 4 = {"E"},
-- 5 = {"F"},
-- 6 = {"F#", "Gb"},
-- 7 = {"G"},
-- 8 = {"Ab"},
-- 9 = {"A"},
-- 10 = {"Bb"},
-- 11 = {"B"},
-- 12 = {"C"}
-- }
function p.get_note_names(et)
local note_names = {}
local i = 0
local last_note = 0
while i < et.size do
note_names[i] = {}
end
local fifth = ET.approximate(et, rat.new(3, 2))
local fourth = ET.approximate(et, rat.new(4, 3))
local chroma = (fifth * 7) % et.size
-- Add major scale notes
table.insert(note_names[0], "C")
table.insert(note_names[(fifth * 2) % et.size], "D")
table.insert(note_names[(fifth * 4) % et.size], "E")
table.insert(note_names[fourth], "F")
table.insert(note_names[fifth], "G")
table.insert(note_names[(fifth * 3) % et.size], "A")
table.insert(note_names[(fifth * 5) % et.size], "B")
table.insert(note_names[et.size], "C")
i = 0
local last_major_note = 0
while i < et.size do
if #(note_names[i]) == 0 then
local num_sharps = math.floor((i - last_major_note) / chroma)
local num_ups = (i - last_major_note) % chroma
local name = interval_names[last_major_note]
local j = 0
while j < num_sharps do
name = name + "#"
end
j = 0
while j < num_ups do
name = "^" + name
end
table.insert(note_names[i], note_names[last_note])
else
last_major_note = i
end
i = i + 1
end
end
return p