Skip to content

Commit

Permalink
Deprecate prime number functions (isprime, primes, primesmask, …
Browse files Browse the repository at this point in the history
…`factor`)

See #16357
  • Loading branch information
simonbyrne authored and tkelman committed May 21, 2016
1 parent 99bf23d commit 84768d3
Show file tree
Hide file tree
Showing 11 changed files with 99 additions and 273 deletions.
93 changes: 89 additions & 4 deletions base/primes.jl → base/deprecated-primes.jl
Original file line number Diff line number Diff line change
@@ -1,5 +1,13 @@
# This file is a part of Julia. License is MIT: http://julialang.org/license

export isprime, primes, primesmask, factor


function isprime(x::BigInt, reps=25)
depwarn("isprime(...) has been deprecated, use isprime(...) in Primes.jl instead", :isprime)
ccall((:__gmpz_probab_prime_p,:libgmp), Cint, (Ptr{BigInt}, Cint), &x, reps) > 0
end

# Primes generating functions
# https://en.wikipedia.org/wiki/Sieve_of_Eratosthenes
# https://en.wikipedia.org/wiki/Wheel_factorization
Expand Down Expand Up @@ -55,6 +63,8 @@ end

# Sieve of the primes from lo up to hi represented as an array of booleans
function primesmask(lo::Int, hi::Int)
depwarn("primesmask(...) has been deprecated, use primesmask(...) in Primes.jl instead", :primesmask)

0 < lo hi || throw(ArgumentError("the condition 0 < lo ≤ hi must be met"))
sieve = falses(hi - lo + 1)
lo 2 hi && (sieve[3-lo] = true)
Expand All @@ -77,6 +87,12 @@ primesmask(n::Integer) = n <= typemax(Int) ? primesmask(Int(n)) :
throw(ArgumentError("requested number of primes must be ≤ $(typemax(Int)), got $n"))

function primes(lo::Int, hi::Int)
depwarn("primes(...) has been deprecated, use primes(...) in Primes.jl instead", :primes)
primes_nowarn(lo,hi)
end


function primes_nowarn(lo::Int, hi::Int)
lo hi || throw(ArgumentError("the condition lo ≤ hi must be met"))
list = Int[]
lo 2 hi && push!(list, 2)
Expand All @@ -93,12 +109,14 @@ function primes(lo::Int, hi::Int)
end
primes(n::Int) = primes(1, n)

const PRIMES = primes(2^16)
const PRIMES = primes_nowarn(1, 2^16)

# Small precomputed primes + Miller-Rabin for primality testing:
# https://en.wikipedia.org/wiki/Miller–Rabin_primality_test
#
function isprime(n::Integer)
depwarn("isprime(...) has been deprecated, use isprime(...) in Primes.jl instead", :isprime)

(n < 3 || iseven(n)) && return n == 2
n <= 2^16 && return PRIMES[searchsortedlast(PRIMES,n)] == n
s = trailing_zeros(n-1)
Expand Down Expand Up @@ -130,10 +148,14 @@ witnesses(n::Union{UInt64,Int64}) =
n < 3474749660383 ? (2,3,5,7,11,13) :
(2,325,9375,28178,450775,9780504,1795265022)

isprime(n::UInt128) =
function isprime(n::UInt128)
depwarn("isprime(...) has been deprecated, use isprime(...) in Primes.jl instead", :isprime)
n <= typemax(UInt64) ? isprime(UInt64(n)) : isprime(BigInt(n))
isprime(n::Int128) = n < 2 ? false :
n <= typemax(Int64) ? isprime(Int64(n)) : isprime(BigInt(n))
end
function isprime(n::Int128)
depwarn("isprime(...) has been deprecated, use isprime(...) in Primes.jl instead", :isprime)
n < 2 ? false : n <= typemax(Int64) ? isprime(Int64(n)) : isprime(BigInt(n))
end


# Trial division of small (< 2^16) precomputed primes +
Expand All @@ -143,6 +165,8 @@ isprime(n::Int128) = n < 2 ? false :
# http://maths-people.anu.edu.au/~brent/pub/pub051.html
#
function factor{T<:Integer}(n::T)
depwarn("factor(...) has been deprecated, use factor(...) in Primes.jl instead", :factor)

0 < n || throw(ArgumentError("number to be factored must be ≥ 0, got $n"))
h = Dict{T,Int}()
n == 1 && return h
Expand Down Expand Up @@ -204,3 +228,64 @@ function pollardfactors!{T<:Integer,K<:Integer}(n::T, h::Dict{K,Int})
end
end
end


"""
primes([lo,] hi)
Returns a collection of the prime numbers (from `lo`, if specified) up to `hi`.
"""
primes

"""
primesmask([lo,] hi)
Returns a prime sieve, as a `BitArray`, of the positive integers (from `lo`, if specified)
up to `hi`. Useful when working with either primes or composite numbers.
"""
primesmask


"""
factor(n) -> Dict
Compute the prime factorization of an integer `n`. Returns a dictionary. The keys of the
dictionary correspond to the factors, and hence are of the same type as `n`. The value
associated with each key indicates the number of times the factor appears in the
factorization.
```jldoctest
julia> factor(100) # == 2*2*5*5
Dict{Int64,Int64} with 2 entries:
2 => 2
5 => 2
```
"""
factor


"""
isprime(x::Integer) -> Bool
Returns `true` if `x` is prime, and `false` otherwise.
```jldoctest
julia> isprime(3)
true
```
"""
isprime(::Integer)

"""
isprime(x::BigInt, [reps = 25]) -> Bool
Probabilistic primality test. Returns `true` if `x` is prime; and `false` if `x` is not
prime with high probability. The false positive rate is about `0.25^reps`. `reps = 25` is
considered safe for cryptographic applications (Knuth, Seminumerical Algorithms).
```jldoctest
julia> isprime(big(3))
true
```
"""
isprime(::BigInt, ?)
3 changes: 3 additions & 0 deletions base/deprecated.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1186,6 +1186,9 @@ end
isequal(x::Char, y::Integer) = false
isequal(x::Integer, y::Char) = false

# prime numbers
include("deprecated-primes.jl")

# During the 0.5 development cycle, do not add any deprecations below this line
# To be deprecated in 0.6

Expand Down
58 changes: 0 additions & 58 deletions base/docs/helpdb/Base.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1291,21 +1291,6 @@ is equivalent to `!isapprox(x,y)`.
"""
isapprox

"""
primes([lo,] hi)
Returns a collection of the prime numbers (from `lo`, if specified) up to `hi`.
"""
primes

"""
primesmask([lo,] hi)
Returns a prime sieve, as a `BitArray`, of the positive integers (from `lo`, if specified)
up to `hi`. Useful when working with either primes or composite numbers.
"""
primesmask

"""
sinh(x)
Expand Down Expand Up @@ -7771,23 +7756,6 @@ the same as the way an object is printed in the Julia REPL.)
"""
TextDisplay

"""
factor(n) -> Dict
Compute the prime factorization of an integer `n`. Returns a dictionary. The keys of the
dictionary correspond to the factors, and hence are of the same type as `n`. The value
associated with each key indicates the number of times the factor appears in the
factorization.
```jldoctest
julia> factor(100) # == 2*2*5*5
Dict{Int64,Int64} with 2 entries:
2 => 2
5 => 2
```
"""
factor

"""
ismatch(r::Regex, s::AbstractString) -> Bool
Expand Down Expand Up @@ -8453,32 +8421,6 @@ any element type for which `dot` is defined), compute the Euclidean dot product
"""
vecdot

"""
isprime(x::Integer) -> Bool
Returns `true` if `x` is prime, and `false` otherwise.
```jldoctest
julia> isprime(3)
true
```
"""
isprime(::Integer)

"""
isprime(x::BigInt, [reps = 25]) -> Bool
Probabilistic primality test. Returns `true` if `x` is prime; and `false` if `x` is not
prime with high probability. The false positive rate is about `0.25^reps`. `reps = 25` is
considered safe for cryptographic applications (Knuth, Seminumerical Algorithms).
```jldoctest
julia> isprime(big(3))
true
```
"""
isprime(::BigInt, ?)

"""
>(x, y)
Expand Down
4 changes: 0 additions & 4 deletions base/exports.jl
Original file line number Diff line number Diff line change
Expand Up @@ -354,7 +354,6 @@ export
exp2,
expm1,
exponent,
factor,
factorial,
fld,
fld1,
Expand Down Expand Up @@ -383,7 +382,6 @@ export
isnan,
isodd,
ispow2,
isprime,
isqrt,
isreal,
isimag,
Expand Down Expand Up @@ -415,8 +413,6 @@ export
prevfloat,
prevpow,
prevpow2,
primes,
primesmask,
rad2deg,
rationalize,
real,
Expand Down
4 changes: 1 addition & 3 deletions base/gmp.jl
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ export BigInt

import Base: *, +, -, /, <, <<, >>, >>>, <=, ==, >, >=, ^, (~), (&), (|), ($),
binomial, cmp, convert, div, divrem, factorial, fld, gcd, gcdx, lcm, mod,
ndigits, promote_rule, rem, show, isqrt, string, isprime, powermod,
ndigits, promote_rule, rem, show, isqrt, string, powermod,
sum, trailing_zeros, trailing_ones, count_ones, base, tryparse_internal,
bin, oct, dec, hex, isequal, invmod, prevpow2, nextpow2, ndigits0z, widen, signed, unsafe_trunc, trunc

Expand Down Expand Up @@ -541,8 +541,6 @@ function ndigits0z(x::BigInt, b::Integer=10)
end
ndigits(x::BigInt, b::Integer=10) = x.size == 0 ? 1 : ndigits0z(x,b)

isprime(x::BigInt, reps=25) = ccall((:__gmpz_probab_prime_p,:libgmp), Cint, (Ptr{BigInt}, Cint), &x, reps) > 0

prevpow2(x::BigInt) = x.size < 0 ? -prevpow2(-x) : (x <= 2 ? x : one(BigInt) << (ndigits(x, 2)-1))
nextpow2(x::BigInt) = x.size < 0 ? -nextpow2(-x) : (x <= 2 ? x : one(BigInt) << ndigits(x-1, 2))

Expand Down
2 changes: 0 additions & 2 deletions base/sysimg.jl
Original file line number Diff line number Diff line change
Expand Up @@ -178,8 +178,6 @@ include("multidimensional.jl")
include("permuteddimsarray.jl")
using .PermutedDimsArrays

include("primes.jl")

let SOURCE_PATH = ""
global include = function(path)
prev = SOURCE_PATH
Expand Down
4 changes: 0 additions & 4 deletions contrib/BBEditTextWrangler-julia.plist
Original file line number Diff line number Diff line change
Expand Up @@ -432,7 +432,6 @@
<string>export</string>
<string>extrema</string>
<string>eye</string>
<string>factor</string>
<string>factorial</string>
<string>factorize</string>
<string>falses</string>
Expand Down Expand Up @@ -642,7 +641,6 @@
<string>isposdef!</string>
<string>isposdef</string>
<string>ispow2</string>
<string>isprime</string>
<string>isprint</string>
<string>ispunct</string>
<string>isqrt</string>
Expand Down Expand Up @@ -858,8 +856,6 @@
<string>prevind</string>
<string>prevpow2</string>
<string>prevpow</string>
<string>primes</string>
<string>primesmask</string>
<string>print</string>
<string>print_escaped</string>
<string>print_joined</string>
Expand Down
13 changes: 6 additions & 7 deletions doc/manual/arrays.rst
Original file line number Diff line number Diff line change
Expand Up @@ -319,14 +319,13 @@ Example:
6 10
7 11

julia> x[map(isprime, x)]
6-element Array{Int64,1}:
julia> x[map(ispow2, x)]
5-element Array{Int64,1}:
1
2
3
5
7
11
13
4
8
16

julia> x[1, [2 3; 4 1]]
2x2 Array{Int64,2}:
Expand Down
6 changes: 0 additions & 6 deletions test/bigint.jl
Original file line number Diff line number Diff line change
Expand Up @@ -217,12 +217,6 @@ g = parse(BigInt,"-1")
@test (|)(a, b, c, d, f) == parse(BigInt,"-1358954753")
@test (|)(a, b, c, d, f, g) == parse(BigInt,"-1")

@test isprime(BigInt(1000000007))
@test isprime(BigInt(1000000007), 1)
@test isprime(BigInt(10000000019))
@test isprime(parse(BigInt,"359334085968622831041960188598043661065388726959079837"))
@test !isprime(BigInt(1))
@test !isprime(BigInt(10000000020))

@test trailing_ones(a) == 8
@test trailing_zeros(b) == 2
Expand Down
9 changes: 0 additions & 9 deletions test/euler.jl
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,6 @@ function euler2(n)
end
@test euler2(4000000) == 4613732

#3: 6857
@test maximum(keys(factor(600851475143))) == 6857

#4: 906609
function euler4(n)
m = 1
Expand All @@ -47,10 +44,6 @@ end
#6: 25164150
@test sum(1:100)^2 - sum((1:100).^2) == 25164150

#7: 104743
euler7(n) = primes(floor(Int,n*log(n*log(n))))[n]
@test euler7(10001) == 104743

#8: 40824
function euler8(n,m)
d = digits(n)
Expand All @@ -68,8 +61,6 @@ function euler9(n)
end
@test euler9(1000) == 31875000

#10: 142913828922
@test sum(map(Int64,primes(2000000))) == 142913828922

#11: 70600674
function euler11(grid,n)
Expand Down
Loading

0 comments on commit 84768d3

Please sign in to comment.