Quellcodebibliothek Statistik Leitseite products/Sources/formale Sprachen/GAP/pkg/crisp/lib/   (Algebra von RWTH Aachen Version 4.15.1©)  Datei vom 16.1.2016 mit Größe 15 kB image not shown  

Quelle  socle.gi   Sprache: unbekannt

 
#############################################################################
##
##  socle.gi                           CRISP                 Burkhard Höfling
##
##  Copyright © 2001, 2002, 2005, 2015 Burkhard Höfling
##

#############################################################################
##
#M  PSocleComponentsOp(<G>, <p>) 
##
InstallMethod(PSocleComponentsOp, 
    "for finite group", true,
    [IsGroup and IsFinite, IsPosInt], 
    0,
    function( G, p )

        local P, O, ser, j, N, res;

        if Size(G) mod p <> 0 then
            return [];
        fi;

        P := PCore(G,p);

        if IsTrivial(P) then
            return [];
        fi;

        O := Omega(Center(P),p,1);

        ser := CompositionSeriesUnderAction(G, O);

        res := [ser[Length(ser)-1]];
        for j in [Length(ser)-2, Length(ser)-3..1] do
            N := ComplementsOfCentralSectionUnderActionNC(G, ser[j], ser[j+1], TrivialSubgroup(G), false);
            if N <> fail then
                Add(res, N);
            fi;
        od;
        return res;
    end);


#############################################################################
##
#M  PSocleComponentsOp(<G>, <p>) 
##
InstallMethod(PSocleComponentsOp, 
    "for finite group with SolubleSocleComponents", true,
    [IsGroup and IsFinite and HasSolubleSocleComponents,
        IsPosInt], 
    0,
    function( G, p ) 
        return Filtered(SolubleSocleComponents(G), L -> PrimePGroup(L) = p);
    end);


#############################################################################
##
#M  PSocleComponentsOp(<G>, <p>) 
##
CRISP_RedispatchOnCondition(PSocleComponentsOp,
    "redispatch if group is finite",
    true,
    [IsGroup, IsPosInt], 
    [IsFinite, ],
    0);
    
    
#############################################################################
##
#M  PSocleComponentsOp(<G>, <p>) 
##
InstallMethod(PSocleComponentsOp,
    "via IsomorphismPcGroup",
    true,
    [IsGroup and IsSolvableGroup and IsFinite, IsPosInt],
    0,
    function( grp, p)
        local hom;
        if CanEasilyComputePcgs(grp) then
            TryNextMethod();
        fi;
        hom := IsomorphismPcGroup(grp);
        return List(PSocleComponentsOp(ImagesSource(hom), p),
            L -> PreImagesSet(hom, L));
    end);
    
    
#############################################################################
##
#M  PSocleComponentsOp(<G>, <p>) 
##
InstallMethod(PSocleComponentsOp,
    "handled by nice monomorphism",
    true,
    [IsGroup and IsHandledByNiceMonomorphism and IsFinite, 
        IsPosInt],
    0,
    function( grp, p )
        local hom;
        hom := NiceMonomorphism(grp);
        return List(PSocleComponentsOp(NiceObject(grp), p),
            L -> PreImagesSet(hom, L));
    end);
    
    
#############################################################################
##
#M  PSocleSeriesOp(<G>, <p>)
##
InstallMethod(PSocleSeriesOp,
    "for pcgs computable group, compute from components", true,
    [IsGroup and CanEasilyComputePcgs and IsFinite, IsPosInt],
    0,
    function( G, p )

        local i, pcgs, pcgssoc, socdepths, L, x, ser, n, S;

        pcgs := ParentPcgs(Pcgs(G));

        pcgssoc := [];
        socdepths := [];
        ser := [TrivialSubgroup(G)];

        for L in PSocleComponents(G, p) do
            for x in Reversed(Pcgs(L)) do
                if not AddPcElementToPcSequence(pcgs, pcgssoc, socdepths, x) then
                    Error("Internal error in method for `PSocleOp' for pcgs computable group");
                fi;
            od;
            S := GroupOfPcgs(InducedPcgsByPcSequenceNC(pcgs, pcgssoc));
            Assert(1, IsElementaryAbelian(S));
            SetIsElementaryAbelian(S, true);
            Add(ser, S);
        od;
        return ser;
    end);


#############################################################################
##
#M  PSocleSeriesOp(<G>, <p>)
##
InstallMethod(PSocleSeriesOp,
    "for finite group, compute from components", true,
    [IsGroup and IsFinite, IsPosInt],
    0,
    function( G, p )

        local S, ser, L;
        
        S := TrivialSubgroup(G);
        ser := [S];

        for L in PSocleComponents(G, p) do
            S := ClosureGroup(S, L);
            Assert(1, IsElementaryAbelian(S));
            SetIsElementaryAbelian(S, true);
            Add(ser, S);
        od;
        return ser;
    end);


#############################################################################
##
#M  PSocleSeriesOp(<G>, <p>)
##
CRISP_RedispatchOnCondition(PSocleSeriesOp,
    "redispatch if group is finite",
    true,
    [IsGroup, IsPosInt], 
    [IsFinite, ],
    0);
    
    
#############################################################################
##
#M  PSocleSeriesOp(<G>, <p>)
##
InstallMethod(PSocleSeriesOp,
    "via IsomorphismPcGroup",
    true,
    [IsGroup and IsSolvableGroup and IsFinite, IsPosInt],
    0,
    function( grp, p)
        local hom;
        if CanEasilyComputePcgs(grp) then
            TryNextMethod();
        fi;
        hom := IsomorphismPcGroup(grp);
        return List(PSocleSeries(ImagesSource(hom), p),
            L -> PreImagesSet(hom, L));
    end);
    
    
#############################################################################
##
#M  PSocleSeriesOp(<G>, <p>)
##
InstallMethod(PSocleSeriesOp,
    "handled by nice monomorphism",
    true,
    [IsGroup and IsHandledByNiceMonomorphism and IsFinite, 
        IsPosInt],
    0,
    function( grp, p )
        local hom;
        hom := NiceMonomorphism(grp);
        return List(PSocleSeries(NiceObject(grp), p),
            L -> PreImagesSet(hom, L));
    end);
    
    
#############################################################################
##
#M  PSocleOp(<G>, <p>)
##
CRISP_RedispatchOnCondition(PSocleOp,
    "redispatch if group is finite",
    true,
    [IsGroup, IsPosInt], 
    [IsFinite, ], 0);
    

#############################################################################
##
#M  PSocleOp(<G>, <p>)
##
InstallMethod(PSocleOp,
    "last term of PSocleSeriesOp",
    true,
    [IsGroup and IsFinite,
        IsPosInt],
    0,
    function( grp, p )
        local ser;
        ser := PSocleSeries(grp, p);
        return ser[Length(ser)];
    end);


##############################################################################
##
#M  SolubleSocleComponents(<G>)
##
InstallMethod(SolubleSocleComponents,
    "concatenate PSocleComponents",
    true,
    [IsGroup and IsFinite],
    0,
    function(G)
        local p, res;
        res := [];
        for p in PrimeDivisors(Size(G)) do
            Append(res, PSocleComponents(G, p));
        od;
        return res;
    end);


##############################################################################
##
#M  SolubleSocleComponents(<G>)
##
InstallMethod(SolubleSocleComponents,
    "handled by nice monomorphism",
    true,
    [IsGroup and IsHandledByNiceMonomorphism and IsFinite],
    0,
    function( grp)
        local hom;
        hom := NiceMonomorphism(grp);
        return List(SolubleSocleComponents(NiceObject(grp)),
            L -> PreImagesSet(hom, L));
    end);
    
    
#############################################################################
##
#M  SolubleSocleComponents(<G>)
##
InstallMethod(SolubleSocleComponents,
    "via IsomorphismPcGroup",
    true,
    [IsGroup and IsSolvableGroup and IsFinite],
    0,
    function( grp)
        local hom;
        if CanEasilyComputePcgs(grp) then
            TryNextMethod();
        fi;
        hom := IsomorphismPcGroup(grp);
        return List(SolubleSocleComponents(ImagesSource(hom)),
            L -> PreImagesSet(hom, L));
    end);
    
    
#############################################################################
##
#M  SolubleSocleComponents(<G>)
##
CRISP_RedispatchOnCondition(SolubleSocleComponents,
    "redispatch if group is finite",
    true,
    [IsGroup], 
    [IsFinite], 0);
    

#############################################################################
##
#M  SocleComponents(<G>) 
##
InstallMethod(SocleComponents, 
    "for soluble group", true,
    [IsGroup and IsSolvableGroup and IsFinite], 0,
    SolubleSocleComponents);
    
    
#############################################################################
##
#M  SocleComponents(<G>) 
##
CRISP_RedispatchOnCondition(SocleComponents,
    "redispatch if group is finite or soluble",
    true,
    [IsGroup], 
    [IsFinite and IsSolvableGroup], 0);
    
    

#############################################################################
##
#M  SocleComponents(<G>) 
##
InstallMethod(SolubleSocleComponents,
    "via IsomorphismPcGroup",
    true,
    [IsGroup and IsSolvableGroup and IsFinite],
    0,
    function( grp)
        local hom;
        if CanEasilyComputePcgs(grp) then
            TryNextMethod();
        fi;
        hom := IsomorphismPcGroup(grp);
        return List(SocleComponents(ImagesSource(hom)),
            L -> PreImagesSet(hom, L));
    end);
    
    
#############################################################################
##
#M  SocleComponents(<G>) 
##
InstallMethod(SocleComponents,
    "handled by nice monomorphism",
    true,
    [IsGroup and IsHandledByNiceMonomorphism and IsFinite],
    0,
    function( grp)
        local hom;
        hom := NiceMonomorphism(grp);
        return List(SocleComponents(NiceObject(grp)),
            L -> PreImagesSet(hom, L));
    end);
    
    
#############################################################################
##
#M  SolubleSocle(<G>)
##
InstallMethod(SolubleSocle,
    "for soluble group, product of socle components", true,
    [IsGroup and CanEasilyComputePcgs and IsFinite], 
    0,
    function( G )

        local i, pcgs, pcgssoc, socdepths, L, x, ser, n, S;
        
        if IsTrivial(G) then
            return G;
        fi;
        
        pcgs := ParentPcgs(Pcgs(G));
        
        pcgssoc := [];
        socdepths := [];
        
        for L in SocleComponents(G) do
            for x in Reversed(Pcgs(L)) do
                if not AddPcElementToPcSequence(pcgs, pcgssoc, socdepths, x) then
                    Error("Internal error in method for `Socle' for soluble groups");
                fi;
            od;
        od;
        pcgssoc := InducedPcgsByPcSequenceNC(pcgs, pcgssoc);
        S := GroupOfPcgs(pcgssoc);
        Assert(1, IsAbelian(S));
        SetIsAbelian(S, true);
        return S;
    end);


#############################################################################
##
#M  SolubleSocle(<G>)
##
InstallMethod(SolubleSocle,
    "for finite group, product of socle components", true,
    [IsGroup and IsFinite], 
    0,
    function( G )

        local S, L;
        
        S := TrivialSubgroup(G);
        for L in SolubleSocleComponents(G) do
            S := ClosureGroup(S, L);
        od;
        Assert(1, IsAbelian(S));
        SetIsAbelian(S, true);
        return S;
    end);



#############################################################################
##
#M  SolubleSocle(<G>)
##
InstallMethod(SolubleSocle,
    "handled by nice monomorphism",
    true,
    [IsGroup and IsHandledByNiceMonomorphism and IsFinite],
    0,
    function( grp )
        return PreImagesSet(NiceMonomorphism(grp), SolubleSocle(NiceObject(grp)));
    end);
    
    
#############################################################################
##
#M  SolubleSocle(<G>)
##
InstallMethod(SolubleSocle,
    "via IsomorphismPcGroup",
    true,
    [IsGroup and IsSolvableGroup and IsFinite],
    0,
    function( grp )
        local hom;
        if CanEasilyComputePcgs(grp) then
            TryNextMethod();
        fi;
        hom := IsomorphismPcGroup(grp);
        return PreImagesSet(hom, SolubleSocle(ImagesSource(hom)));
    end);
    
    
#############################################################################
##
#M  SolubleSocle(<G>)
##
CRISP_RedispatchOnCondition(SolubleSocle,
    "redispatch if group is finite",
    true,
    [IsGroup], 
    [IsFinite], 0);
    
    
#############################################################################
##
#M  Socle(<G>) 
##
InstallMethod(Socle, "for finite soluble group, via SolubleSocle", true,
    [IsGroup and IsFinite and IsSolvableGroup],
    0,
    SolubleSocle);
    
    
#############################################################################
##
#M  Socle(<G>) 
##
CRISP_RedispatchOnCondition(Socle,
    "redispatch if group is finite or soluble",
    true,
    [IsGroup],
    [IsFinite and IsSolvableGroup],
    RankFilter(IsGroup and IsFinite and IsSolvableGroup)-1);
    
    
#############################################################################
##
#M  MinimalNormalPSubgroupsOp(<G>, <p>)
##
InstallMethod(MinimalNormalPSubgroupsOp, 
    "for finite group", true,
    [IsGroup and IsFinite, IsPosInt], 
    0,
    function( G, p )

        local P, O, ser, j, res, N;

        if Size(G) mod p <> 0 then
            return [];
        fi;

        P := PCore(G,p);

        if IsTrivial(P) then
            return [];
        fi;

        O := Omega(Center(P),p,1);

        ser := CompositionSeriesUnderAction(G, O);

        res := [ser[Length(ser)-1]];
        for j in [Length(ser)-2, Length(ser)-3..1] do
            Append(res, ComplementsOfCentralSectionUnderActionNC(G, ser[j], ser[j+1], TrivialSubgroup(G), true));
        od;
        for N in res do
            Assert(1, IsElementaryAbelian(N));
            SetIsElementaryAbelian(N, true);
        od;
        return res;
    end);


#############################################################################
##
#M  MinimalNormalPSubgroupsOp(<G>)
##
InstallMethod(MinimalNormalPSubgroupsOp,
    "handled by nice monomorphism",
    true,
    [IsGroup and IsHandledByNiceMonomorphism and IsFinite, IsPosInt],
    0,
    function( grp, p )
        local hom;
        hom := NiceMonomorphism(grp);
        return List(MinimalNormalPSubgroups(NiceObject(grp), p),
         N -> PreImagesSet(hom, N));
    end);
    
    
#############################################################################
##
#M  MinimalNormalPSubgroupsOp(<G>)
##
InstallMethod(MinimalNormalPSubgroupsOp,
    "handled by IsomorphismPcGroup",
    true,
    [IsGroup and IsSolvableGroup and IsFinite, IsPosInt],
    0,
    function( grp, p )
        local hom;
        if CanEasilyComputePcgs(grp) then
            TryNextMethod();
        fi;
        hom := IsomorphismPcGroup(grp);
        return List(MinimalNormalPSubgroups(ImagesSource(hom), p),
         N -> PreImagesSet(hom, N));
    end);
    
    
############################################################################
##
#M  AbelianMinimalNormalSubgroups(<G>) 
##

InstallMethod(AbelianMinimalNormalSubgroups, 
 "concatenate MinimalNormalPSubgroups",
    true, [IsGroup and IsFinite], 0,
 function(G)

    local p, norms;

    norms := [];

    for p in PrimeDivisors(Size(G)) do
        Append(norms, MinimalNormalPSubgroups(G, p));
    od;

    return norms;
end);


#############################################################################
##
#M  AbelianMinimalNormalSubgroups(<G>) 
##
CRISP_RedispatchOnCondition(AbelianMinimalNormalSubgroups,
    "redispatch if group is finite",
    true,
    [IsGroup], 
    [IsFinite], 0);


#############################################################################
##
#M  MinimalNormalSubgroups(<G>) 
##
InstallMethod(MinimalNormalSubgroups, 
 "for soluble groups: use AbelianMinimalNormalSubgroups",
 true, [IsGroup and IsFinite and IsSolvableGroup], 0,
 AbelianMinimalNormalSubgroups);


#############################################################################
##
#M  MinimalNormalSubgroups(<G>) 
##
CRISP_RedispatchOnCondition(MinimalNormalSubgroups,
    "redispatch if group is finite or soluble",
 true,
    [IsGroup],
    [IsFinite and IsSolvableGroup],
    RankFilter(IsGroup and IsFinite and IsSolvableGroup)-1);


############################################################################
##
#E
##

[ Dauer der Verarbeitung: 0.43 Sekunden  (vorverarbeitet)  ]