2017-01-23 16:45:24 +01:00
|
|
|
using Groups
|
|
|
|
using Base.Test
|
|
|
|
|
|
|
|
# write your own tests here
|
2017-01-23 16:53:33 +01:00
|
|
|
s = FGSymbol("s")
|
|
|
|
t = FGSymbol("t")
|
|
|
|
|
|
|
|
@testset "FGSymbols" begin
|
|
|
|
@testset "defines" begin
|
|
|
|
@test isa(FGSymbol(string(Char(rand(50:2000)))), Groups.GSymbol)
|
|
|
|
@test FGSymbol("abc").pow == 1
|
|
|
|
@test isa(s, FGSymbol)
|
|
|
|
@test isa(t, FGSymbol)
|
|
|
|
end
|
|
|
|
@testset "eltary functions" begin
|
|
|
|
@test length(s) == 1
|
|
|
|
@test one(s) == s^0
|
|
|
|
@test one(s) == one(FGSymbol)
|
|
|
|
@test Groups.change_pow(s,0) == one(s)
|
|
|
|
@test length(one(s)) == 0
|
|
|
|
@test inv(s).pow == -1
|
|
|
|
@test FGSymbol("s", 3) == Groups.change_pow(s,3)
|
|
|
|
@test s^2 ≠ t^2
|
|
|
|
|
|
|
|
end
|
|
|
|
@testset "powers" begin
|
|
|
|
s⁴ = Groups.change_pow(s,4)
|
|
|
|
@test s⁴.pow == 4
|
|
|
|
@test (s^4).symbols[1] == Groups.change_pow(s,4)
|
|
|
|
@test s*s == s^2
|
|
|
|
@test inv(s*s) == inv(s^2)
|
|
|
|
@test inv(s)^2 == inv(s^2)
|
|
|
|
@test inv(s)*inv(s) == inv(s^2)
|
|
|
|
@test inv(s*s) == inv(s)*inv(s)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
@testset "GWords" begin
|
|
|
|
@testset "defines" begin
|
|
|
|
@test isa(Groups.GWord(s), Groups.GWord)
|
|
|
|
@test isa(Groups.GWord(s), FGWord)
|
|
|
|
@test isa(FGWord(s), Groups.GWord)
|
|
|
|
@test isa(s*s, FGWord)
|
|
|
|
@test s*s == s^2
|
|
|
|
@test t*s ≠ s*t
|
|
|
|
end
|
|
|
|
@testset "eltary functions" begin
|
|
|
|
@test length(FGWord(s)) == 1
|
|
|
|
@test length(s*s) == 2
|
|
|
|
@test length(s*s^-1) == 0
|
|
|
|
@test length(s*t^-1) == 2
|
|
|
|
@test isa(one(FGWord), FGWord)
|
|
|
|
@test one(FGWord).symbols == Vector{FGSymbol}([one(FGSymbol)])
|
|
|
|
@test isa(one(Groups.GWord{FGSymbol}), Groups.GWord{FGSymbol})
|
|
|
|
w = s*t*s^-1
|
|
|
|
@test isa(one(w), FGWord)
|
|
|
|
@test inv(s*t) == t^-1*s^-1
|
|
|
|
@test inv(w) == s*t^-1*s^-1
|
|
|
|
end
|
|
|
|
|
|
|
|
@testset "reductions" begin
|
|
|
|
@test one(FGWord) == one(s)*one(s)
|
|
|
|
w = GWord{FGSymbol}([s])
|
|
|
|
push!(w.symbols, (s^-1).symbols[1])
|
|
|
|
@test Groups.freegroup_reduce!(w) == one(FGWord)
|
|
|
|
o = (t*s)^3
|
|
|
|
@test o == t*s*t*s*t*s
|
|
|
|
p = (t*s)^-3
|
|
|
|
@test p == s^-1*t^-1*s^-1*t^-1*s^-1*t^-1
|
|
|
|
@test o*p == one(FGWord)
|
|
|
|
w = FGWord([o.symbols..., p.symbols...])
|
|
|
|
@test Groups.freegroup_reduce!(w).symbols ==Vector{FGSymbol}([])
|
|
|
|
end
|
|
|
|
@testset "arithmetic" begin
|
|
|
|
@test Groups.r_multiply!(FGWord(t),[s,t]; reduced=true) == t*s*t
|
|
|
|
@test Groups.r_multiply!(FGWord(t),[s,t]; reduced=false) == t*s*t
|
|
|
|
|
|
|
|
@test Groups.l_multiply!(FGWord(t),[s,t]; reduced=true) == t*s*t
|
|
|
|
@test Groups.l_multiply!(FGWord(t),[s,t]; reduced=false) == t*s*t
|
|
|
|
@test (t*s*t^-1)^10 == t*s^10*t^-1
|
|
|
|
@test (t*s*t^-1)^-10 == t*s^-10*t^-1
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|