Skip to content

Latest commit

 

History

History
42 lines (25 loc) · 2.74 KB

README.md

File metadata and controls

42 lines (25 loc) · 2.74 KB

A Formalisation of the Nielsen-Schreier Theorem in Homotopy Type Theory in Agda

The Nielsen-Schreier theorem states that subgroups of free groups are also free groups. This is a formalisation of the special case of finite index subgroups in homotopy type theory.

Formalisation of the Theorem

The main theorem and the lemmas it uses are all in the directory main/, using a forked version of the HoTT-Agda library.

Type Checking

Follow these steps to check the proof in Agda:

  1. Install a recent version of the Agda proof assistant. This method has been tested with versions 2.6.1 and 2.6.1.1.

  2. Download the forked version of the HoTT-Agda library from https://github.com/awswan/HoTT-Agda/tree/agda-2.6.1-compatible to a directory of your choice. If you have git installed, you can also use the command git clone -b agda-2.6.1-compatible [email protected]:awswan/HoTT-Agda.git.

  3. Add the location of the file hott-core.agda-lib to your Agda library file.

  4. Change to the directory main/ of this repository and run agda NielsenSchreier.agda to type check the theorem.

You can alternatively use a non-forked version of the HoTT-Agda library. Note however that this is incompatible with the most recent versions of Agda. To do this you will need to delete the option --overlapping-instances from the header of the files Groups/Definition.agda, Util/Misc.agda and NielsenSchreier.agda.

This has been tested and type checks successfully with the following setup:

Directory Layout

The files are arrange as follows:

  • main/NielsenSchreier.agda Contains proof of the main theorem
  • main/Coequalizers/ Definition of coequalizers and some useful lemmas
  • main/Graphs/ Definition of graphs, trees and connected graphs, construction of spanning trees for graphs with finitely many vertices
  • main/Groups/ Type theoretic definition of group and free group
  • main/Util/ Some general miscellaneous lemmas that I couldn't find in the HoTT-Agda library

Demonstration of Cubical Mode

Some of the lemmas on coequalizers have shorter proofs using Agda cubical mode. The file cubical/Coequalizers.agda has been added to demonstrate this. Since this file uses cubical mode, it only works on the most recent versions of Agda. It has been tested and type checks successfully on the following setup (but likely will continue to work on more recent versions):