Module:MOS genchain: Difference between revisions
No edit summary |
ArrowHead294 (talk | contribs) mNo edit summary |
||
| (40 intermediate revisions by 3 users not shown) | |||
| Line 1: | Line 1: | ||
local mos = require("Module:MOS") | local mos = require("Module:MOS") | ||
local tamnams = require("Module:TAMNAMS") | local tamnams = require("Module:TAMNAMS") | ||
local yesno = require("Module:Yesno") | local yesno = require("Module:Yesno") | ||
local p = {} | local p = {} | ||
-- TODO | |||
-- - Cell coloring | |||
-- - Mosprefix and mosabbrev entering | |||
-- - Collapse option | |||
-- Global variables for cell colors | -- Global variables for cell colors | ||
| Line 17: | Line 21: | ||
p.cell_color_sm_altered_size = "#F8CBAD" | p.cell_color_sm_altered_size = "#F8CBAD" | ||
function p. | function p.preprocess_genchain(input_mos) | ||
local input_mos = input_mos or mos.new(5,2) | local input_mos = input_mos or mos.new(5,2) | ||
local num_gens = | local num_gens = (2 * (input_mos.nL + input_mos.nL + input_mos.ns))/mos.period_count(input_mos) - 2 | ||
local bright_gen = mos.bright_gen(input_mos) | local bright_gen = mos.bright_gen(input_mos) | ||
local | local gens = mos.interval_mul(bright_gen, math.floor(num_gens/2)) | ||
bright_gen = mos.interval_mul(bright_gen, -1) | |||
local genchain = { mos.period_reduce(gens, input_mos) } | |||
local | for i = 1, num_gens do | ||
gens = mos.interval_add(gens, bright_gen) | |||
table.insert(genchain, mos.period_reduce(gens, input_mos)) | |||
for i = 1, | |||
table.insert(genchain, | |||
end | end | ||
return genchain | return genchain | ||
end | end | ||
function p._mos_genchain(input_mos) | function p._mos_genchain(input_mos, mos_prefix, mos_abbrev, is_collapsed) | ||
local input_mos = input_mos or mos.new(5,2) | local input_mos = input_mos or mos.new(5,2) | ||
local mos_prefix = mos_prefix or "mos" | |||
local mos_abbrev = mos_abbrev or "m" | |||
local is_collapsed = is_collapsed == true | |||
local num_gens = mos.period_step_count(input_mos) | local num_gens = mos.period_step_count(input_mos) | ||
local genchain = p. | local genchain = p.preprocess_genchain(input_mos) | ||
local | local period_count = mos.period_count(input_mos) | ||
local scale_sig = mos.as_string(input_mos) | |||
-- Begin table | -- Begin table | ||
local result = "{| class=\"wikitable center- | local result = "{| class=\"wikitable center-1 center-3 mw-collapsible" .. (is_collapsed and " mw-collapsed\"\n" or "\"\n") | ||
-- | -- Table caption | ||
result = result .. " | result = result .. "|+ style=\"font-size: 105%; white-space: nowrap;\" | " .. string.format("Generator chain of %s\n", scale_sig) | ||
-- Headers for each period | |||
result = result .. "|-\n" | |||
.. "! Bright gens" | |||
for i = 1, period_count do | |||
result = result | |||
.. " !! Scale degree" | |||
.. " !! Abbrev." | |||
for i = 1, | |||
result = result .. | |||
end | end | ||
result = result .. "\n" | result = result .. "\n" | ||
-- Add a row for each period | -- Add a row for each scale degree, plus their period-shifted counterparts | ||
for i = 1, #genchain do | |||
result = result .. "|-\n" | |||
result = result .. " | |||
-- Number of generators | |||
local current_interval = mos. | local num_gens = math.ceil(#genchain / 2) - i | ||
result = result .. string.format("| %s", string.gsub(num_gens, "-", "−")) | |||
if | |||
result = result .. string.format("| %s", tamnams.degree_quality( | -- Scale degree (full name) and abbrev | ||
for j = 1, period_count do | |||
-- If the scale degree corresponds to the root, say it's both the | |||
-- root and the degree one period up. | |||
-- If the scale degree is reached by a negative number of gens, then | |||
-- say it's the degree one period up instead. | |||
local period_interval = mos.period(input_mos) | |||
local current_interval = mos.interval_add(genchain[i], mos.interval_mul(period_interval, j - 1)) | |||
local period_raised_interval = mos.interval_add(current_interval, period_interval) | |||
if num_gens == 0 then | |||
result = result | |||
.. string.format(" || %s<br />%s || %s<br />%s", | |||
tamnams.degree_quality(current_interval, input_mos, "sentence-case", mos_prefix), | |||
tamnams.degree_quality(period_raised_interval, input_mos, "sentence-case", mos_prefix), | |||
tamnams.degree_quality(current_interval, input_mos, "abbrev" , mos_abbrev), | |||
tamnams.degree_quality(period_raised_interval, input_mos, "abbrev", mos_abbrev)) | |||
elseif num_gens < 0 and mos.interval_step_count(current_interval) % mos.period_step_count(input_mos) == 0 then | |||
result = result | |||
.. string.format(" || %s || %s", | |||
tamnams.degree_quality(period_raised_interval, input_mos, "sentence-case", mos_prefix), | |||
tamnams.degree_quality(period_raised_interval, input_mos, "abbrev", mos_abbrev)) | |||
else | else | ||
result = result .. string.format(" || %s", tamnams.degree_quality(current_interval, input_mos, " | result = result | ||
.. string.format(" || %s || %s", | |||
tamnams.degree_quality(current_interval, input_mos, "sentence-case", mos_prefix), | |||
tamnams.degree_quality(current_interval, input_mos, "abbrev", mos_abbrev)) | |||
end | end | ||
end | end | ||
-- End of row | |||
result = result | |||
.. "\n" | |||
end | end | ||
result = result .. "|}" | |||
return result | return result | ||
end | |||
function p.mos_genchain(frame) | |||
local scalesig = frame.args["Scale Signature"] | |||
local mos_prefix = frame.args["MOS Prefix"] | |||
local mos_abbrev = frame.args["MOS Abbrev"] | |||
local collapsed = yesno(frame.args["Collapsed"]) | |||
local debugg = yesno(frame.args["debug"]) | |||
-- Parse scalesig | |||
local input_mos = mos.parse(scalesig) | |||
-- Verify name/prefix/abbrev | |||
mos_prefix = tamnams.verify_prefix(input_mos, mos_prefix) | |||
mos_abbrev = tamnams.verify_abbrev(input_mos, mos_abbrev) | |||
local result = p._mos_genchain(input_mos, mos_prefix, mos_abbrev, collapsed) | |||
-- Debugger option | |||
if debugg == true then | |||
result = "<syntaxhighlight lang=\"wikitext\">" .. result .. "</syntaxhighlight>" | |||
end | |||
return frame:preprocess(result) | |||
end | end | ||
return p | return p | ||