/mmm

Little Theories for Metamath: specification (and perhaps toy implementation) of a Metamath module system

GNU General Public License v3.0GPL-3.0

mmm: Modular Metamath -or- Little Theories for Metamath

Goal

The goal of this little project is to come up with some sort of module system for Metamath.

There are two main drivers for this.

First, set.mm, the main database of results proved in Metamath, is becoming really large: this text files is 24 MB at last count. Some statistics for the 25-Jun-2015 version:

450810 lines (24740442 characters) were read from "set.mm".
The source has 123892 statements; 1957 are $a and 25097 are $p.

This gives some practical limitations. For example, Github does not show such large files, nor the commit diffs in them. And editors, verifiers, and other tools also occasionally run into performance problems.

The second -- and for me more important -- problem is one of structure: how are all these axioms and theorems interconnected? which axiom sets can be proved from others?

This structure is implicitly present in set.mm, and its rendering on metamath.org, the Metamath Proof Explorer Theorem List, makes this partially explicit.

However, this structure can be made more explicit by allowing axiom sets to be named, and storing proofs for different axiom sets in separate files. (For people who know Ghilbert, this corresponds to .ghi and .gh files.)

Also, it would be helpful to be able to express things like "the positive real numbers form a group", and then take any theorem that holds for any group, and automatically have a theorem for positive real numbers. Basically, this comes down to a definition/abbreviation mechanism.

The result would be support for the 'little theories' approach to mathematics, as described and advocated in, e.g., Farmer, Guttman, and Thayer, "Little Theories" (Springer-Verlag 1992), pp. 567-581 in Automated Deduction|CADE-11, volume 607 of Lecture Notes in Computer Science.

Initial ideas

As far as I currently can see, three mechanisms would be sufficient:

  • Combine two .mm files 'in sequence';
  • Transform a .mm file into a new one through renaming and selection;
  • Transform a .mm file into a new one through expanding abbreviations.

The following principle will guide the design for these transformations:

If the original .mm files verify correctly, and the transformation succeed, then the resulting .mm file should also verify correctly.

(Note: The nice thing is that the Metamath proof verifiers can protect against incorrectly designed or implemented transformations.)

Mechanism: Combining files in sequence

To combine files in sequence, we take all of the first file, and then all of the second file, except that we leave out all axioms ($a) from the second file which are identical to theorems ($p) in the first file.

(TODO: Enhance.)

Mechanism: Renaming and selection of statements

In this transformation, one can change the labels of statements, and leave out specific statements (and all later statements whose proofs refer to them).

This is useful as a preparation for combining files in sequence, to prevent statement name collisions.

(TODO: Enhance.)

Mechanism: Expanding constants using abbreviations

This is the most complex transformation, where an abbreviation specifies how to replace one constant or expression by another, optionally adding one or more $e or $f hypotheses.

(TODO: Design and write down the details.)

How to add this to Metamath?

(TODO: Options I see:

  • an external tool that transforms .mm files based on 'link' / 'module description' files; or
  • an extension to the Metamath language, allowing, e.g., $< ... $> import statements which contain the transformation instructions.

Enhance on this.)