Module:Lumatone mapping intro

Revision as of 17:19, 14 March 2025 by ArrowHead294 (talk | contribs) (Created page with)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Module documentation[view] [edit] [history] [purge]
This module should not be invoked directly; use its corresponding template instead: Template:Lumatone mapping intro.

This module automatically fills in the introduction for Lumatone keyboard mappings for EDOs.

Since the Standard Lumatone mapping for Pythagorean is based on the chain of fifths, the intro text will depend on how accurately an EDO approximates 3/2 and how many mutually-exclusive circles of fifths it has.
Introspection summary for Module:Lumatone mapping intro 
Functions provided (1)
Line Function Params
6 lum_intro (invokable) (frame)
Lua modules required (3)
Variable Module Functions used
ET Module:ET parse
approximate
cents
is_highly_composite
gcd Module:Utils _gcd
yesno Module:Yesno yesno

No function descriptions were provided. The Lua code may have further information.


local p = {}
local ET = require("Module:ET")
local gcd = require("Module:Utils")._gcd
local yesno = require("Module:Yesno")

function p.lum_intro(frame)
	local tuning = frame.args["edo"]
	local et = ET.parse(tuning) or ET.parse("12edo")
	local debug_mode = yesno(frame.args["debug"])
	
	local octave = ET.approximate(et, 2)
	local twelfth = ET.approximate(et, 3)

	local step_size = ET.cents(et, 1)
	local fifth = -octave + twelfth -- 3/2 = [-1 1>
	local fifth_error = ET.cents(et, fifth) - rat.cents(rat.new(3, 2))
	local is_far_fifth = (math.abs(fifth_error) / step_size >= 0.4)

	local result = string.format("There are many conceivable ways to map [[%s]] onto the onto the [[Lumatone]] keyboard.", tuning)
	
	local rings = gcd(octave, twelfth)
	if rings > 1 then
		result = result .. string.format(" However, since it has %d mutually-exclusive rings of fifths,", rings)
			.. "the [[Standard Lumatone mapping for Pythagorean]] is not one of them."
		if ET.is_highly_composite(et) then
			result = result .. " Since it is [[highly composite]], many other mappings will also fail to cover the whole gamut."
		end
	elseif is_far_fifth == true then
		result = result .. " However, as both of its fifths are about as far away from just as possible, "
			.. "neither the sharp or the flat versions of the [[Standard Lumatone mapping for Pythagorean]] work particularly well."
	else
		result = result .. " Only one, however, agrees with the [[Standard Lumatone mapping for Pythagorean]]."
	end
end

return p