Skip to content

harp-project/AML-Formalization

Repository files navigation

AML-Formalization

In this project, we attempt to fully implement the "Applicative Matching Logic" framework in Coq, with example instances.

Documentation

For developers

Build

The matching logic library (in the directory matching-logic/) depends on:

The easiest way to build the library is using the Nix package manager, using the Nix Flakes feature.

Build using Nix Flakes

If you want to work on the matching logic library:

  1. Enter a development environment for the matching logic library:
$ nix develop '.#coq-matching-logic'
  1. Inside the nix develop shell, cd into matching-logic/, then run your favourite IDE (or just make).

Alternatively, instead of entering the development environment, one may want to build the matching-logic library in an isolated environment:

$ nix build '.#coq-matching-logic'

(this is what CI does). Every time you run nix build, it starts from the fresh environment.

If you want to work on the Metamath extractor:

nix develop '.#coq-matching-logic-mm-exporter'

If you want to work on examples:

nix develop '.#coq-matching-logic-example-fol'.

If you want to go through the proof mode tutorial:

nix develop '.#coq-matching-logic-example-proofmode'

And so on. To list all packages, run:

nix flake show

If your Nix does not support Flakes:

  1. Upgrade nix
$ nix upgrade-nix
  1. Enable Flakes

Alternatively, we provide a flake-compat-based wrapper for building the matching logic library with a 'classical' nix, without flakes.

  1. Install Nix
$ curl -L https://nixos.org/nix/install | sh
  1. Step into the directory with the library
$ cd matching-logic
  1. Run Nix shell and let Nix handle all the dependencies
$ nix-shell
  1. Build using make
$ make

Note that this works only for the library located in the matching-logic/ directory. In particular, the Metamath extractor (located in the directory prover/), as well as the examples in the directory examples/, cannot be built this way.

IDE setup

If you have ProofGeneral, CoqIde, or VSCoq, installed, just run them inside the nix-shell. It will detect the nix-provided coq and libraries automatically.

Structure

  • matching-logic library contains a locally-nameless encoding of matching logic in Coq, including the soundness theorem and a proof mode for building matching logic proofs interactively.
  • examples folder contain a set of examples that use the matching logic library.
  • prover contains a proof-of-concept extractors of matching logic proofs to Metamath.

References

Official language definition http://fsl.cs.illinois.edu/index.php/Applicative_Matching_Logic

Snapshot version of the technical report, that was used for the ipmlementation can be found in doc/chen-rosu-2019-trb-public_march182020.pdf.