Skip to content

Latest commit

 

History

History
85 lines (56 loc) · 7.3 KB

File metadata and controls

85 lines (56 loc) · 7.3 KB

VMH-ImaginaryQuadraticNumberFields

Magma and GAP methods for working with arithmetic groups over imaginary quadratic number fields. These methods are described in the following articles:

The implementation was primarily done by Oliver Braun and Sebastian Schönnenbeck during their time as doctoral students at RWTH Aachen University funded by the DFG Research Training Group "Experimental and constructive algebra".

Some results of computations performed using these algorithms are already available in our database. When (not if) you find a bug, feel free to open an issue or try to fix it yourself (good luck reading our code) and open a pull request. For the time being this software is offered as is.

Overview

The algorithms we implemented deal with groups of the form $\operatorname{GL}_n(\mathbb{Z}_K)$ for $n=2,3$ and $K$ an imaginary number field. The following algorithms are available:

  • Computing a presentation (i.e. generators and defining relations).
  • Solving constructive membership problems (i.e. writing a given element in these generators).
  • Computing a contractible $G$-complex which can be used for homology computations with the GAP-package HAP.

Most of these algorithms are also available for finite index subgroups of the base group (as long as we know the index and how to check for membership in this group).

Usage

Overall, the usability of the algorithms is not great and a lot of the general design of the Magma-package is pretty terrible. However, for reasons of me no longer working in academia and generally not wanting to do the refactoring it is going to stay this way for the foresesable future. If you are willing to overlook these weaknesses, performing computations with our packages works as follows:

General Setup

  1. Choose the dimension $n$ (let's say $2$ since only $2$ and $3$ are actually feasible) and the negative integer $d$ (let's say $-10$) whose square-root defines $K$. We will need to edit the file BasicData.m to make this known to Magma. There are three values that need to be set in this file. However, for the time being we will ignore the Steinitz argument; setting it to $1$ simply means we want to work with $\operatorname{GL}_n(\mathbb{Z}_K)$ instead of certain other arithmetic subgroups of $\operatorname{GL}_n(K)$. Edit the file BasicData.m so that it reads:

     n:=2; d:=-10; steinitz:=1;
    
  2. Open Magma and initialize the basic setup by calling:

     AttachSpec("path/to/files/VMH-spec");
     V := VoronoiAlgorithm()
    

Computing a presentation

If we already have the basic setup from above, computing a presentation works as follows:

    G,g := Presentation(V)

Now G is a finitely presented group and g a homomorphism from G to the matrix group we are interested in. There are a couple of keyword arguments to this command:

  • simplify (default: true) specifies whether Magma should try to simplify the presentation before returning it.
  • projective (default: false) specifies whether you want to compute the quotient modulo -1 instead of the matrix group
  • SL (default: false) specifies if you want to compute a presentation of the special linear group instead of the general linear group.
  • CheckMembership (default: 0). Here you can provide a function checking an element of the full matrix group for membership in a (finite index) subgroup. If you do a presentation of this subgroup is computed instead of a presentation for the full group.

Solving constructive membership problems

We suppose we already have the presentation from the last step (if not it is actually computed when you first try to solve an constructive membership problem). Given an element $M \in \operatorname{GL}_n(\mathbb{Z}_K)$ we now want to find $m \in G$ such that $g(m) = M$. To do this call:

    m := SolveWordProblem(M, V)

Constructing a contractible G-complex

This workflow is a little messier and requires us to write things to a text-file which will later be used by GAP. We again assume that we already have the general setup ready.

  1. If we want to work with the full group, i.e. $\operatorname{GL}_n(\mathbb{Z}_K)$ simply call:

     ComputeComplexGL("path/to/store/filename", V)
    
  2. If we want to work with a finite index subgroup. We need a function checking for membership in this subgroup. For example if we have an ideal I and want the subgroup of matrices of determinant 1 whose lower left entry is in I we could define:

     CheckMembership := func<x| IsInSL(x) and x[2][1] in I>;
    
  3. Moreover we need the index of this subgroup in the full group (this is usually known to us) and a system of right-coset-representatives of the subgroup in the full group. You can either choose to provide your own favorite system of representatives or call the following command (note that this will run forever if the index you provide is larger than the actual index):

     Reps:=SystemOfRepresentativesFiniteIndex(V`MultFreeList,CheckMembership,index);
    
  4. Now constructing the file can be done by calling:

     ComputeComplexLowIndexSubgroup("path/to/store/filename", Reps, CheckMembership , V);
    

Now we switch over to GAP.

  1. To get the necessary functionalities call (ignore all warnings, I tried to get rid of them at some point but just could not be bothered):

     LoadPackage("HAP");
     Read("path/to/gapstuff/ReadWellRoundedComplex.gi");
    
  2. To get the contractible $G$-complex (non-free $G$-resolution) up to dimension 'length' (can be arbitrarily high without actually hurting performance) we constructed in Magma call:

     R := ResolutionFromWellRoundedComplex(file, length);
    
  3. This gives you a non-free $G$-resolution in HAP which you can work with in the usual way. For instance you could compute a free resolution (of the integers) by calling

     F := FreeGResolution(R, length);
    
  4. We provide two more GAP-functionalities. In the file 'QuotientComplex.gi' we define a function QuotientComplex which takes in a contractible $G$-complex and a central subgroup of $G$ acting trivially on the complex and outputs a contractible complex for the quotient group. Moreover, the file 'WriteComplex.gi' defines a function WriteComplex taking in a contractible $G$-complex and a filename and stores the contractible $G$-complex in HAP-readable format in the file (eliminating the need to use our GAP-functionalities when sharing complexes with other people).

Additional comments

  1. Why the hell can I not use Latex in the ReadMe? Finally!
  2. License: No clue. If you use these algorithms for your research please cite the corresponding papers. If you use these algorithms for commercial purposes please let me know, I will be mightily impressed that you found a real world use-case...
  3. In case you were wondering: VMH stands for Voronoi, Minimal Classes, and Homology.