factor/basis/math/primes/primes.factor

35 lines
888 B
Factor
Raw Normal View History

! Copyright (C) 2007-2009 Samuel Tardieu.
2007-12-26 21:59:39 -05:00
! See http://factorcode.org/license.txt for BSD license.
2009-05-10 13:24:43 -04:00
USING: combinators kernel math math.functions
math.primes.miller-rabin math.order math.primes.erato
math.ranges sequences ;
2007-12-26 21:59:39 -05:00
IN: math.primes
<PRIVATE
: look-in-bitmap ( n -- ? ) >index 4999999 sieve nth ;
2007-12-26 21:59:39 -05:00
: really-prime? ( n -- ? )
dup 5000000 < [ look-in-bitmap ] [ miller-rabin ] if ; foldable
2007-12-26 21:59:39 -05:00
PRIVATE>
2007-12-26 21:59:39 -05:00
: prime? ( n -- ? )
{
{ [ dup 2 < ] [ drop f ] }
{ [ dup even? ] [ 2 = ] }
[ really-prime? ]
} cond ; foldable
: next-prime ( n -- p )
next-odd [ dup really-prime? ] [ 2 + ] until ; foldable
2007-12-26 21:59:39 -05:00
: primes-between ( low high -- seq )
[ dup 3 max dup even? [ 1 + ] when ] dip
2 <range> [ prime? ] filter
swap 3 < [ 2 prefix ] when ;
: primes-upto ( n -- seq ) 2 swap primes-between ;
2008-02-28 00:09:29 -05:00
: coprime? ( a b -- ? ) gcd nip 1 = ; foldable