Module:Harmonic entropy: Difference between revisions
Jump to navigation
Jump to search
Bug fixing |
Round to 3 decimal places by default ("no rounding" can be achieved by using prec ≥ 12) |
||
| Line 12: | Line 12: | ||
-- ratio defaults to 1 | -- ratio defaults to 1 | ||
ratio = u.eval_num_arg(ratio, 1) | ratio = u.eval_num_arg(ratio, 1) | ||
-- prec defaults to 3 | |||
prec = u.eval_num_arg(prec, 3) | |||
return u._round(1200*u._log(ratio), prec) | |||
end | end | ||
return p | return p | ||
Revision as of 06:06, 19 August 2022
- This module primarily serves as a library for other modules and has no corresponding template.
This module provides a means to calculate harmonic Shannon entropy of a particular interval.
| Introspection summary for Module:Harmonic entropy | ||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
| |||||||||||||||||||||
local getArgs = require('Module:Arguments').getArgs
local u = require('Module:Utils')
local p = {}
-- return measure in cents of an interval ratio, rounded to prec decimal places
function p.to_cents(frame)
local args = getArgs(frame)
return p._to_cents(args[1], args[2])
end
function p._to_cents(ratio, prec)
-- ratio defaults to 1
ratio = u.eval_num_arg(ratio, 1)
-- prec defaults to 3
prec = u.eval_num_arg(prec, 3)
return u._round(1200*u._log(ratio), prec)
end
return p