Skip to content

Instantly share code, notes, and snippets.

@gfldex
Created July 7, 2021 15:29
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save gfldex/962e83b4a0b76c65960711d30a294210 to your computer and use it in GitHub Desktop.
Save gfldex/962e83b4a0b76c65960711d30a294210 to your computer and use it in GitHub Desktop.
sub prefix:<♥>(&c) {
sub avg(@a) { @a.sum / +@a }
state %run-times;
LEAVE %run-times{&c.WHY}.push: (now - ENTER now);
END { say .key, ‚: ‘, .value »~» ‚s‘, ‚ avg: ‘,.value.&avg ~ ‚s‘ for %run-times }
c
}
for ^5 {
#| grep
♥ { say sum (^100_000).grep: *.is-prime; }
#| do for
♥ { say sum do for ^100_000 { .&next if .is-prime; } }
#| eager for
♥ { say sum eager for ^100_000 { .&next if .is-prime; } }
#| gather
♥ { say sum gather for ^100_000 { .take if .is-prime; } }
my \a = lazy gather for ^100_000_000 { .take if .is-prime; }
my \b = lazy for ^100_000_000 { .&next if .is-prime; }
#| lazy gather
♥ { say sum a[^100_000]; }
#| lazy for
♥ { say sum b[^100_000]; }
}
@tony-o
Copy link

tony-o commented Jul 7, 2021

m1 output:

454396537
Cannot resolve caller next(Int:D); none of these signatures match:
    ( --> Nil)
    (Label:D \x --> Nil)
  in code  at m.raku line 14
  in block  at m.raku line 14
  in block <unit> at m.raku line 9

grep: [0.061793717s] avg: 0.061793717s
do for: [0.00066448s] avg: 0.00066448s

@tony-o
Copy link

tony-o commented Jul 7, 2021

454396537
454396537
454396537
454396537
62260698721
62260698721
454396537
454396537
454396537
454396537
62260698721
62260698721
454396537
454396537
454396537
454396537
62260698721
62260698721
454396537
454396537
454396537
454396537
62260698721
62260698721
454396537
454396537
454396537
454396537
62260698721
62260698721
do for: [0.109006467s 0.107999665s 0.107718174s 0.105453619s 0.106429631s] avg: 0.1073215112s
gather: [0.089340866s 0.089803102s 0.089685898s 0.08841527s 0.095971453s] avg: 0.0906433178s
lazy for: [1.77557334s 1.793584325s 1.83347551s 1.794552087s 1.817099641s] avg: 1.8028569806s
lazy gather: [1.310523282s 1.295354835s 1.296478217s 1.328098282s 1.316869878s] avg: 1.3094648988s
eager for: [0.128505199s 0.118648003s 0.1181926s 0.116535277s 0.142791966s] avg: 0.124934609s
grep: [0.07783843s 0.079448088s 0.077027372s 0.075312549s 0.07303012s] avg: 0.0765313118s

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment