Underlying the method installation for AutomorphismGroup
is the function AutomorphismGroupPGroup. This function is
intended for expert users who wish to influence the steps of 
the algorithm.  Note also that AutomorphismGroup will always
choose default values.
AutomorphismGroupPGroup( G [,flag] ) F
The input is a finite p-group as above and an optional flag 
which can be true or false. Here the filters for G need not be 
set, but they should be true for G. The possible values for flag
are considered later in Chapter Influencing the algorithm. If 
flag is not supplied, the algorithm proceeds similarly to the 
method installed for AutomorphismGroup, but it produces slightly 
more detailed output.  The output of the function is a record 
which contains the following fields:
glAutos agAutos
            generate the automorphism group;
glOrder agOrders gives
            the size of the automorphism group;
agAutos 
agOrder agAutos;
one     
group   
size    
We do not return an automorphism group in the standard form 
because we wish to distinguish between agAutos and glAutos; 
the latter act non-trivially on the Frattini quotient of G. This
hybrid-group description of the automorphism group permits more 
efficient computations with it. The following function converts
the output of AutomorphismGroupPGroup to the output of 
AutomorphismGroup.
ConvertHybridAutGroup( A ) F
gap> LoadPackage("autpgrp", false);
true
gap> H := SmallGroup (729, 34);
<pc group of size 729 with 6 generators>
gap> A := AutomorphismGroupPGroup(H);
rec( glAutos := [  ], 
     glOrder := 1, 
     agAutos := [ Pcgs([ f1, f2, f3, f4, f5, f6 ]) 
                    -> [ f1^2, f2, f3^2*f4, f4, f5^2*f6, f6 ], 
                  Pcgs([ f1, f2, f3, f4, f5, f6 ]) 
                    -> [ f2^2, f1, f3*f5^2, f5^2, f4*f6^2, f6^2 ], 
                  Pcgs([ f1, f2, f3, f4, f5, f6 ]) 
                    -> [ f1^2, f2^2, f3*f4^2*f5^2*f6, f4^2*f6, f5^2*f6, f6 ], 
                  Pcgs([ f1, f2, f3, f4, f5, f6 ]) 
                    -> [ f1*f3, f2, f3*f5^2, f4*f6^2, f5, f6 ], 
                  Pcgs([ f1, f2, f3, f4, f5, f6 ])
                    -> [ f1, f2*f3, f3*f4, f4, f5*f6, f6 ], 
                  Pcgs([ f1, f2, f3, f4, f5, f6 ]) 
                    -> [ f1*f4, f2, f3*f6^2, f4, f5, f6 ], 
                  Pcgs([ f1, f2, f3, f4, f5, f6 ]) 
                    -> [ f1, f2*f4, f3, f4, f5, f6 ], 
                  Pcgs([ f1, f2, f3, f4, f5, f6 ]) 
                    -> [ f1*f5, f2, f3, f4, f5, f6 ], 
                  Pcgs([ f1, f2, f3, f4, f5, f6 ]) 
                    -> [ f1, f2*f5, f3*f6, f4, f5, f6 ], 
                  Pcgs([ f1, f2, f3, f4, f5, f6 ]) 
                    -> [ f1*f6, f2, f3, f4, f5, f6 ], 
                  Pcgs([ f1, f2, f3, f4, f5, f6 ]) 
                    -> [ f1, f2*f6, f3, f4, f5, f6 ] ], 
     agOrder := [ 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3 ], 
     one     := IdentityMapping( <pc group of size 729 with 6 generators> ), 
     group   := <pc group of size 729 with 6 generators>, 
     size    := 52488 )
gap> ConvertHybridAutGroup( A );
<group of size 52488 with 11 generators>
Let A be the automorphism group of a p-group G as computed by 
AutomorphismGroupPGroup. Then the following function can compute 
a pc group isomorphic to the solvable part of A stored in the record 
component A.agGroup. This solvable part forms a subgroup of the
automorphism group which  contains at least the automorphisms centralizing
the Frattini factor of G. The pc group facilitates various further
computations with A.
PcGroupAutPGroup( A ) F
computes a pc presentation for the solvable part of the automorphism
group A defined by A.agGroup. A is the output of the function
AutomorphismGroupPGroup.
gap> H := SmallGroup (729, 34);; gap> A := AutomorphismGroupPGroup(H);; gap> B := PcGroupAutPGroup( A ); <pc group of size 52488 with 11 generators> gap> I := InnerAutGroupPGroup( B ); Group([ f5, f4^2*f8, f6^2*f9^2, f11^2, f10^2, <identity> of ... ])
[Up] [Previous] [Next] [Index]
AutPGrp manual