[Up] [Previous] [Index]

4 Cohomology for pcp-groups

Sections

  1. Cohomology records
  2. Cohomology groups
  3. Extended 1-cohomology
  4. Extensions and Complements

The share package polycyclic provides methods to compute the first and second cohomology group for a pcp-group U and a finite dimensional ZU or FU module A where F is a finite field. The algorithm for determining the first cohomology group are outlined in Eic00.

4.1 Cohomology records

First we need some methods to create a module for a pcp-group U. This module can either be defined externally via a matrix operation of U or internally using an elementary or free abelian normal subfactor.

  • CRRecordByMats( U, mats )

    creates an external module. The input mats is a list of integer or finite field matrices. This list corresponds to Pcp(U) and defines the matrix action of the elements of Pcp(U).

  • CRRecordBySubgroup( U, A )
  • CRRecordByPcp( U, pcp )

    creates an internal module. The input A or pcp defines an elementary or free abelian normal subgroup or subfactor of U.

    The returned cohomology record C contains the following entries:

    factor
    a pcp of the acting group. If the module is external, then this is Pcp(U). If the module is internal, then this is Pcp(U, A) or Pcp(U, GroupOfPcp(pcp)).

    mats, invs and one
    the matrix action of factor with acting matrices, their inverses and the identity matrix.

    dim and char
    the dimension and characteristic of the matrices.

    relators and enumrels
    the relators of factor as words and an enumeration list for them.

    central
    is true, if the matrices mats are all trivial. This is used locally for efficiency reasons.

    And additionally, if C defines an internal module, then it contains:

    group
    the original group U.

    normal
    this is either Pcp(A) or the input pcp.

    extension
    information on the extension of A by U/A.

    4.2 Cohomology groups

    Let U be a pcp-group and A a free or elementary abelian pcp-group and a U-module. By Zi(U, A) be denote the group of i-th cocycles and by Bi(U, A) the i-th coboundaries. The factor Zi(U,A) / Bi(U,A) is the i-th cohomology group. Since A is elementary or free abelian, the groups Zi(U, A) and Bi(U, A) are elementary or free abelian groups as well.

    The polycyclic share package provides methods to compute first and second cohomology group for a polycyclic group U. We write all involved groups additively and we use an explicit description by bases for them. Let C be the cohomology record corresponding to U and A.

    Let f1, ¼, fn be the elements in the entry factor of the cohomology record C. Then we use the following embedding of the first cocycle group to describe 1-cocycles and 1-coboundaries: Z1(U, A) \ra An : d\ms (d(f1), ¼, d(fn))

    For the second cohomology group we recall that each element of Z2(U, A) defines an extension H of A by U. Thus there is a pc-presentation of H extending the pc-presentation of U given by the record C. The extended presentation is defined by tails in A; that is, each relator in the record entry relators is extended by an element of A. The concatenation of these tails yields a vector in Al where l is the length of the record entry relators of C. We use these tail vectors to describe Z2(U, A) and B2(U, A). Note that this description is dependent on the chosen presentation in C. However, the factor Z2(U, A)/ B2(U, A) is independent of the chosen presentation.

    The following functions are available to compute explicitly the first and second cohomology group as described above.

  • OneCoboundariesCR( C )

  • OneCocyclesCR( C )

  • TwoCoboundariesCR( C )

  • TwoCocyclesCR( C )

  • OneCohomologyCR( C )

  • TwoCohomologyCR( C )

    The first 4 functions return bases of the corresponding group. The last 2 functions need to describe a factor of additive abelian groups. They return the following descriptions for these factors.

    gcc
    the basis of the cocycles of C.

    gcb
    the basis of the coboundaries of C.

    factor
    a description of the factor of cocycles by coboundaries. Usually, it would be most convenient to use additive mappings here. However, these are not available in case that A is free abelian and thus we use a description of this additive map as record. This record contains

    noindent advancehsize-2cm beginitems

    gens
    a base for the image.

    rels
    relative orders for the image.

    imgs
    the images for the elements in gcc.

    prei
    preimages for the elements in gens.

    denom
    the kernel of the map; that is, another basis for gcb.

    enditems

    4.3 Extended 1-cohomology

    In some cases more information on the first cohomology group is of interest. In particular, if we have an internal module given and we want to compute the complements using the first cohomology group, then we need additional information. This extended version of first cohomology is obtained by the following functions.

  • OneCoboundariesEX( C )

    returns a record consisting of the entries

    basis
    a basis for B1(U, A) £ An.

    transf
    There is a derivation mapping from A to B^1(U,A). This mapping is described here as transformation from A to basis.

    fixpts
    the fixed points of A. This is also the kernel of the derivation mapping.

  • OneCocyclesEX( C )

    returns a record consisting of the entries

    basis
    a basis for Z1(U, A) £ An.

    transl
    a special solution. This is only of interest in case that C is an internal module and in this case it gives the translation vector in An used to obtain complements corresponding to the elements in basis. If C is not an internal module, then this vector is always the zero vector.

  • OneCohomologyEX( C )

    returns the combined information on the first cohomology group.

    4.4 Extensions and Complements

    The natural applications of first and second cohomology group is the determination of extensions and complements. Let C be a cohomology record.

  • ComplementCR( C, c )

    returns the complement corresponding to the 1-cocycle c. In the case that C is an external module, we construct the split extension of U with A first and then determine the complement. In the case that C is an internal module, the vector c must be an element of the affine space corresponding to the complements as described by OneCocyclesEX.

  • ComplementsCR( C )

    returns all complements using the correspondence to Z1(U,A). Further, this function returns fail, if Z1(U,A) is infinite.

  • ComplementClassesCR( C )

    returns complement classes using the correspondence to H1(U,A). Further, this function returns fail, if H1(U,A) is infinite.

  • ComplementClassesEfaPcps( U, N, pcps )

    Let N be a normal subgroup of U. This function returns the complement classes to N in U. The classes are computed by iteration over the U-invariant efa series of N described by pcps. If at some stage in this iteration infinitely many complements are discovered, then the function returns fail. (Even though there might be only finitely many conjugacy classes of complements to N in U.)

  • ComplementClasses( [V,] U, N )

    Let N and U be normal subgroups of V with N £ U £ V. This function attempts to compute the V-conjugacy classes of complements to N in U. The algorithm proceeds by iteration over a V-invariant efa series of N. If at some stage in this iteration infinitely many complements are discovered, then the algorithm returns fail.

  • ExtensionCR( C, c )

    returns the extension corresponding to the 2-cocycle c.

  • ExtensionsCR( C )

    returns all extensions using the correspondence to Z2(U,A). Further, this function returns fail, if Z2(U,A) is infinite.

  • ExtensionClassesCR( C )

    returns extension classes using the correspondence to H2(U,A). Further, this function returns fail, if H2(U,A) is infinite.

  • SplitExtensionPcpGroup( U, mats )

    returns the split extension of U by the U-module described by mats.

    [Up] [Previous] [Index]

    Polycyclic manual
    May 2002