1
0
mirror of https://github.com/kalmarek/PropertyT.jl.git synced 2025-01-12 06:32:34 +01:00

allow arbitrary actions in orbit_decomposition (defaults to ^)

This commit is contained in:
kalmarek 2020-10-10 12:55:02 +02:00
parent c467a52f83
commit 6ab18d0283
No known key found for this signature in database
GPG Key ID: 8BF1A3855328FC15
2 changed files with 37 additions and 26 deletions

View File

@ -58,9 +58,14 @@ function orthSVD(M::AbstractMatrix{T}) where {T<:AbstractFloat}
return fact.U[:,1:M_rank] return fact.U[:,1:M_rank]
end end
orbit_decomposition(G::Group, E::AbstractVector, rdict=GroupRings.reverse_dict(E)) = orbit_decomposition(collect(G), E, rdict) orbit_decomposition(
G::Group,
E::AbstractVector,
rdict = GroupRings.reverse_dict(E);
op = ^,
) = orbit_decomposition(collect(G), E, rdict; op=op)
function orbit_decomposition(elts::AbstractVector{<:GroupElem}, E::AbstractVector, rdict=GroupRings.reverse_dict(E)) function orbit_decomposition(elts::AbstractVector{<:GroupElem}, E::AbstractVector, rdict=GroupRings.reverse_dict(E); op=^)
tovisit = trues(size(E)); tovisit = trues(size(E));
orbits = Vector{Vector{Int}}() orbits = Vector{Vector{Int}}()
@ -71,7 +76,7 @@ function orbit_decomposition(elts::AbstractVector{<:GroupElem}, E::AbstractVecto
if tovisit[i] if tovisit[i]
g = E[i] g = E[i]
Threads.@threads for j in eachindex(elts) Threads.@threads for j in eachindex(elts)
orbit[j] = rdict[elts[j](g)] orbit[j] = rdict[op(g, elts[j])]
end end
tovisit[orbit] .= false tovisit[orbit] .= false
push!(orbits, unique(orbit)) push!(orbits, unique(orbit))
@ -139,7 +144,7 @@ end
function perm_repr(g::GroupElem, E::Vector, E_dict) function perm_repr(g::GroupElem, E::Vector, E_dict)
p = Vector{Int}(undef, length(E)) p = Vector{Int}(undef, length(E))
for (i,elt) in enumerate(E) for (i,elt) in enumerate(E)
p[i] = E_dict[g(elt)] p[i] = E_dict[elt^g]
end end
return p return p
end end
@ -178,29 +183,33 @@ end
# #
############################################################################### ###############################################################################
function (g::GroupRingElem)(y::GroupRingElem) function Base.:^(y::GroupRingElem, g::GroupRingElem, op = ^)
res = parent(y)() res = parent(y)()
for elt in GroupRings.supp(g) for elt in GroupRings.supp(g)
res += g[elt]*elt(y) res += g[elt] * ^(y, elt, op)
end end
return res return res
end end
function (g::GroupElem)(y::GroupRingElem) function Base.:^(y::GroupRingElem, g::GroupElem, op = ^)
RG = parent(y) RG = parent(y)
result = zero(RG, eltype(y.coeffs)) result = zero(RG, eltype(y.coeffs))
for (idx, c) in enumerate(y.coeffs) for (idx, c) in enumerate(y.coeffs)
if !iszero(c) if !iszero(c)
result[g(RG.basis[idx])] = c result[op(RG.basis[idx], g)] = c
end end
end end
return result return result
end end
function (g::GroupElem)(y::GroupRingElem{T, <:SparseVector}) where T function Base.:^(
y::GroupRingElem{T,<:SparseVector},
g::GroupElem,
op = ^,
) where {T}
RG = parent(y) RG = parent(y)
index = [RG.basis_dict[g(RG.basis[idx])] for idx in y.coeffs.nzind] index = [RG.basis_dict[op(RG.basis[idx], g)] for idx in y.coeffs.nzind]
result = GroupRingElem(sparsevec(index, y.coeffs.nzval, y.coeffs.n), RG) result = GroupRingElem(sparsevec(index, y.coeffs.nzval, y.coeffs.n), RG)
@ -213,18 +222,19 @@ end
# #
############################################################################### ###############################################################################
function (p::Generic.Perm)(A::MatAlgElem) function Base.:^(A::MatAlgElem, p::Generic.Perm)
length(p.d) == size(A, 1) == size(A,2) || throw("Can't act via $p on matrix of size $(size(A))") length(p.d) == size(A, 1) == size(A, 2) ||
throw("Can't act via $p on matrix of size $(size(A))")
result = similar(A) result = similar(A)
@inbounds for i in 1:size(A, 1) @inbounds for i = 1:size(A, 1)
for j in 1:size(A, 2) for j = 1:size(A, 2)
result[p[i], p[j]] = A[i, j] # action by permuting rows and colums/conjugation result[p[i], p[j]] = A[i, j] # action by permuting rows and colums/conjugation
end end
end end
return result return result
end end
function (g::WreathProductElem{N})(A::MatAlgElem) where N function Base.:^(A::MatAlgElem, g::WreathProductElem{N}) where {N}
# @assert N == size(A,1) == size(A,2) # @assert N == size(A,1) == size(A,2)
flips = ntuple(i -> (g.n[i].d[1] == 1 && g.n[i].d[2] == 2 ? 1 : -1), N) flips = ntuple(i -> (g.n[i].d[1] == 1 && g.n[i].d[2] == 2 ? 1 : -1), N)
result = similar(A) result = similar(A)
@ -250,7 +260,7 @@ end
# #
############################################################################### ###############################################################################
function (g::GroupElem)(a::Automorphism) function Base.:^(a::Automorphism, g::GroupElem)
Ag = parent(a)(g) Ag = parent(a)(g)
Ag_inv = inv(Ag) Ag_inv = inv(Ag)
res = append!(Ag, a, Ag_inv) res = append!(Ag, a, Ag_inv)
@ -261,10 +271,11 @@ end
function (A::AutGroup)(g::WreathProductElem) function (A::AutGroup)(g::WreathProductElem)
isa(A.objectGroup, FreeGroup) || throw("Not an Aut(Fₙ)") isa(A.objectGroup, FreeGroup) || throw("Not an Aut(Fₙ)")
parent(g).P.n == length(A.objectGroup.gens) || throw("No natural embedding of $(parent(g)) into $A") parent(g).P.n == length(A.objectGroup.gens) ||
throw("No natural embedding of $(parent(g)) into $A")
elt = one(A) elt = one(A)
Id = one(parent(g.n.elts[1])) Id = one(parent(g.n.elts[1]))
for i in 1:length(g.p.d) for i = 1:length(g.p.d)
if g.n.elts[i] != Id if g.n.elts[i] != Id
push!(elt, Groups.flip(i)) push!(elt, Groups.flip(i))
end end

View File

@ -19,7 +19,7 @@ function Sq(RG::GroupRing, N::Integer)
sq = RG() sq = RG()
for σ in Alt_N for σ in Alt_N
GroupRings.addeq!(sq, *(σ(Δ₂), σ(Δ₂), false)) GroupRings.addeq!(sq, *(Δ₂^σ, Δ₂^σ, false))
end end
return sq÷factorial(N-2) return sq÷factorial(N-2)
end end
@ -30,7 +30,7 @@ function Adj(RG::GroupRing, N::Integer)
Δ₂ = length(S₂)*one(RG, ) - RG(S₂, ); Δ₂ = length(S₂)*one(RG, ) - RG(S₂, );
Alt_N = [g for g in SymmetricGroup(N) if parity(g) == 0] Alt_N = [g for g in SymmetricGroup(N) if parity(g) == 0]
Δ₂s = Dict(σ=>σ(Δ₂) for σ in Alt_N) Δ₂s = Dict(σ=>Δ₂^σ for σ in Alt_N)
adj = RG() adj = RG()
for σ in Alt_N for σ in Alt_N
@ -52,7 +52,7 @@ function Op(RG::GroupRing, N::Integer)
Δ₂ = length(S₂)*one(RG, ) - RG(S₂, ); Δ₂ = length(S₂)*one(RG, ) - RG(S₂, );
Alt_N = [g for g in SymmetricGroup(N) if parity(g) == 0] Alt_N = [g for g in SymmetricGroup(N) if parity(g) == 0]
Δ₂s = Dict(σ=>σ(Δ₂) for σ in Alt_N) Δ₂s = Dict(σ=>Δ₂^σ for σ in Alt_N)
op = RG() op = RG()
for σ in Alt_N for σ in Alt_N