diff options
| author | Mohammad S Anwar <mohammad.anwar@yahoo.com> | 2019-11-20 11:59:08 +0000 |
|---|---|---|
| committer | Mohammad S Anwar <mohammad.anwar@yahoo.com> | 2019-11-20 11:59:08 +0000 |
| commit | 00591e00f1f2c3a0bdb046167c79d68c241d8cca (patch) | |
| tree | 4741188e5b5b05ec9cb1a4ce5f49b53027dacf5c | |
| parent | 322b0950aa4dc7ee2810dca36007740f3bd7d08e (diff) | |
| download | perlweeklychallenge-club-00591e00f1f2c3a0bdb046167c79d68c241d8cca.tar.gz perlweeklychallenge-club-00591e00f1f2c3a0bdb046167c79d68c241d8cca.tar.bz2 perlweeklychallenge-club-00591e00f1f2c3a0bdb046167c79d68c241d8cca.zip | |
- Added solutions by Arne Sommer.
| -rw-r--r-- | challenge-035/arne-sommer/blog.txt | 1 | ||||
| -rwxr-xr-x | challenge-035/arne-sommer/perl6/bem | 15 | ||||
| -rwxr-xr-x | challenge-035/arne-sommer/perl6/bem-test | 25 | ||||
| -rwxr-xr-x | challenge-035/arne-sommer/perl6/bem2 | 17 | ||||
| -rwxr-xr-x | challenge-035/arne-sommer/perl6/bem3 | 52 | ||||
| -rwxr-xr-x | challenge-035/arne-sommer/perl6/ch-1.p6 | 52 | ||||
| -rwxr-xr-x | challenge-035/arne-sommer/perl6/ch-2.p6 | 52 | ||||
| -rw-r--r-- | stats/pwc-current.json | 145 | ||||
| -rw-r--r-- | stats/pwc-language-breakdown-summary.json | 60 | ||||
| -rw-r--r-- | stats/pwc-language-breakdown.json | 314 | ||||
| -rw-r--r-- | stats/pwc-leaders.json | 556 | ||||
| -rw-r--r-- | stats/pwc-summary-1-30.json | 38 | ||||
| -rw-r--r-- | stats/pwc-summary-121-150.json | 96 | ||||
| -rw-r--r-- | stats/pwc-summary-31-60.json | 100 | ||||
| -rw-r--r-- | stats/pwc-summary-61-90.json | 42 | ||||
| -rw-r--r-- | stats/pwc-summary-91-120.json | 96 | ||||
| -rw-r--r-- | stats/pwc-summary.json | 334 |
17 files changed, 1114 insertions, 881 deletions
diff --git a/challenge-035/arne-sommer/blog.txt b/challenge-035/arne-sommer/blog.txt new file mode 100644 index 0000000000..43dad4e2cb --- /dev/null +++ b/challenge-035/arne-sommer/blog.txt @@ -0,0 +1 @@ +https://raku-musings.com/morse-remorse.html diff --git a/challenge-035/arne-sommer/perl6/bem b/challenge-035/arne-sommer/perl6/bem new file mode 100755 index 0000000000..93293e71ba --- /dev/null +++ b/challenge-035/arne-sommer/perl6/bem @@ -0,0 +1,15 @@ +#! /usr/bin/env raku + +use lib "lib"; + +use BinaryMorse2; + +multi sub MAIN (BinaryMorse2::BinaryMorse $binary-morse) +{ + say BinaryMorse2::demorsify($binary-morse); +} + +multi sub MAIN (Str $text) +{ + say BinaryMorse2::morsify($text); +} diff --git a/challenge-035/arne-sommer/perl6/bem-test b/challenge-035/arne-sommer/perl6/bem-test new file mode 100755 index 0000000000..da27d608c5 --- /dev/null +++ b/challenge-035/arne-sommer/perl6/bem-test @@ -0,0 +1,25 @@ +#! /usr/bin/env raku + +use lib "lib"; + +use BinaryMorse; + +for %BinaryMorse::morse.keys.sort -> $key +{ + say "$key | { (%BinaryMorse::morse{$key}).fmt('%-6s') } | %BinaryMorse::binary-morse{$key}"; +} + + +say ""; + +for %BinaryMorse::remorse.keys.sort -> $key +{ + say "{ $key.fmt('%-6s') } | { %BinaryMorse::remorse{$key} } | { %BinaryMorse::binary-morse{%BinaryMorse::remorse{$key}} }"; +} + +say ""; + +for %BinaryMorse::binary-remorse.keys.sort -> $key +{ + say "{ $key.fmt('%-20s') } | { (%BinaryMorse::binary-remorse{$key}) } | %BinaryMorse::morse{%BinaryMorse::binary-remorse{$key}}"; +} diff --git a/challenge-035/arne-sommer/perl6/bem2 b/challenge-035/arne-sommer/perl6/bem2 new file mode 100755 index 0000000000..62afd42b2e --- /dev/null +++ b/challenge-035/arne-sommer/perl6/bem2 @@ -0,0 +1,17 @@ +#! /usr/bin/env raku + +use lib "lib"; + +use BinaryMorse2; + +multi sub MAIN (BinaryMorse2::BinaryMorse $binary-morse) +{ + say BinaryMorse2::demorsify($binary-morse); +} + +multi sub MAIN (Str $text, :$roundtrip) +{ + my $encoded = BinaryMorse2::morsify($text); + say $encoded; + say BinaryMorse2::demorsify($encoded) if $roundtrip; +} diff --git a/challenge-035/arne-sommer/perl6/bem3 b/challenge-035/arne-sommer/perl6/bem3 new file mode 100755 index 0000000000..348ecc9c96 --- /dev/null +++ b/challenge-035/arne-sommer/perl6/bem3 @@ -0,0 +1,52 @@ +#! /usr/bin/env raku + +use lib "lib"; + +use BinaryMorse2; + +multi sub MAIN (BinaryMorse2::BinaryMorse $binary-morse) +{ + say BinaryMorse2::demorsify($binary-morse); +} + +multi sub MAIN (:$binary where $binary.IO.f && $binary.IO.r) +{ + my $fh = open $binary, :bin; + my $data = $fh.read; + $fh.close; + + my $result = ""; + $result ~= $_.base(2).fmt("%08d") for @($data); + + $result.substr-rw(0,1) = "" while $result.chars && $result.substr(0,1) eq "0"; + + say BinaryMorse2::demorsify($result); +} + +multi sub MAIN (Str $text, :$roundtrip, :$binary) +{ + if $binary + { + if my $fh = open $binary, :w, :bin + { + my @values = BinaryMorse2::morsify($text).parse-base(2).polymod(256 xx 200).reverse; + @values.shift while @values && @values[0] == 0; + die "Set a higher polymod value" if @values[0] > 255; + $fh.write: Blob.new(@values); + $fh.close; + + MAIN(:$binary) if $roundtrip; + } + else + { + die "Unable to open file $binary"; + } + } + + else + { + my $encoded = BinaryMorse2::morsify($text); + say $encoded; + say BinaryMorse2::demorsify($encoded) if $roundtrip; + } +} diff --git a/challenge-035/arne-sommer/perl6/ch-1.p6 b/challenge-035/arne-sommer/perl6/ch-1.p6 new file mode 100755 index 0000000000..348ecc9c96 --- /dev/null +++ b/challenge-035/arne-sommer/perl6/ch-1.p6 @@ -0,0 +1,52 @@ +#! /usr/bin/env raku + +use lib "lib"; + +use BinaryMorse2; + +multi sub MAIN (BinaryMorse2::BinaryMorse $binary-morse) +{ + say BinaryMorse2::demorsify($binary-morse); +} + +multi sub MAIN (:$binary where $binary.IO.f && $binary.IO.r) +{ + my $fh = open $binary, :bin; + my $data = $fh.read; + $fh.close; + + my $result = ""; + $result ~= $_.base(2).fmt("%08d") for @($data); + + $result.substr-rw(0,1) = "" while $result.chars && $result.substr(0,1) eq "0"; + + say BinaryMorse2::demorsify($result); +} + +multi sub MAIN (Str $text, :$roundtrip, :$binary) +{ + if $binary + { + if my $fh = open $binary, :w, :bin + { + my @values = BinaryMorse2::morsify($text).parse-base(2).polymod(256 xx 200).reverse; + @values.shift while @values && @values[0] == 0; + die "Set a higher polymod value" if @values[0] > 255; + $fh.write: Blob.new(@values); + $fh.close; + + MAIN(:$binary) if $roundtrip; + } + else + { + die "Unable to open file $binary"; + } + } + + else + { + my $encoded = BinaryMorse2::morsify($text); + say $encoded; + say BinaryMorse2::demorsify($encoded) if $roundtrip; + } +} diff --git a/challenge-035/arne-sommer/perl6/ch-2.p6 b/challenge-035/arne-sommer/perl6/ch-2.p6 new file mode 100755 index 0000000000..348ecc9c96 --- /dev/null +++ b/challenge-035/arne-sommer/perl6/ch-2.p6 @@ -0,0 +1,52 @@ +#! /usr/bin/env raku + +use lib "lib"; + +use BinaryMorse2; + +multi sub MAIN (BinaryMorse2::BinaryMorse $binary-morse) +{ + say BinaryMorse2::demorsify($binary-morse); +} + +multi sub MAIN (:$binary where $binary.IO.f && $binary.IO.r) +{ + my $fh = open $binary, :bin; + my $data = $fh.read; + $fh.close; + + my $result = ""; + $result ~= $_.base(2).fmt("%08d") for @($data); + + $result.substr-rw(0,1) = "" while $result.chars && $result.substr(0,1) eq "0"; + + say BinaryMorse2::demorsify($result); +} + +multi sub MAIN (Str $text, :$roundtrip, :$binary) +{ + if $binary + { + if my $fh = open $binary, :w, :bin + { + my @values = BinaryMorse2::morsify($text).parse-base(2).polymod(256 xx 200).reverse; + @values.shift while @values && @values[0] == 0; + die "Set a higher polymod value" if @values[0] > 255; + $fh.write: Blob.new(@values); + $fh.close; + + MAIN(:$binary) if $roundtrip; + } + else + { + die "Unable to open file $binary"; + } + } + + else + { + my $encoded = BinaryMorse2::morsify($text); + say $encoded; + say BinaryMorse2::demorsify($encoded) if $roundtrip; + } +} diff --git a/stats/pwc-current.json b/stats/pwc-current.json index 16db633f99..742adb3456 100644 --- a/stats/pwc-current.json +++ b/stats/pwc-current.json @@ -1,57 +1,40 @@ { - "series" : [ - { - "name" : "Perl Weekly Challenge - 035", - "colorByPoint" : 1, - "data" : [ - { - "name" : "Daniel Mita", - "y" : 2, - "drilldown" : "Daniel Mita" - }, - { - "name" : "E. Choroba", - "drilldown" : "E. Choroba", - "y" : 2 - }, - { - "name" : "Javier Luque", - "drilldown" : "Javier Luque", - "y" : 5 - }, - { - "drilldown" : "Roger Bell West", - "y" : 4, - "name" : "Roger Bell West" - }, - { - "drilldown" : "Simon Proctor", - "y" : 2, - "name" : "Simon Proctor" - } - ] - } - ], "yAxis" : { "title" : { "text" : "Total Solutions" } }, - "title" : { - "text" : "Perl Weekly Challenge - 035" + "subtitle" : { + "text" : "[Champions: 6] Last updated at 2019-11-20 11:58:56 GMT" }, - "plotOptions" : { - "series" : { - "dataLabels" : { - "format" : "{point.y}", - "enabled" : 1 - }, - "borderWidth" : 0 - } + "legend" : { + "enabled" : 0 + }, + "tooltip" : { + "followPointer" : 1, + "headerFormat" : "<span style='font-size:11px'>{series.name}</span><br/>", + "pointFormat" : "<span style='color:{point.color}'>{point.name}</span>: <b>{point.y:f}</b><br/>" + }, + "chart" : { + "type" : "column" }, "drilldown" : { "series" : [ { + "id" : "Arne Sommer", + "data" : [ + [ + "Perl 6", + 2 + ], + [ + "Blog", + 1 + ] + ], + "name" : "Arne Sommer" + }, + { "data" : [ [ "Perl 6", @@ -62,18 +45,17 @@ "name" : "Daniel Mita" }, { + "id" : "E. Choroba", "data" : [ [ "Perl 5", 2 ] ], - "id" : "E. Choroba", "name" : "E. Choroba" }, { "id" : "Javier Luque", - "name" : "Javier Luque", "data" : [ [ "Perl 5", @@ -87,11 +69,10 @@ "Blog", 1 ] - ] + ], + "name" : "Javier Luque" }, { - "id" : "Roger Bell West", - "name" : "Roger Bell West", "data" : [ [ "Perl 5", @@ -101,33 +82,71 @@ "Perl 6", 2 ] - ] + ], + "id" : "Roger Bell West", + "name" : "Roger Bell West" }, { + "id" : "Simon Proctor", "data" : [ [ "Perl 6", 2 ] ], - "name" : "Simon Proctor", - "id" : "Simon Proctor" + "name" : "Simon Proctor" } ] }, - "legend" : { - "enabled" : 0 - }, - "subtitle" : { - "text" : "[Champions: 5] Last updated at 2019-11-20 11:46:08 GMT" - }, - "tooltip" : { - "headerFormat" : "<span style='font-size:11px'>{series.name}</span><br/>", - "pointFormat" : "<span style='color:{point.color}'>{point.name}</span>: <b>{point.y:f}</b><br/>", - "followPointer" : 1 + "title" : { + "text" : "Perl Weekly Challenge - 035" }, - "chart" : { - "type" : "column" + "series" : [ + { + "colorByPoint" : 1, + "data" : [ + { + "name" : "Arne Sommer", + "drilldown" : "Arne Sommer", + "y" : 3 + }, + { + "y" : 2, + "drilldown" : "Daniel Mita", + "name" : "Daniel Mita" + }, + { + "name" : "E. Choroba", + "drilldown" : "E. Choroba", + "y" : 2 + }, + { + "y" : 5, + "name" : "Javier Luque", + "drilldown" : "Javier Luque" + }, + { + "y" : 4, + "name" : "Roger Bell West", + "drilldown" : "Roger Bell West" + }, + { + "drilldown" : "Simon Proctor", + "name" : "Simon Proctor", + "y" : 2 + } + ], + "name" : "Perl Weekly Challenge - 035" + } + ], + "plotOptions" : { + "series" : { + "dataLabels" : { + "enabled" : 1, + "format" : "{point.y}" + }, + "borderWidth" : 0 + } }, "xAxis" : { "type" : "category" diff --git a/stats/pwc-language-breakdown-summary.json b/stats/pwc-language-breakdown-summary.json index 7c896c4b7f..1d2d092046 100644 --- a/stats/pwc-language-breakdown-summary.json +++ b/stats/pwc-language-breakdown-summary.json @@ -3,20 +3,30 @@ "type" : "category", "labels" : { "style" : { - "fontFamily" : "Verdana, sans-serif", - "fontSize" : "13px" + "fontSize" : "13px", + "fontFamily" : "Verdana, sans-serif" } } }, - "title" : { - "text" : "Perl Weekly Challenge Contributions - 2019" - }, "series" : [ { + "name" : "Contributions", + "dataLabels" : { + "rotation" : -90, + "align" : "right", + "color" : "#FFFFFF", + "enabled" : "true", + "format" : "{point.y:.0f}", + "y" : 10, + "style" : { + "fontSize" : "13px", + "fontFamily" : "Verdana, sans-serif" + } + }, "data" : [ [ "Blog", - 374 + 375 ], [ "Perl 5", @@ -24,40 +34,30 @@ ], [ "Perl 6", - 868 + 870 ] - ], - "name" : "Contributions", - "dataLabels" : { - "color" : "#FFFFFF", - "y" : 10, - "enabled" : "true", - "style" : { - "fontSize" : "13px", - "fontFamily" : "Verdana, sans-serif" - }, - "align" : "right", - "rotation" : -90, - "format" : "{point.y:.0f}" - } + ] } ], - "chart" : { - "type" : "column" - }, "subtitle" : { - "text" : "Last updated at 2019-11-20 11:46:16 GMT" - }, - "tooltip" : { - "pointFormat" : "<b>{point.y:.0f}</b>" + "text" : "Last updated at 2019-11-20 11:59:04 GMT" }, "legend" : { "enabled" : "false" }, + "chart" : { + "type" : "column" + }, "yAxis" : { - "min" : 0, "title" : { "text" : null - } + }, + "min" : 0 + }, + "title" : { + "text" : "Perl Weekly Challenge Contributions - 2019" + }, + "tooltip" : { + "pointFormat" : "<b>{point.y:.0f}</b>" } } diff --git a/stats/pwc-language-breakdown.json b/stats/pwc-language-breakdown.json index eaa82de341..ed31cc5a65 100644 --- a/stats/pwc-language-breakdown.json +++ b/stats/pwc-language-breakdown.json @@ -1,4 +1,32 @@ { + "tooltip" : { + "followPointer" : "true", + "pointFormat" : "<span style=\"color:{point.color}\">Challenge {point.name}</span>: <b>{point.y:f}</b><br/>", + "headerFormat" : "<span style=\"font-size:11px\"></span>" + }, + "chart" : { + "type" : "column" + }, + "title" : { + "text" : "Perl Weekly Challenge Language" + }, + "legend" : { + "enabled" : "false" + }, + "yAxis" : { + "title" : { + "text" : "Total Solutions" + } + }, + "plotOptions" : { + "series" : { + "borderWidth" : 0, + "dataLabels" : { + "enabled" : 1, + "format" : "{point.y}" + } + } + }, "drilldown" : { "series" : [ { @@ -20,6 +48,8 @@ ] }, { + "name" : "002", + "id" : "002", "data" : [ [ "Perl 5", @@ -33,12 +63,9 @@ "Blog", 9 ] - ], - "name" : "002", - "id" : "002" + ] }, { - "id" : "003", "data" : [ [ "Perl 5", @@ -53,9 +80,11 @@ 9 ] ], + "id" : "003", "name" : "003" }, { + "name" : "004", "id" : "004", "data" : [ [ @@ -70,11 +99,11 @@ "Blog", 10 ] - ], - "name" : "004" + ] }, { "id" : "005", + "name" : "005", "data" : [ [ "Perl 5", @@ -88,11 +117,9 @@ "Blog", 11 ] - ], - "name" : "005" + ] }, { - "name" : "006", "data" : [ [ "Perl 5", @@ -107,6 +134,7 @@ 7 ] ], + "name" : "006", "id" : "006" }, { @@ -124,8 +152,8 @@ 10 ] ], - "name" : "007", - "id" : "007" + "id" : "007", + "name" : "007" }, { "id" : "008", @@ -164,6 +192,8 @@ "id" : "009" }, { + "name" : "010", + "id" : "010", "data" : [ [ "Perl 5", @@ -177,13 +207,11 @@ "Blog", 11 ] - ], - "name" : "010", - "id" : "010" + ] }, { - "id" : "011", "name" : "011", + "id" : "011", "data" : [ [ "Perl 5", @@ -200,6 +228,7 @@ ] }, { + "id" : "012", "name" : "012", "data" : [ [ @@ -214,10 +243,11 @@ "Blog", 11 ] - ], - "id" : "012" + ] }, { + "id" : "013", + "name" : "013", "data" : [ [ "Perl 5", @@ -231,9 +261,7 @@ "Blog", 13 ] - ], - "name" : "013", - "id" : "013" + ] }, { "id" : "014", @@ -254,6 +282,8 @@ ] }, { + "id" : "015", + "name" : "015", "data" : [ [ "Perl 5", @@ -267,13 +297,9 @@ "Blog", 15 ] - ], - "name" : "015", - "id" : "015" + ] }, { - "id" : "016", - "name" : "016", "data" : [ [ "Perl 5", @@ -287,9 +313,13 @@ "Blog", 12 ] - ] + ], + "id" : "016", + "name" : "016" }, { + "id" : "017", + "name" : "017", "data" : [ [ "Perl 5", @@ -303,12 +333,9 @@ "Blog", 12 ] - ], - "name" : "017", - "id" : "017" + ] }, { - "id" : "018", "data" : [ [ "Perl 5", @@ -323,6 +350,7 @@ 14 ] ], + "id" : "018", "name" : "018" }, { @@ -340,11 +368,10 @@ 13 ] ], - "name" : "019", - "id" : "019" + "id" : "019", + "name" : "019" }, { - "id" : "020", "data" : [ [ "Perl 5", @@ -359,6 +386,7 @@ 13 ] ], + "id" : "020", "name" : "020" }, { @@ -381,6 +409,7 @@ }, { "name" : "022", + "id" : "022", "data" : [ [ "Perl 5", @@ -394,12 +423,9 @@ "Blog", 10 ] - ], - "id" : "022" + ] }, { - "id" : "023", - "name" : "023", "data" : [ [ "Perl 5", @@ -413,9 +439,13 @@ "Blog", 12 ] - ] + ], + "name" : "023", + "id" : "023" }, { + "id" : "024", + "name" : "024", "data" : [ [ "Perl 5", @@ -429,11 +459,10 @@ "Blog", 11 ] - ], - "name" : "024", - "id" : "024" + ] }, { + "name" : "025", "id" : "025", "data" : [ [ @@ -448,11 +477,11 @@ "Blog", 12 ] - ], - "name" : "025" + ] }, { "id" : "026", + "name" : "026", "data" : [ [ "Perl 5", @@ -466,8 +495,7 @@ "Blog", 10 ] - ], - "name" : "026" + ] }, { "data" : [ @@ -484,8 +512,8 @@ 9 ] ], - "name" : "027", - "id" : "027" + "id" : "027", + "name" : "027" }, { "data" : [ @@ -502,10 +530,12 @@ 9 ] ], - "name" : "028", - "id" : "028" + "id" : "028", + "name" : "028" }, { + "id" : "029", + "name" : "029", "data" : [ [ "Perl 5", @@ -519,12 +549,11 @@ "Blog", 12 ] - ], - "name" : "029", - "id" : "029" + ] }, { "id" : "030", + "name" : "030", "data" : [ [ "Perl 5", @@ -538,11 +567,9 @@ "Blog", 10 ] - ], - "name" : "030" + ] }, { - "id" : "031", "data" : [ [ "Perl 5", @@ -557,11 +584,12 @@ 9 ] ], + "id" : "031", "name" : "031" }, { - "id" : "032", "name" : "032", + "id" : "032", "data" : [ [ "Perl 5", @@ -578,6 +606,8 @@ ] }, { + "id" : "033", + "name" : "033", "data" : [ [ "Perl 5", @@ -591,12 +621,9 @@ "Blog", 10 ] - ], - "name" : "033", - "id" : "033" + ] }, { - "id" : "034", "data" : [ [ "Perl 5", @@ -611,10 +638,10 @@ 8 ] ], - "name" : "034" + "name" : "034", + "id" : "034" }, { - "name" : "035", "data" : [ [ "Perl 5", @@ -622,53 +649,52 @@ ], [ "Perl 6", - 8 + 10 ], [ "Blog", - 1 + 2 ] ], - "id" : "035" + "id" : "035", + "name" : "035" } ] }, - "chart" : { - "type" : "column" + "xAxis" : { + "type" : "category" }, "series" : [ { - "colorByPoint" : "true", - "name" : "Perl Weekly Challenge Languages", "data" : [ { + "y" : 132, "drilldown" : "001", - "name" : "#001", - "y" : 132 + "name" : "#001" }, { + "name" : "#002", "drilldown" : "002", - "y" : 104, - "name" : "#002" + "y" : 104 }, { + "drilldown" : "003", "name" : "#003", - "y" : 67, - "drilldown" : "003" + "y" : 67 }, { "name" : "#004", - "y" : 87, - "drilldown" : "004" + "drilldown" : "004", + "y" : 87 }, { - "drilldown" : "005", + "y" : 66, "name" : "#005", - "y" : 66 + "drilldown" : "005" }, { - "drilldown" : "006", "name" : "#006", + "drilldown" : "006", "y" : 48 }, { @@ -678,33 +704,33 @@ }, { "drilldown" : "008", - "y" : 70, - "name" : "#008" + "name" : "#008", + "y" : 70 }, { "name" : "#009", - "y" : 68, - "drilldown" : "009" + "drilldown" : "009", + "y" : 68 }, { + "name" : "#010", "drilldown" : "010", - "y" : 60, - "name" : "#010" + "y" : 60 }, { + "y" : 79, "drilldown" : "011", - "name" : "#011", - "y" : 79 + "name" : "#011" |
