From 811a2154f3c76e60b215ef231002265b0310d8c1 Mon Sep 17 00:00:00 2001 From: Oscar Smith Date: Wed, 21 Feb 2024 09:43:42 -0500 Subject: [PATCH 1/2] fix `eachfactor` type stability fixes https://github.com/JuliaMath/Primes.jl/issues/151. (test incoming) --- src/Primes.jl | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Primes.jl b/src/Primes.jl index 6971891..6025ae0 100644 --- a/src/Primes.jl +++ b/src/Primes.jl @@ -357,7 +357,7 @@ function iterate(f::FactorIterator{T}, state=(f.n, T(3))) where T tz = trailing_zeros(n) tz>0 && return (T(2), Int(tz)), (n >> tz, p) if n <= N_SMALL_FACTORS - p = _min_factor(n) + p = T(_min_factor(n)) num_p = 1 while true n = div(n, p) @@ -369,7 +369,7 @@ function iterate(f::FactorIterator{T}, state=(f.n, T(3))) where T elseif p == 3 && isprime(n) return (n, 1), (T(1), n) end - for p in p:2:N_SMALL_FACTORS + for p in p:T(2):T(N_SMALL_FACTORS) _min_factor(p) == p || continue num_p = 0 while true From 693f648d6ad8ae2e4120a0772b3131a0a696b450 Mon Sep 17 00:00:00 2001 From: oscarddssmith Date: Wed, 21 Feb 2024 10:02:40 -0500 Subject: [PATCH 2/2] add test --- test/runtests.jl | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/test/runtests.jl b/test/runtests.jl index 27b18b9..cb5dc7c 100644 --- a/test/runtests.jl +++ b/test/runtests.jl @@ -247,11 +247,16 @@ end @test all([issorted(collect(factor(rand(Int)))) for x in 1:100]) # test eachfactor iteration -@test iterate(eachfactor(36)) == ((2, 2), (9, 3)) -@test iterate(eachfactor(7^2*5^3)) == ((5, 3), (49, 5)) -@test iterate(eachfactor(257)) == ((257, 1), (1, 257)) -@test iterate(eachfactor(nextprime(2^16))) == ((65537, 1), (1, 65537)) - +for T in (Int32, Int64, BigInt) + @test iterate(eachfactor(T(36))) == ((T(2), 2), T.((9, 3))) + @test iterate(eachfactor(T(7^2*5^3))) == ((T(5), 3), T.((49, 5))) + @test iterate(eachfactor(T(257))) == ((T(257), 1), T.((1, 257))) + @test iterate(eachfactor(T(nextprime(2^16)))) == ((T(65537), 1), T.((1, 65537))) + for (p,e) in eachfactor(T(901800900)) + @test (p,e) isa Tuple{T, Int} + end +end + # Lucas-Lehmer @test !ismersenneprime(2047) @test ismersenneprime(8191) @@ -341,7 +346,7 @@ divisors_brute_force(n) = [d for d in one(n):n if iszero(n % d)] for n in 2:1000 ds = divisors(T(n)) - @test ds == divisors(-T(n)) + @test ds == divisors(-T(n)) @test sort!(ds) == divisors_brute_force(T(n)) end end