|
gap> # some random group
gap> G := DirectProduct(SymmetricGroup(3), SymmetricGroup(3));;
gap> irreps := IrreducibleRepresentations(G);;
gap> # rho is irreps2 oplus irreps2 oplus irreps2 (rho has degree 3)
gap> rho := DirectSumOfRepresentations([irreps[2], irreps[2], irreps[2]]);;
gap> # so the canonical summand is just the whole space
gap> summand := Cyclotomics^3;;
gap> # and each axis is an irreducible G-invariant space
gap> DecomposeCanonicalSummand@RepnDecomp(rho, irreps[2], summand); # should get 3 bits, 1 for each irrep
[ rec( basis := [ [ 1, 0, 0 ] ] ),
rec( basis := [ [ 0, 1, 0 ] ] ),
rec( basis := [ [ 0, 0, 1 ] ] ) ]
gap> # should also work if we use small-degree kronecker trick (same up to scaling)
gap> DecomposeCanonicalSummand@RepnDecomp(rho, irreps[2], summand : use_kronecker);
[ rec( basis := [ [ 36, 0, 0 ] ] ),
rec( basis := [ [ 0, 36, 0 ] ] ),
rec( basis := [ [ 0, 0, 36 ] ] ) ]
[ Dauer der Verarbeitung: 0.20 Sekunden
(vorverarbeitet)
]
|