<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://catalog.jinharsh.co.in/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://catalog.jinharsh.co.in/index.php?action=history&amp;feed=atom&amp;title=Module%3APop_density"/>
	<link rel="alternate" type="text/html" href="https://catalog.jinharsh.co.in/index.php?title=Module:Pop_density&amp;action=history"/>
	<updated>2026-05-02T21:16:32Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.35.1</generator>
	<entry>
		<id>https://catalog.jinharsh.co.in/index.php?title=Module:Pop_density&amp;diff=4629&amp;oldid=prev</id>
		<title>Admin: 1 revision imported: Mitul Imported from Wikipedia</title>
		<link rel="alternate" type="text/html" href="https://catalog.jinharsh.co.in/index.php?title=Module:Pop_density&amp;diff=4629&amp;oldid=prev"/>
		<updated>2021-04-11T19:17:23Z</updated>

		<summary type="html">&lt;p&gt;1 revision imported: Mitul Imported from Wikipedia&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left diff-editfont-monospace&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 19:17, 11 April 2021&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>
	</entry>
	<entry>
		<id>https://catalog.jinharsh.co.in/index.php?title=Module:Pop_density&amp;diff=4628&amp;oldid=prev</id>
		<title>setup&gt;Frietjes: fix double sort key</title>
		<link rel="alternate" type="text/html" href="https://catalog.jinharsh.co.in/index.php?title=Module:Pop_density&amp;diff=4628&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;] = 'km&amp;lt;sup&amp;gt;2&amp;lt;/sup&amp;gt;',&lt;br /&gt;
	[&amp;quot;sqmi&amp;quot;] = 'sq&amp;amp;nbsp;mi',&lt;br /&gt;
	[&amp;quot;acre&amp;quot;] = 'acre',&lt;br /&gt;
	[&amp;quot;ha&amp;quot;] = 'ha',&lt;br /&gt;
	[&amp;quot;dunam&amp;quot;] = 'dunam',&lt;br /&gt;
	[&amp;quot;m2&amp;quot;] = 'm&amp;lt;sup&amp;gt;2&amp;lt;/sup&amp;gt;'&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 = '', ''&lt;br /&gt;
	local uniterror = '&amp;lt;sup&amp;gt;[[Template:Pop density|?Unknown unit?]]&amp;lt;/sup&amp;gt;[[Category:Pop density using unsupported units]]'&lt;br /&gt;
	&lt;br /&gt;
	if(pop ~= '' and area1 ~= '') 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('Unable to convert population &amp;quot;%s&amp;quot; to a number', 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('Unable to convert area &amp;quot;%s&amp;quot; to a number', 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 ~= '') 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;lt;span style=&amp;quot;display:none&amp;quot; data-sort-value=&amp;quot;'&lt;br /&gt;
			.. sortkey._sortKeyForNumber(dens1num) .. '♠&amp;quot;&amp;gt;&amp;lt;/span&amp;gt;'&lt;br /&gt;
		if (unit1) then&lt;br /&gt;
			str1 = '/' .. 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;lt;span style=&amp;quot;display:none&amp;quot; data-sort-value=&amp;quot;'&lt;br /&gt;
					.. sortkey._sortKeyForNumber(dens1num*mult) .. '♠&amp;quot;&amp;gt;&amp;lt;/span&amp;gt;'&lt;br /&gt;
				str2 = '/' .. unitstr[unit2]&lt;br /&gt;
			elseif(areaunit2 ~= '') then&lt;br /&gt;
				if( disp ~= 'num' ) then&lt;br /&gt;
					dens2 = '?'&lt;br /&gt;
				else&lt;br /&gt;
					dens2 = '?' .. uniterror&lt;br /&gt;
				end&lt;br /&gt;
				str2 = '/' .. areaunit2 .. uniterror&lt;br /&gt;
			end&lt;br /&gt;
		elseif(areaunit1 ~= '') then&lt;br /&gt;
			if( disp ~= 'num' ) then&lt;br /&gt;
				dens2 = '?'&lt;br /&gt;
			else&lt;br /&gt;
				dens2 = '?' .. uniterror&lt;br /&gt;
			end&lt;br /&gt;
			if(unit2) then&lt;br /&gt;
				str2 = '/' .. unitstr[unit2]&lt;br /&gt;
			elseif(areaunit2 ~= '') then&lt;br /&gt;
				str2 = '/' .. areaunit2 .. uniterror				&lt;br /&gt;
			end&lt;br /&gt;
			str1 = '/' .. areaunit1 .. uniterror&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		-- form output&lt;br /&gt;
		if( str2 ~= '' ) then&lt;br /&gt;
			-- has a converted unit&lt;br /&gt;
			if( disp ~= 'num' and disp ~= 'table' ) then&lt;br /&gt;
				-- display input and output density numbers with units&lt;br /&gt;
				if( flip == 'on' ) then&lt;br /&gt;
					return (dens2sort or '') .. dens2 .. str2 .. ' (' .. dens1 .. str1 .. ')'&lt;br /&gt;
				else&lt;br /&gt;
					return (dens1sort or '') .. dens1 .. str1 .. ' (' .. dens2 .. str2 .. ')'&lt;br /&gt;
				end&lt;br /&gt;
			elseif( disp == 'table') then&lt;br /&gt;
				dens1 = (dens1sort or '') .. dens1&lt;br /&gt;
				dens2 = (dens2sort or '') .. dens2&lt;br /&gt;
				return pop .. '||' .. area1 .. '||' .. dens1 .. '||' .. 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 ~= 'num' and disp ~= 'table' ) then&lt;br /&gt;
				-- display input density number with unit &lt;br /&gt;
				return (dens1sort or '') .. dens1 .. str1 &lt;br /&gt;
			elseif( disp == 'table') then&lt;br /&gt;
				return pop .. '||' .. area1 .. '||' ..(dens1sort or '') .. 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 ''&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 '', args[2] or '', args[3] or '', args[4] or '', &lt;br /&gt;
		args['prec'] or '', args['disp'] or '', args['flip'] or ''&lt;br /&gt;
		)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>setup&gt;Frietjes</name></author>
	</entry>
</feed>