1
0
mirror of https://github.com/kalmarek/Groups.jl.git synced 2025-01-24 16:55:28 +01:00
Groups.jl/test/matrix_groups.jl

84 lines
2.3 KiB
Julia
Raw Normal View History

using Groups.MatrixGroups
@testset "Matrix Groups" begin
@testset "SL(n, )" begin
SL3Z = SpecialLinearGroup{3}(Int8)
2022-10-14 01:14:38 +02:00
S = gens(SL3Z)
union!(S, inv.(S))
2022-10-14 01:14:38 +02:00
_, sizes = Groups.wlmetric_ball(S, radius=4)
2022-04-02 14:53:06 +02:00
@test sizes == [13, 121, 883, 5455]
2022-10-14 01:14:38 +02:00
E(i, j) = SL3Z([A[MatrixGroups.ElementaryMatrix{3}(i, j, Int8(1))]])
2022-04-02 14:53:06 +02:00
A = alphabet(SL3Z)
2022-10-14 01:14:38 +02:00
w = E(1, 2)
r = E(2, 3)^-3
s = E(1, 3)^2 * E(3, 2)^-1
2022-04-02 14:53:06 +02:00
2022-10-14 01:14:38 +02:00
S = [w, r, s]
S = unique([S; inv.(S)])
_, sizes = Groups.wlmetric_ball(S, radius=4)
2022-04-02 14:53:06 +02:00
@test sizes == [7, 33, 141, 561]
2022-10-14 01:14:38 +02:00
_, sizes = Groups.wlmetric_ball_serial(S, radius=4)
2022-04-02 14:53:06 +02:00
@test sizes == [7, 33, 141, 561]
2022-04-02 15:51:29 +02:00
Logging.with_logger(Logging.NullLogger()) do
@testset "GroupsCore conformance" begin
test_Group_interface(SL3Z)
g = SL3Z(rand(1:length(alphabet(SL3Z)), 10))
h = SL3Z(rand(1:length(alphabet(SL3Z)), 10))
test_GroupElement_interface(g, h)
end
end
2022-04-03 16:58:49 +02:00
2022-10-14 01:14:38 +02:00
x = w * inv(w) * r
2022-04-03 16:58:49 +02:00
@test length(word(x)) == 5
2022-10-14 01:14:38 +02:00
@test size(x) == (3, 3)
2022-04-03 16:58:49 +02:00
@test eltype(x) == Int8
@test contains(sprint(print, SL3Z), "special linear group of 3×3")
@test contains(sprint(show, MIME"text/plain"(), x), "SL{3,Int8} matrix:")
@test sprint(print, x) isa String
@test length(word(x)) == 3
end
2022-04-02 16:19:08 +02:00
@testset "Sp(6, )" begin
Sp6 = MatrixGroups.SymplecticGroup{6}(Int8)
2022-10-14 01:14:38 +02:00
Logging.with_logger(Logging.NullLogger()) do
@testset "GroupsCore conformance" begin
test_Group_interface(Sp6)
g = Sp6(rand(1:length(alphabet(Sp6)), 10))
h = Sp6(rand(1:length(alphabet(Sp6)), 10))
2022-04-02 16:19:08 +02:00
2022-10-14 01:14:38 +02:00
test_GroupElement_interface(g, h)
end
2022-04-02 16:19:08 +02:00
end
2022-04-03 16:58:49 +02:00
@test contains(sprint(print, Sp6), "group of 6×6 symplectic matrices")
x = gens(Sp6, 1)
x *= inv(x) * gens(Sp6, 2)
@test length(word(x)) == 3
2022-10-14 01:14:38 +02:00
@test size(x) == (6, 6)
2022-04-03 16:58:49 +02:00
@test eltype(x) == Int8
@test contains(sprint(show, MIME"text/plain"(), x), "6×6 symplectic matrix:")
@test sprint(print, x) isa String
@test length(word(x)) == 1
2022-04-03 18:40:02 +02:00
for g in gens(Sp6)
@test MatrixGroups.issymplectic(MatrixGroups.matrix_repr(g))
end
2022-04-02 16:19:08 +02:00
end
end