[Purdue-pm] Perl 6

Mark Daniel Ward mdw at purdue.edu
Tue Jul 10 06:52:07 PDT 2018


Dear Mark,

Perl 6 can do this so quickly, because it knows the formula you 
mentioned (which was also known to Gauss, and is known to all math 
students now).

I wonder what repository of formulas like this are known by Perl, and 
how it learns new formulas.

This seems to be a key strength of Sage (which is built on Python), 
which is causing Sage to take over the symbolic math world (formerly a 
territory that Maple and Mathematica owned). Sage is community 
developed, so anybody can make contributions to similar formulas that 
Sage would inherently know.

This is a key strength of Sage over Mathematica, and I wonder if it is a 
strength of Sage over Perl 6 ?  For comparison, do you know how to 
enable Perl to learn other formulas that might be found in the OEIS 
(On-Line Encyclopedia of Integer Sequences) that have nice formulas?

Mark


On 7/10/18 8:56 AM, Mark Senn wrote:
> Carl Friedrich Gauss added the integers from 1 to 100 ca 1784
> using the formula (n/2)(n+1).  See pages 12--13 of
>      https://books.google.co.uk/books?id=4mwSrfxBSzkC&printsec=frontcover#v=onepage&q&f=false
> for details.
>
>
> Brian Duggan <bduggan2 at gmail.com> wrote on 2018-07-10 at 06:42 -04:
> To: ToddAndMargo <ToddAndMargo at zoho.com>
> Cc: perl6-users <perl6-users at perl.org>
> Subject: Re: An interesting math formula to share
> Message-ID: <20180710104250.GA22895 at localhost>
> |  Another cool thing is that this formula is used in Perl 6 under the hood
> |  to calculate the sum of the integers in a range instantly:
>
>
> It nice not to worry about integer overflow with Perl 6.
> Perl 6 has the formula to add integers from 1 to n built-in
> so adding 1 to 10^1000 doesn't take much longer than adding
> 1 + 2 + 3.
>
> $ /usr/bin/time -f '%e wall clock seconds' perl6 -e 'say [+] 1..3'
> 6
> 0.39 wall clock seconds
>
> $ /usr/bin/time -f '%e wall clock seconds' perl6 -e 'say [+] 1..10'
> 55
> 0.40 wall clock seconds
>
> $ /usr/bin/time -f '%e wall clock seconds' perl6 -e 'say [+] 1..10**1'
> 55
> 0.40 wall clock seconds
>
> $ /usr/bin/time -f '%e wall clock seconds' perl6 -e 'say [+] 1..100'
> 5050
> 0.40 wall clock seconds
>
> $ /usr/bin/time -f '%e wall clock seconds' perl6 -e 'say [+] 1..10**2'
> 5050
> 0.40 wall clock seconds
>
> $ /usr/bin/time -f '%e wall clock seconds' perl6 -e 'say [+] 1..10**1000'
> 50000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
>   0050000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
>   00000
> 0.41 wall clock seconds
>
>
> -mark
> _______________________________________________
> Purdue-pm mailing list
> Purdue-pm at pm.org
> http://mail.pm.org/mailman/listinfo/purdue-pm


More information about the Purdue-pm mailing list