From 5a1fd9e0764ce3f758a8f202b2b8f09592d611f7 Mon Sep 17 00:00:00 2001 From: Abigail Date: Mon, 1 Feb 2021 22:59:29 +0100 Subject: Use base-91 instead of base-60. We're now using base-91, which is from character '#' to '~', excluding the backslash. --- challenge-004/abigail/perl/ch-1.pl | 79 +++++++++++++++++++++++++++----------- 1 file changed, 57 insertions(+), 22 deletions(-) diff --git a/challenge-004/abigail/perl/ch-1.pl b/challenge-004/abigail/perl/ch-1.pl index c6333723dd..a36eb78e42 100644 --- a/challenge-004/abigail/perl/ch-1.pl +++ b/challenge-004/abigail/perl/ch-1.pl @@ -17,40 +17,75 @@ use experimental 'lexical_subs'; # Run as: perl ch-1.pl # +################################################################################ +# +# We have encoded the digits of perl. We're grouping the digits (after +# the decimal dot), in groups of 9, considering this as a base-10 number, +# and then we turn this into a base-91 number. To represent the base-91 +# number, we are using ASCII characters, starting from "#", up to "~", +# *BUT* skipping "\". +# +# We can encode a 9 digit base-10 number with 5 characters in base-91, +# giving us a 44.44% reduction in size. +# +################################################################################ + my $first_ord = 1 + ord ('"'); -my $range = 60; +my $skip_ord = ord ("\\"); +my $last_ord = ord ("~"); +my $range = $last_ord - $first_ord; +my $in_size = 5; +my $out_size = 9; print "3."; while () { - foreach (/.{6}/g) { + my $pat = ".{$in_size}"; + foreach (/$pat/g) { my $out = 0; foreach (/./g) { $out *= $range; - $out += ord () - $first_ord; + my $n = ord (); + $n -- if $n >= $skip_ord; + $out += $n - $first_ord; } - print $out; + printf "%0${out_size}d" => $out; } } -print "\n" +print "\n"; # -# Encoded digits of PI below __DATA__ -# Encoding is in base-60; from character '#' +# FODDER FODDER FODDER FODDER FODDER FODDER FODDER +# FODDER FODDER FODDER FODDER FODDER FODDER FODDER # __DATA__ -$T2/ZF.CU[H=&:\X*^)?$KCV+Z@7<-*@+\@'*H$J@;#SA3Y^.(OG7<':]P.6 --DVB4B'02VUR$/;J?2)A4L^C)XC'?S).0\8M-S[=,X-\@DP^+4:J5,*&UN[G -(LNP32+DU2*L&JN-0N'W.;/P&@2II.(W0FOW'>#*[U(UDI?%$N7OIQ#606[J+'-NC2%KD,L-KB>?C -/IQ2[%(K#Q0U.&ON.E+0>B5\%>+S3I*U1KH\#LG9C[&Q/^W&-X854=,VQA5W -##=5*V(T28+%-#P12M,OMV+.,?.4./$X572$%XEAI8(^-O%4$8'QOJ+VU+*2 -(;0L#.%O3E^7.)LFG8*LB@M\)+,:WK)K108X)L:-Z'>KE-=(?)20P'5'J-F&9)=I$,*Z#(0-'UB8=*D7GL:-?1NSH,VP5LN -*LGZ2'&LWN$0$@?7RN.7TMOF/&:L%]%:7U+W%/*-$)$K6;JR+A*:5@%Q^>0, -'X[LF7$9/S4N&F->G$)VXSD3-F&1^/#>17M,+W9@3%&7E6;V&/L.FW-O*OPV -*-,B>9(U<@MJ)C/.?B+T>2AZ.=#X&&-AT9,))8*0*F#QG784#/XKBK/J[;=W -.%5\R2+.E40A)&=:W9/47DX,)#VQFO/,$Z9^,\Q^$.#B0VB'*^#\;O&6X\?C -/##QF%.DG=LO,K96%T+@=LGN-?W9IB&2AK(#'EFPDO,I7u0$Nh<#2&:@+#=`/*YtP-0t8uf+tf/V&yjx>+]S=&%d}7z +0YXa9$SOyt$*mzv1&X(W(.{0G-Vya`0a}KI0pQD2,nV0:,WE0+#?F[>(iMb} +%k(tB/UO0m.8R'x%Vys_-|IgL.y-n6(v[*#+/-J1#[`] +&*M#'1wg +-}+B}*jWDi)/2&k,h|/)+eu-3)9{mU-`:]M/YF$a.O0SF0{~2C.EjkZ&>|lD +#%UmL+w)$V&14Ty0arq+%xnAo/XX/y0_=Bl/)f*}'Gc88'GV;X1RG~<+gJ8p +&^E~A'/3N=*R2|j&SgD@-0St?*jL@'-ZsbD$+_hy.#HkF0cO_[#t0wL-8._r +#0)@p#4(ha+lyD6,[|1w%_K//+c2#j.4xl2)SpX=.>)gp$R)ZP,IS%@,}%#J +*1zj[,sIw#%6pwl%D'fk#Bx6'%4?.0&c9'?#R7P|&ZJ;M&q6q&&|h9?0LVI} +(2lq>#/G+<,Bv`l+U'K?'2i}q+,J8W/7dU++X(l51R>#T&)fV0'I%FC%HHkt +%{(NN&Kn$]*e0, +$K`U.%bSL*&dG^f,lN@.+jGbU.g8,s&FwUP$9p3S/)f(4,y>{*/L)t +-Oi$Y*&I1x1Kyk#$}~i|)^4uG%|&sU)XNR-,PLl/.lmT'&_~it-16U9-B~A[ +(}s.a0~]Zj*<*~%-~N27%$O,*/a,,c%<#@60On3z0~3@B13UOG/A^&K,GRHi +,S_:*&9I{_$nCM9&U^*9)WmPj+$TL8.]WpP)CWDR$u#7])K/Bi+,[B9(0~a& +&=aag,L-UG#HoAx/=@p,&ux{:0($3X*[J<4,eh{E1F&tE$cGo.&C}15*:u{Z +,:*H^'f,=~$,z%B)WZbL$DjA;/oFKa%.>ig/^o.90e/P=*Auex0TD}p/hncA +/%d87#/u19,r&sM(A+4V0%4u$.}F+P0o|4e.g(<[#5yy*]3@5%II741/XZ>)Lm6e0``3L%.JF[+Z?8b(tj7C +'S/z}#vS|i)S9[=*/nCG)PMaY-{pML);vN?%kRcr#*.Tg,x;42'(1w.0dA)S +)-us%.#1$R-rkwf%m%B-(ctK8+4Sn^%*C1Y-wqsr%eNg11%$De&&07q+%1>- ++mCl2%)V#w%#y:[,?t*D$64`9.U+{`-SBX-+gi/o)0B$q#V$tW+#lmM)';EH +%yFPZ/Gy(~,dl@h)A&ju-Co2,-du++)[Awk&wE}p*H;._.[]4W+Eb7K#iiKB -- cgit