<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en-GB">
	<id>https://stockhub.co/index.php?action=history&amp;feed=atom&amp;title=Module%3APop_density</id>
	<title>Module:Pop density - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://stockhub.co/index.php?action=history&amp;feed=atom&amp;title=Module%3APop_density"/>
	<link rel="alternate" type="text/html" href="https://stockhub.co/index.php?title=Module:Pop_density&amp;action=history"/>
	<updated>2026-05-24T12:48:55Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.43.5</generator>
	<entry>
		<id>https://stockhub.co/index.php?title=Module:Pop_density&amp;diff=144374&amp;oldid=prev</id>
		<title>imported&gt;Frietjes: fix double sort key</title>
		<link rel="alternate" type="text/html" href="https://stockhub.co/index.php?title=Module:Pop_density&amp;diff=144374&amp;oldid=prev"/>
		<updated>2019-04-28T13:31:39Z</updated>

		<summary type="html">&lt;p&gt;fix double sort key&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;--&lt;br /&gt;
-- This module implements {{Pop density}}&lt;br /&gt;
--&lt;br /&gt;
local p = {}&lt;br /&gt;
local math_module = require( &amp;quot;Module:Math&amp;quot; )&lt;br /&gt;
local precision = math_module._precision&lt;br /&gt;
local sortkey = require( &amp;quot;Module:Sortkey&amp;quot; )&lt;br /&gt;
&lt;br /&gt;
local function rnd(num, digits)&lt;br /&gt;
	-- This function implements {{rnd}}&lt;br /&gt;
	return math_module._precision_format(tostring(num), tostring(digits))&lt;br /&gt;
end&lt;br /&gt;
local unitnames = {&lt;br /&gt;
	[&amp;quot;km²&amp;quot;] = &amp;quot;km2&amp;quot;,&lt;br /&gt;
	[&amp;quot;sqkm&amp;quot;] = &amp;quot;km2&amp;quot;,&lt;br /&gt;
	[&amp;quot;km2&amp;quot;] = &amp;quot;km2&amp;quot;,&lt;br /&gt;
	[&amp;quot;mi2&amp;quot;] = &amp;quot;sqmi&amp;quot;,&lt;br /&gt;
	[&amp;quot;sqmi&amp;quot;] = &amp;quot;sqmi&amp;quot;,&lt;br /&gt;
	[&amp;quot;acres&amp;quot;] = &amp;quot;acre&amp;quot;,&lt;br /&gt;
	[&amp;quot;acre&amp;quot;] = &amp;quot;acre&amp;quot;,&lt;br /&gt;
	[&amp;quot;ha&amp;quot;] = &amp;quot;ha&amp;quot;,&lt;br /&gt;
	[&amp;quot;dunam&amp;quot;] = &amp;quot;dunam&amp;quot;,&lt;br /&gt;
	[&amp;quot;m²&amp;quot;] = &amp;quot;m2&amp;quot;,&lt;br /&gt;
	[&amp;quot;sqm&amp;quot;] = &amp;quot;m2&amp;quot;,&lt;br /&gt;
	[&amp;quot;m2&amp;quot;] = &amp;quot;m2&amp;quot;&lt;br /&gt;
}&lt;br /&gt;
local unitmult = {&lt;br /&gt;
	[&amp;quot;km2&amp;quot;] = 1000000,&lt;br /&gt;
	[&amp;quot;sqmi&amp;quot;] = 2589988.110336,&lt;br /&gt;
	[&amp;quot;acre&amp;quot;] = 4046.8564224,&lt;br /&gt;
	[&amp;quot;ha&amp;quot;] = 10000,&lt;br /&gt;
	[&amp;quot;dunam&amp;quot;] = 1000,&lt;br /&gt;
	[&amp;quot;m2&amp;quot;] = 1&lt;br /&gt;
}&lt;br /&gt;
local unitstr = {&lt;br /&gt;
	[&amp;quot;km2&amp;quot;] = &amp;#039;km&amp;lt;sup&amp;gt;2&amp;lt;/sup&amp;gt;&amp;#039;,&lt;br /&gt;
	[&amp;quot;sqmi&amp;quot;] = &amp;#039;sq&amp;amp;nbsp;mi&amp;#039;,&lt;br /&gt;
	[&amp;quot;acre&amp;quot;] = &amp;#039;acre&amp;#039;,&lt;br /&gt;
	[&amp;quot;ha&amp;quot;] = &amp;#039;ha&amp;#039;,&lt;br /&gt;
	[&amp;quot;dunam&amp;quot;] = &amp;#039;dunam&amp;#039;,&lt;br /&gt;
	[&amp;quot;m2&amp;quot;] = &amp;#039;m&amp;lt;sup&amp;gt;2&amp;lt;/sup&amp;gt;&amp;#039;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
local function popdensity(pop, area1, areaunit1, areaunit2, prec, disp, flip)&lt;br /&gt;
	local dens1, dens1sort, prec1&lt;br /&gt;
	local dens2, dens2sort, prec2&lt;br /&gt;
	local str1, str2 = &amp;#039;&amp;#039;, &amp;#039;&amp;#039;&lt;br /&gt;
	local uniterror = &amp;#039;&amp;lt;sup&amp;gt;[[Template:Pop density|?Unknown unit?]]&amp;lt;/sup&amp;gt;[[Category:Pop density using unsupported units]]&amp;#039;&lt;br /&gt;
	&lt;br /&gt;
	if(pop ~= &amp;#039;&amp;#039; and area1 ~= &amp;#039;&amp;#039;) then&lt;br /&gt;
		-- pop and area are defined&lt;br /&gt;
		local popnum = tonumber(pop)&lt;br /&gt;
		if not popnum then&lt;br /&gt;
			error(string.format(&amp;#039;Unable to convert population &amp;quot;%s&amp;quot; to a number&amp;#039;, pop), 2)&lt;br /&gt;
		end&lt;br /&gt;
		local area1num = tonumber(area1)&lt;br /&gt;
		if not area1num then&lt;br /&gt;
			error(string.format(&amp;#039;Unable to convert area &amp;quot;%s&amp;quot; to a number&amp;#039;, area1), 2)&lt;br /&gt;
		end&lt;br /&gt;
		local dens1num = popnum/area1num&lt;br /&gt;
		&lt;br /&gt;
		local unit1 = unitnames[areaunit1] or nil&lt;br /&gt;
		local unit2 = unitnames[areaunit2] or nil&lt;br /&gt;
		&lt;br /&gt;
		prec1 = (prec ~= &amp;#039;&amp;#039;) and tonumber(prec) &lt;br /&gt;
			or (1+math.log10(2*area1/(1/10^precision(pop)+pop/area1/10^precision(area1))))&lt;br /&gt;
		dens1 = rnd(dens1num, math.floor(prec1 + 0.5))&lt;br /&gt;
		dens1sort = &amp;#039;&amp;lt;span style=&amp;quot;display:none&amp;quot; data-sort-value=&amp;quot;&amp;#039;&lt;br /&gt;
			.. sortkey._sortKeyForNumber(dens1num) .. &amp;#039;♠&amp;quot;&amp;gt;&amp;lt;/span&amp;gt;&amp;#039;&lt;br /&gt;
		if (unit1) then&lt;br /&gt;
			str1 = &amp;#039;/&amp;#039; .. unitstr[unit1]&lt;br /&gt;
			if(unit2) then&lt;br /&gt;
				-- convert&lt;br /&gt;
				local mult = unitmult[unit2]/unitmult[unit1]&lt;br /&gt;
				prec2 = prec1 - math.log10(mult)&lt;br /&gt;
				dens2 = rnd(dens1num*mult, math.floor(prec2 + 0.5))&lt;br /&gt;
				dens2sort = &amp;#039;&amp;lt;span style=&amp;quot;display:none&amp;quot; data-sort-value=&amp;quot;&amp;#039;&lt;br /&gt;
					.. sortkey._sortKeyForNumber(dens1num*mult) .. &amp;#039;♠&amp;quot;&amp;gt;&amp;lt;/span&amp;gt;&amp;#039;&lt;br /&gt;
				str2 = &amp;#039;/&amp;#039; .. unitstr[unit2]&lt;br /&gt;
			elseif(areaunit2 ~= &amp;#039;&amp;#039;) then&lt;br /&gt;
				if( disp ~= &amp;#039;num&amp;#039; ) then&lt;br /&gt;
					dens2 = &amp;#039;?&amp;#039;&lt;br /&gt;
				else&lt;br /&gt;
					dens2 = &amp;#039;?&amp;#039; .. uniterror&lt;br /&gt;
				end&lt;br /&gt;
				str2 = &amp;#039;/&amp;#039; .. areaunit2 .. uniterror&lt;br /&gt;
			end&lt;br /&gt;
		elseif(areaunit1 ~= &amp;#039;&amp;#039;) then&lt;br /&gt;
			if( disp ~= &amp;#039;num&amp;#039; ) then&lt;br /&gt;
				dens2 = &amp;#039;?&amp;#039;&lt;br /&gt;
			else&lt;br /&gt;
				dens2 = &amp;#039;?&amp;#039; .. uniterror&lt;br /&gt;
			end&lt;br /&gt;
			if(unit2) then&lt;br /&gt;
				str2 = &amp;#039;/&amp;#039; .. unitstr[unit2]&lt;br /&gt;
			elseif(areaunit2 ~= &amp;#039;&amp;#039;) then&lt;br /&gt;
				str2 = &amp;#039;/&amp;#039; .. areaunit2 .. uniterror				&lt;br /&gt;
			end&lt;br /&gt;
			str1 = &amp;#039;/&amp;#039; .. areaunit1 .. uniterror&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		-- form output&lt;br /&gt;
		if( str2 ~= &amp;#039;&amp;#039; ) then&lt;br /&gt;
			-- has a converted unit&lt;br /&gt;
			if( disp ~= &amp;#039;num&amp;#039; and disp ~= &amp;#039;table&amp;#039; ) then&lt;br /&gt;
				-- display input and output density numbers with units&lt;br /&gt;
				if( flip == &amp;#039;on&amp;#039; ) then&lt;br /&gt;
					return (dens2sort or &amp;#039;&amp;#039;) .. dens2 .. str2 .. &amp;#039; (&amp;#039; .. dens1 .. str1 .. &amp;#039;)&amp;#039;&lt;br /&gt;
				else&lt;br /&gt;
					return (dens1sort or &amp;#039;&amp;#039;) .. dens1 .. str1 .. &amp;#039; (&amp;#039; .. dens2 .. str2 .. &amp;#039;)&amp;#039;&lt;br /&gt;
				end&lt;br /&gt;
			elseif( disp == &amp;#039;table&amp;#039;) then&lt;br /&gt;
				dens1 = (dens1sort or &amp;#039;&amp;#039;) .. dens1&lt;br /&gt;
				dens2 = (dens2sort or &amp;#039;&amp;#039;) .. dens2&lt;br /&gt;
				return pop .. &amp;#039;||&amp;#039; .. area1 .. &amp;#039;||&amp;#039; .. dens1 .. &amp;#039;||&amp;#039; .. dens2&lt;br /&gt;
			else&lt;br /&gt;
				-- display output density number without unit&lt;br /&gt;
				return dens2&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			-- no converted unit&lt;br /&gt;
			if( disp ~= &amp;#039;num&amp;#039; and disp ~= &amp;#039;table&amp;#039; ) then&lt;br /&gt;
				-- display input density number with unit &lt;br /&gt;
				return (dens1sort or &amp;#039;&amp;#039;) .. dens1 .. str1 &lt;br /&gt;
			elseif( disp == &amp;#039;table&amp;#039;) then&lt;br /&gt;
				return pop .. &amp;#039;||&amp;#039; .. area1 .. &amp;#039;||&amp;#039; ..(dens1sort or &amp;#039;&amp;#039;) .. dens1&lt;br /&gt;
			else&lt;br /&gt;
				-- display input density number without unit&lt;br /&gt;
				return dens1&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return &amp;#039;&amp;#039;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.density(frame)&lt;br /&gt;
	local args = (frame.args[3] ~= nil) and frame.args or frame:getParent().args&lt;br /&gt;
	return popdensity(&lt;br /&gt;
		args[1] or &amp;#039;&amp;#039;, args[2] or &amp;#039;&amp;#039;, args[3] or &amp;#039;&amp;#039;, args[4] or &amp;#039;&amp;#039;, &lt;br /&gt;
		args[&amp;#039;prec&amp;#039;] or &amp;#039;&amp;#039;, args[&amp;#039;disp&amp;#039;] or &amp;#039;&amp;#039;, args[&amp;#039;flip&amp;#039;] or &amp;#039;&amp;#039;&lt;br /&gt;
		)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>imported&gt;Frietjes</name></author>
	</entry>
</feed>