Module:Utils/number: Difference between revisions

From Space Station 14 Wiki
Aliser (talk | contribs)
simplify format_probability
Aliser (talk | contribs)
simplify format_probability
 
Line 31: Line 31:
     local percentage = prob * 100
     local percentage = prob * 100


    local percentage_display
     if digits == nil then
     if digits == nil then
         percentage_display = percentage .. "%"
         return percentage .. "%"
     else
     else
     return p.round_to_digit_formatted(percentage, digits) .. "%"
     return p.round_to_digit_formatted(percentage, digits) .. "%"
     end
     end
    return percentage_display
end
end


return p
return p

Latest revision as of 13:47, 27 May 2025

Module documentation
View or edit this documentation (about module documentation)

Contains number-related module utilities.


local p = {}

-- Rounds number `num` to `digits` numbers after comma.
-- @returns {number}
function p.round_to_digit(num, digits)
	local str_res = string.format("%." .. digits .. "f", num)
    	:gsub("%.?0+$", "") -- strip trailing zeros (including the dot if theres all zeros after)
    	
    return tonumber(str_res)
end

-- Rounds number `num` to `digits` numbers after comma,
-- adding "≈" if rounding occured.
-- @returns {string}
function p.round_to_digit_formatted(num, digits)
	local rounded = p.round_to_digit(num, digits)
	if num == rounded then
		return tostring(rounded)
	else
		return "≈" .. rounded
	end
end

-- Formats a probability number, ranging from 0 to 1, 
-- to a percentage with specified number of digits after comma.
-- If rounding occurs, also adds "≈".
-- @param prob Probability, from 0 to 1.
-- @param digits Digits after comma. Any more get rounded
-- @returns {string}
function p.format_probability(prob, digits)
    local percentage = prob * 100

    if digits == nil then
        return percentage .. "%"
    else
    	return p.round_to_digit_formatted(percentage, digits) .. "%"
    end
end

return p