<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="fr">
	<id>https://baripedia.org/index.php?action=history&amp;feed=atom&amp;title=Module%3AMath</id>
	<title>Module:Math - Historique des versions</title>
	<link rel="self" type="application/atom+xml" href="https://baripedia.org/index.php?action=history&amp;feed=atom&amp;title=Module%3AMath"/>
	<link rel="alternate" type="text/html" href="https://baripedia.org/index.php?title=Module:Math&amp;action=history"/>
	<updated>2026-04-13T10:33:03Z</updated>
	<subtitle>Historique des versions pour cette page sur le wiki</subtitle>
	<generator>MediaWiki 1.38.6</generator>
	<entry>
		<id>https://baripedia.org/index.php?title=Module:Math&amp;diff=28295&amp;oldid=prev</id>
		<title>Arthur : 1 révision importée</title>
		<link rel="alternate" type="text/html" href="https://baripedia.org/index.php?title=Module:Math&amp;diff=28295&amp;oldid=prev"/>
		<updated>2015-11-09T20:49:19Z</updated>

		<summary type="html">&lt;p&gt;1 révision importée&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nouvelle page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;--[[&lt;br /&gt;
&lt;br /&gt;
This module provides a number of basic mathematical operations.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
local z = {}&lt;br /&gt;
&lt;br /&gt;
-- Generate random number&lt;br /&gt;
function z.random( frame )&lt;br /&gt;
    local first = tonumber(frame.args[1]) -- if it doesn't exist it's NaN, if not a number it's nil&lt;br /&gt;
    local second = tonumber(frame.args[2])&lt;br /&gt;
&lt;br /&gt;
    if first then -- if NaN or nil, will skip down to final return&lt;br /&gt;
        if first &amp;lt;= second then -- could match if both nil, but already checked that first is a number in last line&lt;br /&gt;
            return math.random(first, second)&lt;br /&gt;
        end&lt;br /&gt;
        return math.random(first)&lt;br /&gt;
    end   &lt;br /&gt;
    return math.random()&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
order&lt;br /&gt;
&lt;br /&gt;
Determine order of magnitude of a number&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke: Math | order | value }}&lt;br /&gt;
]]&lt;br /&gt;
function z.order(frame)&lt;br /&gt;
    local input_string = (frame.args[1] or frame.args.x or '0');&lt;br /&gt;
    local input_number;&lt;br /&gt;
    &lt;br /&gt;
    input_number = z._cleanNumber( frame, input_string );&lt;br /&gt;
    if input_number == nil then&lt;br /&gt;
        return '&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: Order of magnitude input appears non-numeric&amp;lt;/strong&amp;gt;'&lt;br /&gt;
    else&lt;br /&gt;
        return z._order( input_number )&lt;br /&gt;
    end    &lt;br /&gt;
end&lt;br /&gt;
function z._order(x)&lt;br /&gt;
    if x == 0 then return 0 end&lt;br /&gt;
    return math.floor(math.log10(math.abs(x)))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
precision&lt;br /&gt;
&lt;br /&gt;
Detemines the precision of a number using the string representation&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{ #invoke: Math | precision | value }}&lt;br /&gt;
]]&lt;br /&gt;
function z.precision( frame )&lt;br /&gt;
    local input_string = (frame.args[1] or frame.args.x or '0');&lt;br /&gt;
    local trap_fraction = frame.args.check_fraction or false;&lt;br /&gt;
    local input_number;&lt;br /&gt;
    &lt;br /&gt;
    if type( trap_fraction ) == 'string' then&lt;br /&gt;
        trap_fraction = trap_fraction:lower();&lt;br /&gt;
        if trap_fraction == 'false' or trap_fraction == '0' or&lt;br /&gt;
                trap_fraction == 'no' or trap_fraction == '' then&lt;br /&gt;
            trap_fraction = false;&lt;br /&gt;
        else&lt;br /&gt;
            trap_fraction = true;&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    if trap_fraction then&lt;br /&gt;
        local pos = string.find( input_string, '/', 1, true );&lt;br /&gt;
        if pos ~= nil then&lt;br /&gt;
            if string.find( input_string, '/', pos + 1, true ) == nil then&lt;br /&gt;
                local denominator = string.sub( input_string, pos+1, -1 );&lt;br /&gt;
                local denom_value = tonumber( denominator );&lt;br /&gt;
                if denom_value ~= nil then&lt;br /&gt;
                    return math.log10(denom_value);&lt;br /&gt;
                end&lt;br /&gt;
            end                        &lt;br /&gt;
        end&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    input_number, input_string = z._cleanNumber( frame, input_string );&lt;br /&gt;
    if input_string == nil then&lt;br /&gt;
        return '&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: Precision input appears non-numeric&amp;lt;/strong&amp;gt;'&lt;br /&gt;
    else&lt;br /&gt;
        return z._precision( input_string )&lt;br /&gt;
    end    &lt;br /&gt;
end&lt;br /&gt;
function z._precision( x )    &lt;br /&gt;
    x = string.upper( x )&lt;br /&gt;
&lt;br /&gt;
    local decimal = string.find( x, '.', 1, true )&lt;br /&gt;
    local exponent_pos = string.find( x, 'E', 1, true )&lt;br /&gt;
    local result = 0;&lt;br /&gt;
    &lt;br /&gt;
    if exponent_pos ~= nil then&lt;br /&gt;
        local exponent = string.sub( x, exponent_pos + 1 )&lt;br /&gt;
        x = string.sub( x, 1, exponent_pos - 1 )&lt;br /&gt;
        result = result - tonumber( exponent )&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    if decimal ~= nil then&lt;br /&gt;
        result = result + string.len( x ) - decimal&lt;br /&gt;
        return result&lt;br /&gt;
    end&lt;br /&gt;
        &lt;br /&gt;
    local pos = string.len( x );&lt;br /&gt;
    while x:byte(pos) == string.byte('0') do&lt;br /&gt;
        pos = pos - 1&lt;br /&gt;
        result = result - 1&lt;br /&gt;
        if pos &amp;lt;= 0 then&lt;br /&gt;
            return 0&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
max&lt;br /&gt;
&lt;br /&gt;
Finds the maximum argument&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke:Math| max | value1 | value2 | ... }}&lt;br /&gt;
OR&lt;br /&gt;
    {{#invoke:Math| max }}&lt;br /&gt;
&lt;br /&gt;
When used with no arguments, it takes its input from the parent&lt;br /&gt;
frame.  Note, any values that do not evaluate to numbers are ignored.&lt;br /&gt;
]]&lt;br /&gt;
function z.max( frame )&lt;br /&gt;
    local args = frame.args;&lt;br /&gt;
    &lt;br /&gt;
    if args[1] == nil then&lt;br /&gt;
        local parent = frame:getParent();&lt;br /&gt;
        args = parent.args;&lt;br /&gt;
    end&lt;br /&gt;
    local max_value = nil;&lt;br /&gt;
    &lt;br /&gt;
    local i = 1;&lt;br /&gt;
    while args[i] ~= nil do&lt;br /&gt;
        local val = z._cleanNumber( frame, args[i] );&lt;br /&gt;
        if val ~= nil then&lt;br /&gt;
            if max_value == nil or val &amp;gt; max_value then&lt;br /&gt;
                max_value = val;&lt;br /&gt;
            end&lt;br /&gt;
        end        &lt;br /&gt;
        i = i + 1;&lt;br /&gt;
    end&lt;br /&gt;
  &lt;br /&gt;
    return max_value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
min &lt;br /&gt;
&lt;br /&gt;
Finds the minimum argument&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke:Math| min | value1 | value2 | ... }}&lt;br /&gt;
OR&lt;br /&gt;
    {{#invoke:Math| min }}&lt;br /&gt;
&lt;br /&gt;
When used with no arguments, it takes its input from the parent&lt;br /&gt;
frame.  Note, any values that do not evaluate to numbers are ignored.&lt;br /&gt;
]]&lt;br /&gt;
function z.min( frame )&lt;br /&gt;
    local args = frame.args;&lt;br /&gt;
    &lt;br /&gt;
    if args[1] == nil then&lt;br /&gt;
        local parent = frame:getParent();&lt;br /&gt;
        args = parent.args;&lt;br /&gt;
    end&lt;br /&gt;
    local min_value = nil;&lt;br /&gt;
    &lt;br /&gt;
    local i = 1;&lt;br /&gt;
    while args[i] ~= nil do&lt;br /&gt;
        local val = z._cleanNumber( frame, args[i] );&lt;br /&gt;
        if val ~= nil then&lt;br /&gt;
            if min_value == nil or val &amp;lt; min_value then&lt;br /&gt;
                min_value = val;&lt;br /&gt;
            end&lt;br /&gt;
        end        &lt;br /&gt;
        i = i + 1;&lt;br /&gt;
    end&lt;br /&gt;
  &lt;br /&gt;
    return min_value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
round&lt;br /&gt;
&lt;br /&gt;
Rounds a number to specified precision&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke:Math | round | value | precision }}&lt;br /&gt;
    &lt;br /&gt;
--]]&lt;br /&gt;
function z.round(frame)&lt;br /&gt;
    local value, precision;&lt;br /&gt;
    &lt;br /&gt;
    value = z._cleanNumber( frame, frame.args[1] or frame.args.value or 0 );&lt;br /&gt;
    precision = z._cleanNumber( frame, frame.args[2] or frame.args.precision or 0 );&lt;br /&gt;
    &lt;br /&gt;
    if value == nil or precision == nil then&lt;br /&gt;
        return '&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: Round input appears non-numeric&amp;lt;/strong&amp;gt;'&lt;br /&gt;
    else&lt;br /&gt;
        return z._round( value, precision );&lt;br /&gt;
    end    &lt;br /&gt;
end&lt;br /&gt;
function z._round( value, precision )&lt;br /&gt;
    local rescale = math.pow( 10, precision );&lt;br /&gt;
    return math.floor( value * rescale + 0.5 ) / rescale;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
precision_format&lt;br /&gt;
&lt;br /&gt;
Rounds a number to the specified precision and formats according to rules &lt;br /&gt;
originally used for {{template:Rnd}}.  Output is a string.&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke: Math | precision_format | number | precision }}&lt;br /&gt;
]]&lt;br /&gt;
function z.precision_format( frame )&lt;br /&gt;
    -- For access to Mediawiki built-in formatter.&lt;br /&gt;
    local lang = mw.getContentLanguage();&lt;br /&gt;
    &lt;br /&gt;
    local value_string, value, precision;&lt;br /&gt;
    value, value_string = z._cleanNumber( frame, frame.args[1] or 0 );&lt;br /&gt;
    precision = z._cleanNumber( frame, frame.args[2] or 0 );&lt;br /&gt;
    &lt;br /&gt;
    -- Check for non-numeric input&lt;br /&gt;
    if value == nil or precision == nil then&lt;br /&gt;
        return '&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: invalid input when rounding&amp;lt;/strong&amp;gt;'&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    local current_precision = z._precision( value );&lt;br /&gt;
&lt;br /&gt;
    local order = z._order( value );&lt;br /&gt;
    &lt;br /&gt;
    -- Due to round-off effects it is neccesary to limit the returned precision under&lt;br /&gt;
    -- some circumstances because the terminal digits will be inaccurately reported.&lt;br /&gt;
    if order + precision &amp;gt;= 14 then&lt;br /&gt;
        local orig_precision = z._precision( value_string );&lt;br /&gt;
        if order + orig_precision &amp;gt;= 14 then&lt;br /&gt;
            precision = 13 - order;        &lt;br /&gt;
        end        &lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    -- If rounding off, truncate extra digits&lt;br /&gt;
    if precision &amp;lt; current_precision then&lt;br /&gt;
        value = z._round( value, precision );&lt;br /&gt;
        current_precision = z._precision( value );&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    local formatted_num = lang:formatNum( math.abs(value) );&lt;br /&gt;
    local sign;&lt;br /&gt;
    &lt;br /&gt;
    -- Use proper unary minus sign rather than ASCII default&lt;br /&gt;
    if value &amp;lt; 0 then&lt;br /&gt;
        sign = '−';&lt;br /&gt;
    else&lt;br /&gt;
        sign = '';&lt;br /&gt;
    end    &lt;br /&gt;
        &lt;br /&gt;
    -- Handle cases requiring scientific notation&lt;br /&gt;
    if string.find( formatted_num, 'E', 1, true ) ~= nil or math.abs(order) &amp;gt;= 9 then&lt;br /&gt;
        value = value * math.pow( 10, -order );&lt;br /&gt;
        current_precision = current_precision + order;&lt;br /&gt;
        precision = precision + order;&lt;br /&gt;
        formatted_num = lang:formatNum( math.abs(value) );&lt;br /&gt;
    else&lt;br /&gt;
        order = 0;        &lt;br /&gt;
    end&lt;br /&gt;
    formatted_num = sign .. formatted_num;&lt;br /&gt;
    &lt;br /&gt;
    -- Pad with zeros, if needed    &lt;br /&gt;
    if current_precision &amp;lt; precision then&lt;br /&gt;
        local padding;&lt;br /&gt;
        if current_precision &amp;lt;= 0 then&lt;br /&gt;
            if precision &amp;gt; 0 then&lt;br /&gt;
                local zero_sep = lang:formatNum( 1.1 );&lt;br /&gt;
                formatted_num = formatted_num .. zero_sep:sub(2,2);&lt;br /&gt;
&lt;br /&gt;
                padding = precision;&lt;br /&gt;
                if padding &amp;gt; 20 then&lt;br /&gt;
                    padding = 20;&lt;br /&gt;
                end&lt;br /&gt;
                &lt;br /&gt;
                formatted_num = formatted_num .. string.rep( '0', padding );&lt;br /&gt;
            end            &lt;br /&gt;
        else                   &lt;br /&gt;
            padding = precision - current_precision&lt;br /&gt;
            if padding &amp;gt; 20 then&lt;br /&gt;
                padding = 20;&lt;br /&gt;
            end&lt;br /&gt;
            formatted_num = formatted_num .. string.rep( '0', padding );&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    -- Add exponential notation, if necessary.&lt;br /&gt;
    if order ~= 0 then&lt;br /&gt;
        -- Use proper unary minus sign rather than ASCII default&lt;br /&gt;
        if order &amp;lt; 0 then&lt;br /&gt;
            order = '−' .. lang:formatNum( math.abs(order) );&lt;br /&gt;
        else&lt;br /&gt;
            order = lang:formatNum( order );&lt;br /&gt;
        end    &lt;br /&gt;
        &lt;br /&gt;
        formatted_num = formatted_num .. '&amp;lt;span style=&amp;quot;margin:0 .15em 0 .25em&amp;quot;&amp;gt;×&amp;lt;/span&amp;gt;10&amp;lt;sup&amp;gt;' .. order .. '&amp;lt;/sup&amp;gt;'&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    return formatted_num;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Helper function that interprets the input numerically.  If the &lt;br /&gt;
input does not appear to be a number, attempts evaluating it as&lt;br /&gt;
a parser functions expression.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function z._cleanNumber( frame, number_string )&lt;br /&gt;
    if number_string == nil or number_string:len() == 0 then&lt;br /&gt;
        return nil, nil;&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    -- Attempt basic conversion&lt;br /&gt;
    local number = tonumber( number_string )&lt;br /&gt;
    &lt;br /&gt;
    -- If failed, attempt to evaluate input as an expression&lt;br /&gt;
    if number == nil then        &lt;br /&gt;
        local attempt = frame:preprocess( '{{#expr: ' .. number_string .. '}}' );&lt;br /&gt;
        attempt = tonumber( attempt );&lt;br /&gt;
        if attempt ~= nil then&lt;br /&gt;
            number = attempt;&lt;br /&gt;
            number_string = tostring( number );&lt;br /&gt;
        else&lt;br /&gt;
            number = nil;&lt;br /&gt;
            number_string = nil;&lt;br /&gt;
        end&lt;br /&gt;
    else&lt;br /&gt;
    -- String is valid but may contain padding, clean it.&lt;br /&gt;
        number_string = number_string:match( &amp;quot;^%s*(.-)%s*$&amp;quot; );&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    return number, number_string;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return z&lt;/div&gt;</summary>
		<author><name>Arthur</name></author>
	</entry>
	<entry>
		<id>https://baripedia.org/index.php?title=Module:Math&amp;diff=13897&amp;oldid=prev</id>
		<title>Arthur : 1 version</title>
		<link rel="alternate" type="text/html" href="https://baripedia.org/index.php?title=Module:Math&amp;diff=13897&amp;oldid=prev"/>
		<updated>2014-07-18T22:02:52Z</updated>

		<summary type="html">&lt;p&gt;1 version&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nouvelle page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;--[[&lt;br /&gt;
&lt;br /&gt;
This module provides a number of basic mathematical operations.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local yesno, getArgs -- lazily initialized&lt;br /&gt;
&lt;br /&gt;
local p = {} -- Holds functions to be returned from #invoke, and functions to make available to other Lua modules.&lt;br /&gt;
local wrap = {} -- Holds wrapper functions that process arguments from #invoke. These act as intemediary between functions meant for #invoke and functions meant for Lua.&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Helper functions used to avoid redundant code.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function err(msg)&lt;br /&gt;
	-- Generates wikitext error messages.&lt;br /&gt;
	return mw.ustring.format('&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: %s&amp;lt;/strong&amp;gt;', msg)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function unpackNumberArgs(args)&lt;br /&gt;
	-- Returns an unpacked list of arguments specified with numerical keys.&lt;br /&gt;
	local ret = {}&lt;br /&gt;
	for k, v in pairs(args) do&lt;br /&gt;
		if type(k) == 'number' then&lt;br /&gt;
			table.insert(ret, v)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return unpack(ret)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function makeArgArray(...)&lt;br /&gt;
	-- Makes an array of arguments from a list of arguments that might include nils.&lt;br /&gt;
	local args = {...} -- Table of arguments. It might contain nils or non-number values, so we can't use ipairs.&lt;br /&gt;
	local nums = {} -- Stores the numbers of valid numerical arguments.&lt;br /&gt;
	local ret = {}&lt;br /&gt;
	for k, v in pairs(args) do&lt;br /&gt;
		v = p._cleanNumber(v)&lt;br /&gt;
		if v then&lt;br /&gt;
			nums[#nums + 1] = k&lt;br /&gt;
			args[k] = v&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	table.sort(nums)&lt;br /&gt;
	for i, num in ipairs(nums) do&lt;br /&gt;
		ret[#ret + 1] = args[num]&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function applyFuncToArgs(func, ...)&lt;br /&gt;
	-- Use a function on all supplied arguments, and return the result. The function must accept two numbers as parameters,&lt;br /&gt;
	-- and must return a number as an output. This number is then supplied as input to the next function call.&lt;br /&gt;
	local vals = makeArgArray(...)	&lt;br /&gt;
	local count = #vals -- The number of valid arguments&lt;br /&gt;
	if count == 0 then return&lt;br /&gt;
		-- Exit if we have no valid args, otherwise removing the first arg would cause an error.&lt;br /&gt;
		nil, 0&lt;br /&gt;
	end &lt;br /&gt;
	local ret = table.remove(vals, 1)&lt;br /&gt;
	for _, val in ipairs(vals) do&lt;br /&gt;
		ret = func(ret, val)&lt;br /&gt;
	end&lt;br /&gt;
	return ret, count&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
random&lt;br /&gt;
&lt;br /&gt;
Generate a random number&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke: Math | random }}&lt;br /&gt;
{{#invoke: Math | random | maximum value }}&lt;br /&gt;
{{#invoke: Math | random | minimum value | maximum value }}&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.random(args)&lt;br /&gt;
	local first = p._cleanNumber(args[1])&lt;br /&gt;
	local second = p._cleanNumber(args[2])&lt;br /&gt;
	return p._random(first, second)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._random(first, second)&lt;br /&gt;
	math.randomseed(mw.site.stats.edits + mw.site.stats.pages + os.time() + math.floor(os.clock() * 1000000000))&lt;br /&gt;
	-- math.random will throw an error if given an explicit nil parameter, so we need to use if statements to check the params.&lt;br /&gt;
	if first and second then&lt;br /&gt;
		if first &amp;lt;= second then -- math.random doesn't allow the first number to be greater than the second.&lt;br /&gt;
			return math.random(first, second)&lt;br /&gt;
		end&lt;br /&gt;
	elseif first then&lt;br /&gt;
		return math.random(first)&lt;br /&gt;
	else&lt;br /&gt;
		return math.random()&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
order&lt;br /&gt;
&lt;br /&gt;
Determine order of magnitude of a number&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke: Math | order | value }}&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.order(args)&lt;br /&gt;
	local input_string = (args[1] or args.x or '0');&lt;br /&gt;
	local input_number = p._cleanNumber(input_string);&lt;br /&gt;
	if input_number == nil then&lt;br /&gt;
		return err('order of magnitude input appears non-numeric')&lt;br /&gt;
	else&lt;br /&gt;
		return p._order(input_number)&lt;br /&gt;
	end    &lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._order(x)&lt;br /&gt;
	if x == 0 then return 0 end&lt;br /&gt;
	return math.floor(math.log10(math.abs(x)))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
precision&lt;br /&gt;
&lt;br /&gt;
Detemines the precision of a number using the string representation&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{ #invoke: Math | precision | value }}&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.precision(args)&lt;br /&gt;
	local input_string = (args[1] or args.x or '0');&lt;br /&gt;
	local trap_fraction = args.check_fraction;&lt;br /&gt;
	local input_number;&lt;br /&gt;
&lt;br /&gt;
	if not yesno then&lt;br /&gt;
		yesno = require('Module:Yesno')&lt;br /&gt;
	end&lt;br /&gt;
	if yesno(trap_fraction, true) then -- Returns true for all input except nil, false, &amp;quot;no&amp;quot;, &amp;quot;n&amp;quot;, &amp;quot;0&amp;quot; and a few others. See [[Module:Yesno]].&lt;br /&gt;
		local pos = string.find(input_string, '/', 1, true);&lt;br /&gt;
		if pos ~= nil then&lt;br /&gt;
			if string.find(input_string, '/', pos + 1, true) == nil then&lt;br /&gt;
				local denominator = string.sub(input_string, pos+1, -1);&lt;br /&gt;
				local denom_value = tonumber(denominator);&lt;br /&gt;
				if denom_value ~= nil then&lt;br /&gt;
					return math.log10(denom_value);&lt;br /&gt;
				end&lt;br /&gt;
			end                        &lt;br /&gt;
		end&lt;br /&gt;
	end    &lt;br /&gt;
&lt;br /&gt;
	input_number, input_string = p._cleanNumber(input_string);&lt;br /&gt;
	if input_string == nil then&lt;br /&gt;
		return err('precision input appears non-numeric')&lt;br /&gt;
	else&lt;br /&gt;
		return p._precision(input_string)&lt;br /&gt;
	end    &lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._precision(x)&lt;br /&gt;
	if type(x) == 'number' then&lt;br /&gt;
		x = tostring(x)&lt;br /&gt;
	end&lt;br /&gt;
	x = string.upper(x)&lt;br /&gt;
&lt;br /&gt;
	local decimal = x:find('%.')&lt;br /&gt;
	local exponent_pos = x:find('E')&lt;br /&gt;
	local result = 0;&lt;br /&gt;
&lt;br /&gt;
	if exponent_pos ~= nil then&lt;br /&gt;
		local exponent = string.sub(x, exponent_pos + 1)&lt;br /&gt;
		x = string.sub(x, 1, exponent_pos - 1)&lt;br /&gt;
		result = result - tonumber(exponent)&lt;br /&gt;
	end    &lt;br /&gt;
&lt;br /&gt;
	if decimal ~= nil then&lt;br /&gt;
		result = result + string.len(x) - decimal&lt;br /&gt;
		return result&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local pos = string.len(x);&lt;br /&gt;
	while x:byte(pos) == string.byte('0') do&lt;br /&gt;
		pos = pos - 1&lt;br /&gt;
		result = result - 1&lt;br /&gt;
		if pos &amp;lt;= 0 then&lt;br /&gt;
			return 0&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
max&lt;br /&gt;
&lt;br /&gt;
Finds the maximum argument&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Math| max | value1 | value2 | ... }}&lt;br /&gt;
&lt;br /&gt;
Note, any values that do not evaluate to numbers are ignored.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.max(args)&lt;br /&gt;
	return p._max(unpackNumberArgs(args))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._max(...)&lt;br /&gt;
	local function maxOfTwo(a, b)&lt;br /&gt;
		if a &amp;gt; b then&lt;br /&gt;
			return a&lt;br /&gt;
		else&lt;br /&gt;
			return b&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	local max_value = applyFuncToArgs(maxOfTwo, ...)&lt;br /&gt;
	if max_value then&lt;br /&gt;
		return max_value&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
min &lt;br /&gt;
&lt;br /&gt;
Finds the minimum argument&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Math| min | value1 | value2 | ... }}&lt;br /&gt;
OR&lt;br /&gt;
{{#invoke:Math| min }}&lt;br /&gt;
&lt;br /&gt;
When used with no arguments, it takes its input from the parent&lt;br /&gt;
frame.  Note, any values that do not evaluate to numbers are ignored.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.min(args)&lt;br /&gt;
	return p._min(unpackNumberArgs(args))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._min(...)&lt;br /&gt;
	local function minOfTwo(a, b)&lt;br /&gt;
		if a &amp;lt; b then&lt;br /&gt;
			return a&lt;br /&gt;
		else&lt;br /&gt;
			return b&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	local min_value = applyFuncToArgs(minOfTwo, ...)&lt;br /&gt;
	if min_value then&lt;br /&gt;
		return min_value&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
average &lt;br /&gt;
&lt;br /&gt;
Finds the average&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Math| average | value1 | value2 | ... }}&lt;br /&gt;
OR&lt;br /&gt;
{{#invoke:Math| average }}&lt;br /&gt;
&lt;br /&gt;
Note, any values that do not evaluate to numbers are ignored.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.average(args)&lt;br /&gt;
	return p._average(unpackNumberArgs(args))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._average(...)&lt;br /&gt;
	local function getSum(a, b)&lt;br /&gt;
		return a + b&lt;br /&gt;
	end&lt;br /&gt;
	local sum, count = applyFuncToArgs(getSum, ...)&lt;br /&gt;
	if not sum then&lt;br /&gt;
		return 0&lt;br /&gt;
	else&lt;br /&gt;
		return sum / count&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
round&lt;br /&gt;
&lt;br /&gt;
Rounds a number to specified precision&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Math | round | value | precision }}&lt;br /&gt;
&lt;br /&gt;
--]]&lt;br /&gt;
&lt;br /&gt;
function wrap.round(args)&lt;br /&gt;
	local value = p._cleanNumber(args[1] or args.value or 0)&lt;br /&gt;
	local precision = p._cleanNumber(args[2] or args.precision or 0)&lt;br /&gt;
	if value == nil or precision == nil then&lt;br /&gt;
		return err('round input appears non-numeric')&lt;br /&gt;
	else&lt;br /&gt;
		return p._round(value, precision)&lt;br /&gt;
	end    &lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._round(value, precision)&lt;br /&gt;
	local rescale = math.pow(10, precision or 0);&lt;br /&gt;
	return math.floor(value * rescale + 0.5) / rescale;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
mod&lt;br /&gt;
&lt;br /&gt;
Implements the modulo operator&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Math | mod | x | y }}&lt;br /&gt;
&lt;br /&gt;
--]]&lt;br /&gt;
&lt;br /&gt;
function wrap.mod(args)&lt;br /&gt;
	local x = p._cleanNumber(args[1])&lt;br /&gt;
	local y = p._cleanNumber(args[2])&lt;br /&gt;
	if not x then&lt;br /&gt;
		return err('first argument to mod appears non-numeric')&lt;br /&gt;
	elseif not y then&lt;br /&gt;
		return err('second argument to mod appears non-numeric')&lt;br /&gt;
	else&lt;br /&gt;
		return p._mod(x, y)&lt;br /&gt;
	end    &lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._mod(x, y)&lt;br /&gt;
	local ret = x % y&lt;br /&gt;
	if not (0 &amp;lt;= ret and ret &amp;lt; y) then&lt;br /&gt;
		ret = 0&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
gcd&lt;br /&gt;
&lt;br /&gt;
Calculates the greatest common divisor of multiple numbers&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Math | gcd | value 1 | value 2 | value 3 | ... }}&lt;br /&gt;
--]]&lt;br /&gt;
&lt;br /&gt;
function wrap.gcd(args)&lt;br /&gt;
	return p._gcd(unpackNumberArgs(args))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._gcd(...)&lt;br /&gt;
	local function findGcd(a, b)&lt;br /&gt;
		local r = b&lt;br /&gt;
		local oldr = a&lt;br /&gt;
		while r ~= 0 do&lt;br /&gt;
			local quotient = math.floor(oldr / r)&lt;br /&gt;
			oldr, r = r, oldr - quotient * r&lt;br /&gt;
		end&lt;br /&gt;
		if oldr &amp;lt; 0 then&lt;br /&gt;
			oldr = oldr * -1&lt;br /&gt;
		end&lt;br /&gt;
		return oldr&lt;br /&gt;
	end&lt;br /&gt;
	local result, count = applyFuncToArgs(findGcd, ...)&lt;br /&gt;
	return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
precision_format&lt;br /&gt;
&lt;br /&gt;
Rounds a number to the specified precision and formats according to rules &lt;br /&gt;
originally used for {{template:Rnd}}.  Output is a string.&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke: Math | precision_format | number | precision }}&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.precision_format(args)&lt;br /&gt;
	local value_string = args[1] or 0&lt;br /&gt;
	local precision = args[2] or 0&lt;br /&gt;
	return p._precision_format(value_string, precision)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._precision_format(value_string, precision)&lt;br /&gt;
	-- For access to Mediawiki built-in formatter.&lt;br /&gt;
	local lang = mw.getContentLanguage();&lt;br /&gt;
&lt;br /&gt;
	local value&lt;br /&gt;
	value, value_string = p._cleanNumber(value_string)&lt;br /&gt;
	precision = p._cleanNumber(precision)&lt;br /&gt;
&lt;br /&gt;
	-- Check for non-numeric input&lt;br /&gt;
	if value == nil or precision == nil then&lt;br /&gt;
		return err('invalid input when rounding')&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local current_precision = p._precision(value)&lt;br /&gt;
	local order = p._order(value)&lt;br /&gt;
&lt;br /&gt;
	-- Due to round-off effects it is neccesary to limit the returned precision under&lt;br /&gt;
	-- some circumstances because the terminal digits will be inaccurately reported.&lt;br /&gt;
	if order + precision &amp;gt;= 14 then&lt;br /&gt;
		orig_precision = p._precision(value_string)&lt;br /&gt;
		if order + orig_precision &amp;gt;= 14 then&lt;br /&gt;
			precision = 13 - order;        &lt;br /&gt;
		end        &lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- If rounding off, truncate extra digits&lt;br /&gt;
	if precision &amp;lt; current_precision then&lt;br /&gt;
		value = p._round(value, precision)&lt;br /&gt;
		current_precision = p._precision(value)&lt;br /&gt;
	end    &lt;br /&gt;
&lt;br /&gt;
	local formatted_num = lang:formatNum(math.abs(value))&lt;br /&gt;
	local sign&lt;br /&gt;
&lt;br /&gt;
	-- Use proper unary minus sign rather than ASCII default&lt;br /&gt;
	if value &amp;lt; 0 then&lt;br /&gt;
		sign = '−'&lt;br /&gt;
	else&lt;br /&gt;
		sign = ''&lt;br /&gt;
	end    &lt;br /&gt;
&lt;br /&gt;
	-- Handle cases requiring scientific notation&lt;br /&gt;
	if string.find(formatted_num, 'E', 1, true) ~= nil or math.abs(order) &amp;gt;= 9 then&lt;br /&gt;
		value = value * math.pow(10, -order)&lt;br /&gt;
		current_precision = current_precision + order&lt;br /&gt;
		precision = precision + order&lt;br /&gt;
		formatted_num = lang:formatNum(math.abs(value))&lt;br /&gt;
	else&lt;br /&gt;
		order = 0;        &lt;br /&gt;
	end&lt;br /&gt;
	formatted_num = sign .. formatted_num&lt;br /&gt;
&lt;br /&gt;
	-- Pad with zeros, if needed    &lt;br /&gt;
	if current_precision &amp;lt; precision then&lt;br /&gt;
		local padding&lt;br /&gt;
		if current_precision &amp;lt;= 0 then&lt;br /&gt;
			if precision &amp;gt; 0 then&lt;br /&gt;
				local zero_sep = lang:formatNum(1.1)&lt;br /&gt;
				formatted_num = formatted_num .. zero_sep:sub(2,2)&lt;br /&gt;
&lt;br /&gt;
				padding = precision&lt;br /&gt;
				if padding &amp;gt; 20 then&lt;br /&gt;
					padding = 20&lt;br /&gt;
				end&lt;br /&gt;
&lt;br /&gt;
				formatted_num = formatted_num .. string.rep('0', padding)&lt;br /&gt;
			end            &lt;br /&gt;
		else                   &lt;br /&gt;
			padding = precision - current_precision&lt;br /&gt;
			if padding &amp;gt; 20 then&lt;br /&gt;
				padding = 20&lt;br /&gt;
			end&lt;br /&gt;
			formatted_num = formatted_num .. string.rep('0', padding)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Add exponential notation, if necessary.&lt;br /&gt;
	if order ~= 0 then&lt;br /&gt;
		-- Use proper unary minus sign rather than ASCII default&lt;br /&gt;
		if order &amp;lt; 0 then&lt;br /&gt;
			order = '−' .. lang:formatNum(math.abs(order))&lt;br /&gt;
		else&lt;br /&gt;
			order = lang:formatNum(order)&lt;br /&gt;
		end    &lt;br /&gt;
&lt;br /&gt;
		formatted_num = formatted_num .. '&amp;lt;span style=&amp;quot;margin:0 .15em 0 .25em&amp;quot;&amp;gt;×&amp;lt;/span&amp;gt;10&amp;lt;sup&amp;gt;' .. order .. '&amp;lt;/sup&amp;gt;'&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return formatted_num&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Helper function that interprets the input numerically.  If the &lt;br /&gt;
input does not appear to be a number, attempts evaluating it as&lt;br /&gt;
a parser functions expression.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function p._cleanNumber(number_string)&lt;br /&gt;
	if type(number_string) == 'number' then&lt;br /&gt;
		-- We were passed a number, so we don't need to do any processing.&lt;br /&gt;
		return number_string, tostring(number_string)&lt;br /&gt;
	elseif type(number_string) ~= 'string' or not number_string:find('%S') then&lt;br /&gt;
		-- We were passed a non-string or a blank string, so exit.&lt;br /&gt;
		return nil, nil;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Attempt basic conversion&lt;br /&gt;
	local number = tonumber(number_string)&lt;br /&gt;
&lt;br /&gt;
	-- If failed, attempt to evaluate input as an expression&lt;br /&gt;
	if number == nil then&lt;br /&gt;
		local success, result = pcall(mw.ext.ParserFunctions.expr, number_string)&lt;br /&gt;
		if success then&lt;br /&gt;
			number = tonumber(result)&lt;br /&gt;
			number_string = tostring(number)&lt;br /&gt;
		else&lt;br /&gt;
			number = nil&lt;br /&gt;
			number_string = nil&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		number_string = number_string:match(&amp;quot;^%s*(.-)%s*$&amp;quot;) -- String is valid but may contain padding, clean it.&lt;br /&gt;
		number_string = number_string:match(&amp;quot;^%+(.*)$&amp;quot;) or number_string -- Trim any leading + signs.&lt;br /&gt;
		if number_string:find('^%-?0[xX]') then&lt;br /&gt;
			-- Number is using 0xnnn notation to indicate base 16; use the number that Lua detected instead.&lt;br /&gt;
			number_string = tostring(number)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return number, number_string&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Wrapper function that does basic argument processing. This ensures that all functions from #invoke can use either the current&lt;br /&gt;
frame or the parent frame, and it also trims whitespace for all arguments and removes blank arguments.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local mt = { __index = function(t, k)&lt;br /&gt;
	return function(frame)&lt;br /&gt;
		if not getArgs then&lt;br /&gt;
			getArgs = require('Module:Arguments').getArgs&lt;br /&gt;
		end&lt;br /&gt;
		return wrap[k](getArgs(frame))  -- Argument processing is left to Module:Arguments. Whitespace is trimmed and blank arguments are removed.&lt;br /&gt;
	end&lt;br /&gt;
end }&lt;br /&gt;
&lt;br /&gt;
return setmetatable(p, mt)&lt;/div&gt;</summary>
		<author><name>Arthur</name></author>
	</entry>
	<entry>
		<id>https://baripedia.org/index.php?title=Module:Math&amp;diff=11824&amp;oldid=prev</id>
		<title>Arthur : 1 version</title>
		<link rel="alternate" type="text/html" href="https://baripedia.org/index.php?title=Module:Math&amp;diff=11824&amp;oldid=prev"/>
		<updated>2014-05-02T22:06:38Z</updated>

		<summary type="html">&lt;p&gt;1 version&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nouvelle page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;--[[&lt;br /&gt;
&lt;br /&gt;
This module provides a number of basic mathematical operations.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
local z = {}&lt;br /&gt;
&lt;br /&gt;
-- Generate random number&lt;br /&gt;
function z.random( frame )&lt;br /&gt;
    first = tonumber(frame.args[1]) -- if it doesn't exist it's NaN, if not a number it's nil&lt;br /&gt;
    second = tonumber(frame.args[2])&lt;br /&gt;
&lt;br /&gt;
    if first then -- if NaN or nil, will skip down to final return&lt;br /&gt;
        if first &amp;lt;= second then -- could match if both nil, but already checked that first is a number in last line&lt;br /&gt;
            return math.random(first, second)&lt;br /&gt;
        end&lt;br /&gt;
        return math.random(first)&lt;br /&gt;
    end   &lt;br /&gt;
    return math.random()&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
order&lt;br /&gt;
&lt;br /&gt;
Determine order of magnitude of a number&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke: Math | order | value }}&lt;br /&gt;
]]&lt;br /&gt;
function z.order(frame)&lt;br /&gt;
    local input_string = (frame.args[1] or frame.args.x or '0');&lt;br /&gt;
    local input_number;&lt;br /&gt;
    &lt;br /&gt;
    input_number = z._cleanNumber( frame, input_string );&lt;br /&gt;
    if input_number == nil then&lt;br /&gt;
        return '&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: Order of magnitude input appears non-numeric&amp;lt;/strong&amp;gt;'&lt;br /&gt;
    else&lt;br /&gt;
        return z._order( input_number )&lt;br /&gt;
    end    &lt;br /&gt;
end&lt;br /&gt;
function z._order(x)&lt;br /&gt;
    if x == 0 then return 0 end&lt;br /&gt;
    return math.floor(math.log10(math.abs(x)))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
precision&lt;br /&gt;
&lt;br /&gt;
Detemines the precision of a number using the string representation&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{ #invoke: Math | precision | value }}&lt;br /&gt;
]]&lt;br /&gt;
function z.precision( frame )&lt;br /&gt;
    local input_string = (frame.args[1] or frame.args.x or '0');&lt;br /&gt;
    local trap_fraction = frame.args.check_fraction or false;&lt;br /&gt;
    local input_number;&lt;br /&gt;
    &lt;br /&gt;
    if type( trap_fraction ) == 'string' then&lt;br /&gt;
        trap_fraction = trap_fraction:lower();&lt;br /&gt;
        if trap_fraction == 'false' or trap_fraction == '0' or&lt;br /&gt;
                trap_fraction == 'no' or trap_fraction == '' then&lt;br /&gt;
            trap_fraction = false;&lt;br /&gt;
        else&lt;br /&gt;
            trap_fraction = true;&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    if trap_fraction then&lt;br /&gt;
        local pos = string.find( input_string, '/', 1, true );&lt;br /&gt;
        if pos ~= nil then&lt;br /&gt;
            if string.find( input_string, '/', pos + 1, true ) == nil then&lt;br /&gt;
                local denominator = string.sub( input_string, pos+1, -1 );&lt;br /&gt;
                local denom_value = tonumber( denominator );&lt;br /&gt;
                if denom_value ~= nil then&lt;br /&gt;
                    return math.log10(denom_value);&lt;br /&gt;
                end&lt;br /&gt;
            end                        &lt;br /&gt;
        end&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    input_number, input_string = z._cleanNumber( frame, input_string );&lt;br /&gt;
    if input_string == nil then&lt;br /&gt;
        return '&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: Precision input appears non-numeric&amp;lt;/strong&amp;gt;'&lt;br /&gt;
    else&lt;br /&gt;
        return z._precision( input_string )&lt;br /&gt;
    end    &lt;br /&gt;
end&lt;br /&gt;
function z._precision( x )    &lt;br /&gt;
    x = string.upper( x )&lt;br /&gt;
&lt;br /&gt;
    local decimal = string.find( x, '.', 1, true )&lt;br /&gt;
    local exponent_pos = string.find( x, 'E', 1, true )&lt;br /&gt;
    local result = 0;&lt;br /&gt;
    &lt;br /&gt;
    if exponent_pos ~= nil then&lt;br /&gt;
        local exponent = string.sub( x, exponent_pos + 1 )&lt;br /&gt;
        x = string.sub( x, 1, exponent_pos - 1 )&lt;br /&gt;
        result = result - tonumber( exponent )&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    if decimal ~= nil then&lt;br /&gt;
        result = result + string.len( x ) - decimal&lt;br /&gt;
        return result&lt;br /&gt;
    end&lt;br /&gt;
        &lt;br /&gt;
    local pos = string.len( x );&lt;br /&gt;
    while x:byte(pos) == string.byte('0') do&lt;br /&gt;
        pos = pos - 1&lt;br /&gt;
        result = result - 1&lt;br /&gt;
        if pos &amp;lt;= 0 then&lt;br /&gt;
            return 0&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
max&lt;br /&gt;
&lt;br /&gt;
Finds the maximum argument&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke:Math| max | value1 | value2 | ... }}&lt;br /&gt;
OR&lt;br /&gt;
    {{#invoke:Math| max }}&lt;br /&gt;
&lt;br /&gt;
When used with no arguments, it takes its input from the parent&lt;br /&gt;
frame.  Note, any values that do not evaluate to numbers are ignored.&lt;br /&gt;
]]&lt;br /&gt;
function z.max( frame )&lt;br /&gt;
    local args = frame.args;&lt;br /&gt;
    &lt;br /&gt;
    if args[1] == nil then&lt;br /&gt;
        local parent = frame:getParent();&lt;br /&gt;
        args = parent.args;&lt;br /&gt;
    end&lt;br /&gt;
    local max_value = nil;&lt;br /&gt;
    &lt;br /&gt;
    local i = 1;&lt;br /&gt;
    while args[i] ~= nil do&lt;br /&gt;
        local val = z._cleanNumber( frame, args[i] );&lt;br /&gt;
        if val ~= nil then&lt;br /&gt;
            if max_value == nil or val &amp;gt; max_value then&lt;br /&gt;
                max_value = val;&lt;br /&gt;
            end&lt;br /&gt;
        end        &lt;br /&gt;
        i = i + 1;&lt;br /&gt;
    end&lt;br /&gt;
  &lt;br /&gt;
    return max_value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
min &lt;br /&gt;
&lt;br /&gt;
Finds the minimum argument&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke:Math| min | value1 | value2 | ... }}&lt;br /&gt;
OR&lt;br /&gt;
    {{#invoke:Math| min }}&lt;br /&gt;
&lt;br /&gt;
When used with no arguments, it takes its input from the parent&lt;br /&gt;
frame.  Note, any values that do not evaluate to numbers are ignored.&lt;br /&gt;
]]&lt;br /&gt;
function z.min( frame )&lt;br /&gt;
    local args = frame.args;&lt;br /&gt;
    &lt;br /&gt;
    if args[1] == nil then&lt;br /&gt;
        local parent = frame:getParent();&lt;br /&gt;
        args = parent.args;&lt;br /&gt;
    end&lt;br /&gt;
    local min_value = nil;&lt;br /&gt;
    &lt;br /&gt;
    local i = 1;&lt;br /&gt;
    while args[i] ~= nil do&lt;br /&gt;
        local val = z._cleanNumber( frame, args[i] );&lt;br /&gt;
        if val ~= nil then&lt;br /&gt;
            if min_value == nil or val &amp;lt; min_value then&lt;br /&gt;
                min_value = val;&lt;br /&gt;
            end&lt;br /&gt;
        end        &lt;br /&gt;
        i = i + 1;&lt;br /&gt;
    end&lt;br /&gt;
  &lt;br /&gt;
    return min_value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
round&lt;br /&gt;
&lt;br /&gt;
Rounds a number to specified precision&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke:Math | round | value | precision }}&lt;br /&gt;
    &lt;br /&gt;
--]]&lt;br /&gt;
function z.round(frame)&lt;br /&gt;
    local value, precision;&lt;br /&gt;
    &lt;br /&gt;
    value = z._cleanNumber( frame, frame.args[1] or frame.args.value or 0 );&lt;br /&gt;
    precision = z._cleanNumber( frame, frame.args[2] or frame.args.precision or 0 );&lt;br /&gt;
    &lt;br /&gt;
    if value == nil or precision == nil then&lt;br /&gt;
        return '&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: Round input appears non-numeric&amp;lt;/strong&amp;gt;'&lt;br /&gt;
    else&lt;br /&gt;
        return z._round( value, precision );&lt;br /&gt;
    end    &lt;br /&gt;
end&lt;br /&gt;
function z._round( value, precision )&lt;br /&gt;
    local rescale = math.pow( 10, precision );&lt;br /&gt;
    return math.floor( value * rescale + 0.5 ) / rescale;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
precision_format&lt;br /&gt;
&lt;br /&gt;
Rounds a number to the specified precision and formats according to rules &lt;br /&gt;
originally used for {{template:Rnd}}.  Output is a string.&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke: Math | precision_format | number | precision }}&lt;br /&gt;
]]&lt;br /&gt;
function z.precision_format( frame )&lt;br /&gt;
    -- For access to Mediawiki built-in formatter.&lt;br /&gt;
    local lang = mw.getContentLanguage();&lt;br /&gt;
    &lt;br /&gt;
    local value_string, value, precision;&lt;br /&gt;
    value, value_string = z._cleanNumber( frame, frame.args[1] or 0 );&lt;br /&gt;
    precision = z._cleanNumber( frame, frame.args[2] or 0 );&lt;br /&gt;
    &lt;br /&gt;
    -- Check for non-numeric input&lt;br /&gt;
    if value == nil or precision == nil then&lt;br /&gt;
        return '&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: invalid input when rounding&amp;lt;/strong&amp;gt;'&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    local current_precision = z._precision( value );&lt;br /&gt;
&lt;br /&gt;
    local order = z._order( value );&lt;br /&gt;
    &lt;br /&gt;
    -- Due to round-off effects it is neccesary to limit the returned precision under&lt;br /&gt;
    -- some circumstances because the terminal digits will be inaccurately reported.&lt;br /&gt;
    if order + precision &amp;gt;= 14 then&lt;br /&gt;
        orig_precision = z._precision( value_string );&lt;br /&gt;
        if order + orig_precision &amp;gt;= 14 then&lt;br /&gt;
            precision = 13 - order;        &lt;br /&gt;
        end        &lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    -- If rounding off, truncate extra digits&lt;br /&gt;
    if precision &amp;lt; current_precision then&lt;br /&gt;
        value = z._round( value, precision );&lt;br /&gt;
        current_precision = z._precision( value );&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    local formatted_num = lang:formatNum( math.abs(value) );&lt;br /&gt;
    local sign;&lt;br /&gt;
    &lt;br /&gt;
    -- Use proper unary minus sign rather than ASCII default&lt;br /&gt;
    if value &amp;lt; 0 then&lt;br /&gt;
        sign = '−';&lt;br /&gt;
    else&lt;br /&gt;
        sign = '';&lt;br /&gt;
    end    &lt;br /&gt;
        &lt;br /&gt;
    -- Handle cases requiring scientific notation&lt;br /&gt;
    if string.find( formatted_num, 'E', 1, true ) ~= nil or math.abs(order) &amp;gt;= 9 then&lt;br /&gt;
        value = value * math.pow( 10, -order );&lt;br /&gt;
        current_precision = current_precision + order;&lt;br /&gt;
        precision = precision + order;&lt;br /&gt;
        formatted_num = lang:formatNum( math.abs(value) );&lt;br /&gt;
    else&lt;br /&gt;
        order = 0;        &lt;br /&gt;
    end&lt;br /&gt;
    formatted_num = sign .. formatted_num;&lt;br /&gt;
    &lt;br /&gt;
    -- Pad with zeros, if needed    &lt;br /&gt;
    if current_precision &amp;lt; precision then&lt;br /&gt;
        local padding;&lt;br /&gt;
        if current_precision &amp;lt;= 0 then&lt;br /&gt;
            if precision &amp;gt; 0 then&lt;br /&gt;
                local zero_sep = lang:formatNum( 1.1 );&lt;br /&gt;
                formatted_num = formatted_num .. zero_sep:sub(2,2);&lt;br /&gt;
&lt;br /&gt;
                padding = precision;&lt;br /&gt;
                if padding &amp;gt; 20 then&lt;br /&gt;
                    padding = 20;&lt;br /&gt;
                end&lt;br /&gt;
                &lt;br /&gt;
                formatted_num = formatted_num .. string.rep( '0', padding );&lt;br /&gt;
            end            &lt;br /&gt;
        else                   &lt;br /&gt;
            padding = precision - current_precision&lt;br /&gt;
            if padding &amp;gt; 20 then&lt;br /&gt;
                padding = 20;&lt;br /&gt;
            end&lt;br /&gt;
            formatted_num = formatted_num .. string.rep( '0', padding );&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    -- Add exponential notation, if necessary.&lt;br /&gt;
    if order ~= 0 then&lt;br /&gt;
        -- Use proper unary minus sign rather than ASCII default&lt;br /&gt;
        if order &amp;lt; 0 then&lt;br /&gt;
            order = '−' .. lang:formatNum( math.abs(order) );&lt;br /&gt;
        else&lt;br /&gt;
            order = lang:formatNum( order );&lt;br /&gt;
        end    &lt;br /&gt;
        &lt;br /&gt;
        formatted_num = formatted_num .. '&amp;lt;span style=&amp;quot;margin:0 .15em 0 .25em&amp;quot;&amp;gt;×&amp;lt;/span&amp;gt;10&amp;lt;sup&amp;gt;' .. order .. '&amp;lt;/sup&amp;gt;'&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    return formatted_num;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Helper function that interprets the input numerically.  If the &lt;br /&gt;
input does not appear to be a number, attempts evaluating it as&lt;br /&gt;
a parser functions expression.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function z._cleanNumber( frame, number_string )&lt;br /&gt;
    if number_string == nil or number_string:len() == 0 then&lt;br /&gt;
        return nil, nil;&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    -- Attempt basic conversion&lt;br /&gt;
    local number = tonumber( number_string )&lt;br /&gt;
    &lt;br /&gt;
    -- If failed, attempt to evaluate input as an expression&lt;br /&gt;
    if number == nil then        &lt;br /&gt;
        local attempt = frame:preprocess( '{{#expr: ' .. number_string .. '}}' );&lt;br /&gt;
        attempt = tonumber( attempt );&lt;br /&gt;
        if attempt ~= nil then&lt;br /&gt;
            number = attempt;&lt;br /&gt;
            number_string = tostring( number );&lt;br /&gt;
        else&lt;br /&gt;
            number = nil;&lt;br /&gt;
            number_string = nil;&lt;br /&gt;
        end&lt;br /&gt;
    else&lt;br /&gt;
    -- String is valid but may contain padding, clean it.&lt;br /&gt;
        number_string = number_string:match( &amp;quot;^%s*(.-)%s*$&amp;quot; );&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    return number, number_string;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return z&lt;/div&gt;</summary>
		<author><name>Arthur</name></author>
	</entry>
	<entry>
		<id>https://baripedia.org/index.php?title=Module:Math&amp;diff=7569&amp;oldid=prev</id>
		<title>Arthur : 1 version</title>
		<link rel="alternate" type="text/html" href="https://baripedia.org/index.php?title=Module:Math&amp;diff=7569&amp;oldid=prev"/>
		<updated>2014-01-13T22:01:23Z</updated>

		<summary type="html">&lt;p&gt;1 version&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nouvelle page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;--[[&lt;br /&gt;
&lt;br /&gt;
This module provides a number of basic mathematical operations.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
local z = {}&lt;br /&gt;
&lt;br /&gt;
-- Generate random number&lt;br /&gt;
function z.random( frame )&lt;br /&gt;
    first = tonumber(frame.args[1]) -- if it doesn't exist it's NaN, if not a number it's nil&lt;br /&gt;
    second = tonumber(frame.args[2])&lt;br /&gt;
&lt;br /&gt;
    if first then -- if NaN or nil, will skip down to final return&lt;br /&gt;
        if first &amp;lt;= second then -- could match if both nil, but already checked that first is a number in last line&lt;br /&gt;
            return math.random(first, second)&lt;br /&gt;
        end&lt;br /&gt;
        return math.random(first)&lt;br /&gt;
    end   &lt;br /&gt;
    return math.random()&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
order&lt;br /&gt;
&lt;br /&gt;
Determine order of magnitude of a number&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke: Math | order | value }}&lt;br /&gt;
]]&lt;br /&gt;
function z.order(frame)&lt;br /&gt;
    local input_string = (frame.args[1] or frame.args.x or '0');&lt;br /&gt;
    local input_number;&lt;br /&gt;
    &lt;br /&gt;
    input_number = z._cleanNumber( frame, input_string );&lt;br /&gt;
    if input_number == nil then&lt;br /&gt;
        return '&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: Order of magnitude input appears non-numeric&amp;lt;/strong&amp;gt;'&lt;br /&gt;
    else&lt;br /&gt;
        return z._order( input_number )&lt;br /&gt;
    end    &lt;br /&gt;
end&lt;br /&gt;
function z._order(x)&lt;br /&gt;
    if x == 0 then return 0 end&lt;br /&gt;
    return math.floor(math.log10(math.abs(x)))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
precision&lt;br /&gt;
&lt;br /&gt;
Detemines the precision of a number using the string representation&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{ #invoke: Math | precision | value }}&lt;br /&gt;
]]&lt;br /&gt;
function z.precision( frame )&lt;br /&gt;
    local input_string = (frame.args[1] or frame.args.x or '0');&lt;br /&gt;
    local trap_fraction = frame.args.check_fraction or false;&lt;br /&gt;
    local input_number;&lt;br /&gt;
    &lt;br /&gt;
    if type( trap_fraction ) == 'string' then&lt;br /&gt;
        trap_fraction = trap_fraction:lower();&lt;br /&gt;
        if trap_fraction == 'false' or trap_fraction == '0' or&lt;br /&gt;
                trap_fraction == 'no' or trap_fraction == '' then&lt;br /&gt;
            trap_fraction = false;&lt;br /&gt;
        else&lt;br /&gt;
            trap_fraction = true;&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    if trap_fraction then&lt;br /&gt;
        local pos = string.find( input_string, '/', 1, true );&lt;br /&gt;
        if pos ~= nil then&lt;br /&gt;
            if string.find( input_string, '/', pos + 1, true ) == nil then&lt;br /&gt;
                local denominator = string.sub( input_string, pos+1, -1 );&lt;br /&gt;
                local denom_value = tonumber( denominator );&lt;br /&gt;
                if denom_value ~= nil then&lt;br /&gt;
                    return math.log10(denom_value);&lt;br /&gt;
                end&lt;br /&gt;
            end                        &lt;br /&gt;
        end&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    input_number, input_string = z._cleanNumber( frame, input_string );&lt;br /&gt;
    if input_string == nil then&lt;br /&gt;
        return '&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: Precision input appears non-numeric&amp;lt;/strong&amp;gt;'&lt;br /&gt;
    else&lt;br /&gt;
        return z._precision( input_string )&lt;br /&gt;
    end    &lt;br /&gt;
end&lt;br /&gt;
function z._precision( x )    &lt;br /&gt;
    x = string.upper( x )&lt;br /&gt;
&lt;br /&gt;
    local decimal = string.find( x, '.', 1, true )&lt;br /&gt;
    local exponent_pos = string.find( x, 'E', 1, true )&lt;br /&gt;
    local result = 0;&lt;br /&gt;
    &lt;br /&gt;
    if exponent_pos ~= nil then&lt;br /&gt;
        local exponent = string.sub( x, exponent_pos + 1 )&lt;br /&gt;
        x = string.sub( x, 1, exponent_pos - 1 )&lt;br /&gt;
        result = result - tonumber( exponent )&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    if decimal ~= nil then&lt;br /&gt;
        result = result + string.len( x ) - decimal&lt;br /&gt;
        return result&lt;br /&gt;
    end&lt;br /&gt;
        &lt;br /&gt;
    local pos = string.len( x );&lt;br /&gt;
    while x:byte(pos) == string.byte('0') do&lt;br /&gt;
        pos = pos - 1&lt;br /&gt;
        result = result - 1&lt;br /&gt;
        if pos &amp;lt;= 0 then&lt;br /&gt;
            return 0&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
max&lt;br /&gt;
&lt;br /&gt;
Finds the maximum argument&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke:Math| max | value1 | value2 | ... }}&lt;br /&gt;
OR&lt;br /&gt;
    {{#invoke:Math| max }}&lt;br /&gt;
&lt;br /&gt;
When used with no arguments, it takes its input from the parent&lt;br /&gt;
frame.  Note, any values that do not evaluate to numbers are ignored.&lt;br /&gt;
]]&lt;br /&gt;
function z.max( frame )&lt;br /&gt;
    local args = frame.args;&lt;br /&gt;
    &lt;br /&gt;
    if args[1] == nil then&lt;br /&gt;
        local parent = frame:getParent();&lt;br /&gt;
        args = parent.args;&lt;br /&gt;
    end&lt;br /&gt;
    local max_value = nil;&lt;br /&gt;
    &lt;br /&gt;
    local i = 1;&lt;br /&gt;
    while args[i] ~= nil do&lt;br /&gt;
        local val = z._cleanNumber( frame, args[i] );&lt;br /&gt;
        if val ~= nil then&lt;br /&gt;
            if max_value == nil or val &amp;gt; max_value then&lt;br /&gt;
                max_value = val;&lt;br /&gt;
            end&lt;br /&gt;
        end        &lt;br /&gt;
        i = i + 1;&lt;br /&gt;
    end&lt;br /&gt;
  &lt;br /&gt;
    return max_value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
min &lt;br /&gt;
&lt;br /&gt;
Finds the minimum argument&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke:Math| min | value1 | value2 | ... }}&lt;br /&gt;
OR&lt;br /&gt;
    {{#invoke:Math| min }}&lt;br /&gt;
&lt;br /&gt;
When used with no arguments, it takes its input from the parent&lt;br /&gt;
frame.  Note, any values that do not evaluate to numbers are ignored.&lt;br /&gt;
]]&lt;br /&gt;
function z.min( frame )&lt;br /&gt;
    local args = frame.args;&lt;br /&gt;
    &lt;br /&gt;
    if args[1] == nil then&lt;br /&gt;
        local parent = frame:getParent();&lt;br /&gt;
        args = parent.args;&lt;br /&gt;
    end&lt;br /&gt;
    local min_value = nil;&lt;br /&gt;
    &lt;br /&gt;
    local i = 1;&lt;br /&gt;
    while args[i] ~= nil do&lt;br /&gt;
        local val = z._cleanNumber( frame, args[i] );&lt;br /&gt;
        if val ~= nil then&lt;br /&gt;
            if min_value == nil or val &amp;lt; min_value then&lt;br /&gt;
                min_value = val;&lt;br /&gt;
            end&lt;br /&gt;
        end        &lt;br /&gt;
        i = i + 1;&lt;br /&gt;
    end&lt;br /&gt;
  &lt;br /&gt;
    return min_value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
round&lt;br /&gt;
&lt;br /&gt;
Rounds a number to specified precision&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke:Math | round | value | precision }}&lt;br /&gt;
    &lt;br /&gt;
--]]&lt;br /&gt;
function z.round(frame)&lt;br /&gt;
    local value, precision;&lt;br /&gt;
    &lt;br /&gt;
    value = z._cleanNumber( frame, frame.args[1] or frame.args.value or 0 );&lt;br /&gt;
    precision = z._cleanNumber( frame, frame.args[2] or frame.args.precision or 0 );&lt;br /&gt;
    &lt;br /&gt;
    if value == nil or precision == nil then&lt;br /&gt;
        return '&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: Round input appears non-numeric&amp;lt;/strong&amp;gt;'&lt;br /&gt;
    else&lt;br /&gt;
        return z._round( value, precision );&lt;br /&gt;
    end    &lt;br /&gt;
end&lt;br /&gt;
function z._round( value, precision )&lt;br /&gt;
    local rescale = math.pow( 10, precision );&lt;br /&gt;
    return math.floor( value * rescale + 0.5 ) / rescale;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
precision_format&lt;br /&gt;
&lt;br /&gt;
Rounds a number to the specified precision and formats according to rules &lt;br /&gt;
originally used for {{template:Rnd}}.  Output is a string.&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
    {{#invoke: Math | precision_format | number | precision }}&lt;br /&gt;
]]&lt;br /&gt;
function z.precision_format( frame )&lt;br /&gt;
    -- For access to Mediawiki built-in formatter.&lt;br /&gt;
    local lang = mw.getContentLanguage();&lt;br /&gt;
    &lt;br /&gt;
    local value_string, value, precision;&lt;br /&gt;
    value, value_string = z._cleanNumber( frame, frame.args[1] or 0 );&lt;br /&gt;
    precision = z._cleanNumber( frame, frame.args[2] or 0 );&lt;br /&gt;
    &lt;br /&gt;
    -- Check for non-numeric input&lt;br /&gt;
    if value == nil or precision == nil then&lt;br /&gt;
        return '&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: invalid input when rounding&amp;lt;/strong&amp;gt;'&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    local current_precision = z._precision( value );&lt;br /&gt;
&lt;br /&gt;
    local order = z._order( value );&lt;br /&gt;
    &lt;br /&gt;
    -- Due to round-off effects it is neccesary to limit the returned precision under&lt;br /&gt;
    -- some circumstances because the terminal digits will be inaccurately reported.&lt;br /&gt;
    if order + precision &amp;gt;= 14 then&lt;br /&gt;
        orig_precision = z._precision( value_string );&lt;br /&gt;
        if order + orig_precision &amp;gt;= 14 then&lt;br /&gt;
            precision = 13 - order;        &lt;br /&gt;
        end        &lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    -- If rounding off, truncate extra digits&lt;br /&gt;
    if precision &amp;lt; current_precision then&lt;br /&gt;
        value = z._round( value, precision );&lt;br /&gt;
        current_precision = z._precision( value );&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    local formatted_num = lang:formatNum( math.abs(value) );&lt;br /&gt;
    local sign;&lt;br /&gt;
    &lt;br /&gt;
    -- Use proper unary minus sign rather than ASCII default&lt;br /&gt;
    if value &amp;lt; 0 then&lt;br /&gt;
        sign = '−';&lt;br /&gt;
    else&lt;br /&gt;
        sign = '';&lt;br /&gt;
    end    &lt;br /&gt;
        &lt;br /&gt;
    -- Handle cases requiring scientific notation&lt;br /&gt;
    if string.find( formatted_num, 'E', 1, true ) ~= nil or math.abs(order) &amp;gt;= 9 then&lt;br /&gt;
        value = value * math.pow( 10, -order );&lt;br /&gt;
        current_precision = current_precision + order;&lt;br /&gt;
        precision = precision + order;&lt;br /&gt;
        formatted_num = lang:formatNum( math.abs(value) );&lt;br /&gt;
    else&lt;br /&gt;
        order = 0;        &lt;br /&gt;
    end&lt;br /&gt;
    formatted_num = sign .. formatted_num;&lt;br /&gt;
    &lt;br /&gt;
    -- Pad with zeros, if needed    &lt;br /&gt;
    if current_precision &amp;lt; precision then&lt;br /&gt;
        local padding;&lt;br /&gt;
        if current_precision &amp;lt;= 0 then&lt;br /&gt;
            if precision &amp;gt; 0 then&lt;br /&gt;
                local zero_sep = lang:formatNum( 1.1 );&lt;br /&gt;
                formatted_num = formatted_num .. zero_sep:sub(2,2);&lt;br /&gt;
&lt;br /&gt;
                padding = precision;&lt;br /&gt;
                if padding &amp;gt; 20 then&lt;br /&gt;
                    padding = 20;&lt;br /&gt;
                end&lt;br /&gt;
                &lt;br /&gt;
                formatted_num = formatted_num .. string.rep( '0', padding );&lt;br /&gt;
            end            &lt;br /&gt;
        else                   &lt;br /&gt;
            padding = precision - current_precision&lt;br /&gt;
            if padding &amp;gt; 20 then&lt;br /&gt;
                padding = 20;&lt;br /&gt;
            end&lt;br /&gt;
            formatted_num = formatted_num .. string.rep( '0', padding );&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    -- Add exponential notation, if necessary.&lt;br /&gt;
    if order ~= 0 then&lt;br /&gt;
        -- Use proper unary minus sign rather than ASCII default&lt;br /&gt;
        if order &amp;lt; 0 then&lt;br /&gt;
            order = '−' .. lang:formatNum( math.abs(order) );&lt;br /&gt;
        else&lt;br /&gt;
            order = lang:formatNum( order );&lt;br /&gt;
        end    &lt;br /&gt;
        &lt;br /&gt;
        formatted_num = formatted_num .. '&amp;lt;span style=&amp;quot;margin:0 .15em 0 .25em&amp;quot;&amp;gt;×&amp;lt;/span&amp;gt;10&amp;lt;sup&amp;gt;' .. order .. '&amp;lt;/sup&amp;gt;'&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    return formatted_num;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Helper function that interprets the input numerically.  If the &lt;br /&gt;
input does not appear to be a number, attempts evaluating it as&lt;br /&gt;
a parser functions expression.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function z._cleanNumber( frame, number_string )&lt;br /&gt;
    if number_string == nil or number_string:len() == 0 then&lt;br /&gt;
        return nil, nil;&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    -- Attempt basic conversion&lt;br /&gt;
    local number = tonumber( number_string )&lt;br /&gt;
    &lt;br /&gt;
    -- If failed, attempt to evaluate input as an expression&lt;br /&gt;
    if number == nil then        &lt;br /&gt;
        local attempt = frame:preprocess( '{{#expr: ' .. number_string .. '}}' );&lt;br /&gt;
        attempt = tonumber( attempt );&lt;br /&gt;
        if attempt ~= nil then&lt;br /&gt;
            number = attempt;&lt;br /&gt;
            number_string = tostring( number );&lt;br /&gt;
        else&lt;br /&gt;
            number = nil;&lt;br /&gt;
            number_string = nil;&lt;br /&gt;
        end&lt;br /&gt;
    else&lt;br /&gt;
    -- String is valid but may contain padding, clean it.&lt;br /&gt;
        number_string = number_string:match( &amp;quot;^%s*(.-)%s*$&amp;quot; );&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    return number, number_string;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return z&lt;/div&gt;</summary>
		<author><name>Arthur</name></author>
	</entry>
</feed>