Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Jaa/is nilpotent #1974

Merged
merged 37 commits into from
Jan 9, 2025
Merged
Show file tree
Hide file tree
Changes from 20 commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
77e4926
Improved is_nilpotent(::ResElem)
JohnAAbbott Dec 13, 2024
07d5861
Merge branch 'Nemocas:master' into JAA/is_nilpotent
JohnAAbbott Dec 13, 2024
f1abed2
New tests for is_nilpotent
JohnAAbbott Dec 13, 2024
0b80802
Merge branch 'JAA/is_nilpotent' of github.com:JohnAAbbott/Nemo.jl int…
JohnAAbbott Dec 13, 2024
7173aa9
Removed spaces which triggered syntax error
JohnAAbbott Dec 13, 2024
7b2fea9
Fixed typo (from careless copy-paste)
JohnAAbbott Dec 13, 2024
db38bc5
Inserted missing defn of is_domain_type
JohnAAbbott Dec 13, 2024
7928bd5
Inserted missing defn of is_domain_type
JohnAAbbott Dec 13, 2024
dd78f50
Inserted missing defn of is_domain_type
JohnAAbbott Dec 13, 2024
6c5912f
Inserted missing defn of is_domain_type
JohnAAbbott Dec 13, 2024
9cb13a3
Add defns of is_nilpotent for ZZRingElem & QQFieldElem
JohnAAbbott Dec 13, 2024
1061b42
Bugfix: use data instead of lift, use mod! to avoid overflow
JohnAAbbott Dec 16, 2024
d5739b3
Minor impl change to is_nilpotent
JohnAAbbott Dec 16, 2024
80afb22
Removed unnecessary is_domain_type defn
JohnAAbbott Dec 16, 2024
e714f6c
Removed unnecessary is_domain_type defn
JohnAAbbott Dec 16, 2024
4254da6
Removed unnecessary is_domain_type defn
JohnAAbbott Dec 16, 2024
013b53c
Removed unnecessary is_domain_type defn
JohnAAbbott Dec 16, 2024
9d2354e
Added overflow test
JohnAAbbott Dec 16, 2024
a755c62
Fixed typo
JohnAAbbott Dec 16, 2024
96616b1
Commented out buggy old impl of is_unit
JohnAAbbott Dec 17, 2024
0773b26
Merge branch 'Nemocas:master' into JAA/is_nilpotent
JohnAAbbott Dec 18, 2024
80e1c02
is_unit subsumed by impl in AbstractAlgebra/src/generic/Residue.jl
JohnAAbbott Dec 20, 2024
61e9fc1
is_nilpotent subsumed by impl in AbstractAlgebra/src/Residue.jl
JohnAAbbott Dec 20, 2024
2de0918
Minor: inserted underscore dummy arg
JohnAAbbott Dec 20, 2024
3829e3a
Merge branch 'master' into JAA/is_nilpotent
fingolfin Dec 21, 2024
e3004f4
Require AA 0.44.2
fingolfin Dec 21, 2024
c09c7df
Apply suggestions from code review
fingolfin Dec 22, 2024
fe4c891
Remove more redundant methods
fingolfin Dec 22, 2024
08f690d
Remove more redundant stuff
fingolfin Dec 22, 2024
baa6317
Remove more redundant methods
fingolfin Dec 22, 2024
31125c8
Removed blank line
JohnAAbbott Jan 8, 2025
77dbc49
Removed blank line
JohnAAbbott Jan 8, 2025
b319a28
Moved test on residue_ring(ZZ,720) to nmod; replaced length(filter(..…
JohnAAbbott Jan 8, 2025
959bc11
Moved test from fmpz_mod-test to here: is_nilpotent in ZZmod720
JohnAAbbott Jan 8, 2025
cebd9c6
Inserted a space
JohnAAbbott Jan 8, 2025
522970d
Merge branch 'Nemocas:master' into JAA/is_nilpotent
JohnAAbbott Jan 8, 2025
956abae
Merge branch 'JAA/is_nilpotent' of github.com:JohnAAbbott/Nemo.jl int…
JohnAAbbott Jan 8, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 13 additions & 5 deletions src/HeckeMoreStuff.jl
Original file line number Diff line number Diff line change
Expand Up @@ -391,11 +391,19 @@ end

Tests if $a$ is nilpotent.
"""
function is_nilpotent(a::ResElem{T}) where {T<:IntegerUnion}
#a is nilpontent if it is divisible by all primes divising the modulus
# the largest exponent a prime can divide is nbits(m)
l = nbits(modulus(a))
return iszero(a^l)
function is_nilpotent(res::ResElem{T}) where {T<:IntegerUnion}
# Code below is faster than
# m=modulus(res);
# return powermod(lift(res),nbits(m),m)==0
m = modulus(res)
r = data(res) # the least non-negative class representative as a value of type "unsigned" T; !!note that "lift" casts the value to BigInt!!
while true
g = gcd(r, m)
(g == m) && return true
(g == 1) && return false
m = divexact(m, g) # equiv to: m /= g
mod!(g, m); r = g^2 # g^2 cannot overflow thanks to mod!
fingolfin marked this conversation as resolved.
Show resolved Hide resolved
end
end

function inv(f::T) where {T<:Union{ZZModPolyRingElem,zzModPolyRingElem}}
Expand Down
2 changes: 2 additions & 0 deletions src/flint/fmpq.jl
Original file line number Diff line number Diff line change
Expand Up @@ -115,6 +115,8 @@ is_zero(a::QQFieldElemOrPtr) = is_zero(_num_ptr(a))

is_unit(a::QQFieldElem) = !iszero(a)

is_nilpotent(a::QQFieldElem) = iszero(a)
fingolfin marked this conversation as resolved.
Show resolved Hide resolved
fingolfin marked this conversation as resolved.
Show resolved Hide resolved

isinteger(a::QQFieldElemOrPtr) = is_one(_den_ptr(a))

isfinite(::QQFieldElem) = true
Expand Down
2 changes: 2 additions & 0 deletions src/flint/fmpz.jl
Original file line number Diff line number Diff line change
Expand Up @@ -254,6 +254,8 @@ size(a::ZZRingElem) = _fmpz_is_small(a) ? 1 : abs(_fmpz_size(a))

is_unit(a::ZZRingElemOrPtr) = data(a) == 1 || data(a) == -1

is_nilpotent(a::ZZRingElemOrPtr) = (data(a) == 0)

fingolfin marked this conversation as resolved.
Show resolved Hide resolved
is_zero(a::ZZRingElemOrPtr) = data(a) == 0

is_one(a::ZZRingElemOrPtr) = data(a) == 1
Expand Down
1 change: 1 addition & 0 deletions src/flint/nmod.jl
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ base_ring(a::zzModRing) = ZZ

parent(a::zzModRingElem) = a.parent


fingolfin marked this conversation as resolved.
Show resolved Hide resolved
###############################################################################
#
# Basic manipulation
Expand Down
6 changes: 3 additions & 3 deletions src/flint/nmod_mpoly.jl
Original file line number Diff line number Diff line change
Expand Up @@ -100,9 +100,9 @@ for (etype, rtype, ftype, ctype, utype) in (
return length(a) == 1
end

function is_unit(a::($etype))
return length(a) == 1 && total_degree(a) == 0 && is_unit(coeff(a, 1))
end
# function is_unit(a::($etype))
# return length(a) == 1 && total_degree(a) == 0 && is_unit(coeff(a, 1))
# end

fingolfin marked this conversation as resolved.
Show resolved Hide resolved
function is_constant(a::($etype))
return Bool(@ccall libflint.nmod_mpoly_is_ui(a::Ref{($etype)}, parent(a)::Ref{($rtype)})::Cint)
Expand Down
1 change: 1 addition & 0 deletions src/flint/nmod_poly.jl
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ elem_type(::Type{zzModPolyRing}) = zzModPolyRingElem

dense_poly_type(::Type{zzModRingElem}) = zzModPolyRingElem


fingolfin marked this conversation as resolved.
Show resolved Hide resolved
################################################################################
#
# Basic helper
Expand Down
18 changes: 18 additions & 0 deletions test/flint/fmpz_mod-test.jl
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,8 @@ end

@test !is_unit(R())
@test is_unit(R(3))
@test is_nilpotent(R())
@test !is_nilpotent(R(3))

@test deepcopy(R(3)) == R(3)

Expand All @@ -103,6 +105,7 @@ end
@test modulus(S) == UInt(1)

@test is_unit(S())
@test is_nilpotent(S())

@test characteristic(R) == 13

Expand All @@ -128,6 +131,21 @@ end
@test_throws Exception R6(R22(1))
@test_throws Exception R2(R3(1))
@test_throws Exception R3(R2(1))

ZZmod720,_ = residue_ring(ZZ,720)
JohnAAbbott marked this conversation as resolved.
Show resolved Hide resolved
ZZmodZZ720,_ = residue_ring(ZZ,ZZ(720))
@test is_nilpotent(ZZmod720(30))
@test is_nilpotent(ZZmodZZ720(30))
nilp720 = filter((r -> is_nilpotent(ZZmod720(r))), 0:719);
@test length(nilp720) == 24 # 720/(2*3*5)
JohnAAbbott marked this conversation as resolved.
Show resolved Hide resolved
nilp720 = filter((r -> is_nilpotent(ZZmodZZ720(r))), 0:719);
@test length(nilp720) == 24 # 720/(2*3*5)

# 64-bit overflow test: **ASSUMES** Int is 64 bits
rr = 4*3^20
mm = 3*rr
R_overflow, = residue_ring(ZZ, mm)
@test is_nilpotent(R_overflow(rr))
end

@testset "ZZModRingElem.unary_ops" begin
Expand Down
Loading