Quellcodebibliothek Statistik Leitseite products/sources/formale Sprachen/GAP/pkg/repndecomp/lib/cohcfg/   (Algebra von RWTH Aachen Version 4.15.1©)  Datei vom 12.8.2025 mit Größe 1 kB image not shown  

Quelle  misc.gi   Sprache: unbekannt

 
# Replace and extend GRAPE's OrbitNumbers function, using native GAP functions
# G is a group
# Omega is a set upon which G acts (please make sure it is closed under action by G, as this will not be checked!)
OrbitsInfo@ := function (G, Omega)
    local orbits, mapping, representatives,
        i, j;
    if IsPosInt(Omega) then Omega := [1..Omega]; # backwards-compatibility with GRAPE's OrbitNumbers() syntax
    elif not IsHomogeneousList(Omega) then
        Error("OrbitsInfo@: malformed Omega");
    fi;
    
    orbits := OrbitsDomain(G, Omega); # this returns a list of the orbits; WARNING: undefined behavior when Omega is not closed!
    mapping := EmptyPlist(Length(Omega));
    for i in [1..Length(orbits)] do
        for j in orbits[i] do
            mapping[j] := i; # element j in Omega is in the i-th orbit; WARNING: mapping domain may be too big when Omega is not closed!
        od;
    od;
    MakeImmutable(mapping);

    representatives := List(orbits, x -> x[1]); # retrieves the first element of each orbit
    MakeImmutable(representatives);
    
    return rec(
        orbits := orbits, # a list of the orbits of G acting on Omega
        mapping := mapping, # a mapping from Omega to orbits, i.e. mapping[i] = j iff i in Omega is in orbit j
            orbitNumbers := ~.mapping, # backwards-compatibility with GRAPE's OrbitNumbers() syntax
        representatives := representatives # a list whose i-th entry is a representative element from the i-th orbit of Omega
    );
end;

[ Dauer der Verarbeitung: 0.26 Sekunden  (vorverarbeitet)  ]