countries: hardcode codes reserved for WIPO
[sheet.git] / base.plp
index f34f36e8580a4a25f00567040bdd381f1a99d993..3a89a53de6979de2a05417ab84620f5698ad353d 100644 (file)
--- a/base.plp
+++ b/base.plp
@@ -13,12 +13,32 @@ Html({
 });
 
 my @cols = (2, 6, 8, 9, 10, 12, 16, 18, 20);
-my @morecols = (2, 3, 4, 6, 8, 9, 10, 12, 16, 18, 20, 24, 32, 36, 64);
+my @morecols = (2 .. 6, 8, 9, 10, 12, 16, 18, 20, 24, 32, 36, 64);
 my @char = (0..9, 'A'..'Z', 'a'..'z');
 :>
 <h1>Number bases</h1>
 
-<h2>Fractions</h2>
+<h2>Radix economy</h2>
+<table>
+<:
+sub radix_economy {
+       my ($val, $radix) = @_;
+       return $radix * int(log($val) / log($radix) + 1);
+}
+
+use List::Util 'sum';
+print '<tr><th>';
+print '<th>', $_ for @morecols;
+for my $max (100, 255, 1024) {
+       print '<tr><th>⍳', $max;
+       for my $radix (@morecols) {
+               printf '<td style="text-align:right">%.1f',
+                       sum(map { radix_economy($_, $radix) } 1 .. $max) / $max;
+       }
+}
+:></table>
+
+<h2>Reciprocal fractions (n⁻¹)</h2>
 <table>
 <:
 print '<tr><th>';
@@ -74,7 +94,7 @@ for my $n (2 .. $count) {
 
 <hr>
 
-<h2>Duplication</h2>
+<h2>Duplication (2ⁿ)</h2>
 <table>
 <:
 use 5.010;