/logia

A simple theorem prover for Coq.

Primary LanguagePython

LOGIA

Logia is my attempt to create an automated theorem prover by combining the widely separate fields of proof theory, evolutionary algorithms and computer programming. In its current form, it uses evolutionary algorithms to generate mathematical proofs which are then verified by Coq, a proof assistant for a variant of higher order type theory that also manages to avoid the halting problem.

Getting Started

Get Python 3 and the NumPy and SymPy libraries. I use Anaconda by Continuum Mechanics, which contains these libraries and many others.

Next, download Coq, a proof assistant for the Calculus of (Inductive) Constructions, which is a formal language for mathematics invented by Thiery Coquand.

Clone the repository and change the path variable in the python sourcecodes accordingly, and you're good to go!

How To

Logia comes with a shell (lsh) that can be run by executing either lsh.py or l.sh. Built into lsh are various commands to evaluate mathematical expressions, as well as rudimentary file management commands. Type help into lsh to get a list of commands. Almost all math commands require SymPy, so it's advisable to get it first. In the future I'd like to have a better interface and more out-of-the-box support for doing mathematics (graphs, numerical solvers, better editors &c).

The Logia 'kernel', which is the theorem prover, can be launched from lsh through the prove command. NumPy is required for this to run. prove calls the GNU nano editor on a theorem.v file, which can be edited and saved. Write the theorem to be proved here. Saving theorem.v automatically launches the prover to action, which tries to find proofs for the theorem and halts only when a proof is found, threshold fitness goes over a certain value, or if no such value is set, possibly forever.

lsh also has basic file management capabilities. To find files, type find <string>; an empty string returns all files in the present working directory. To change directory, type cd, hit enter, type the path. To edit or compile a .v file, type edit or com, press enter, and type in the filename. The coq compiler tries to compile the .v file and produce a .vo file. To remove all temporary .v and .vo files in the present directory, type del. Doing this is necessary before launching the prover everytime, as this flushes temporary files out. Any time the screen gets messy doing math, use cls. To quit the shell, type qed.

If you have queries, please mail me at wrickbasu@gmail.com.

Related Work and Further Reading

  1. Univalent Foundations, Vladimir Voevodsky, Benedikt Ahrens, Daniel Grayson and others.
  2. Automatically Proving Mathematical Theorems with Evolutionary Algorithms and Proof Assistants, Li-An Yang, Jui-Pin Liu, Chao-Hong Chen, Ying-ping Chen.
  3. ProvingGround, Siddhartha Gadgil.
  4. Machine Learning for Proof General, Jonathan Heras and Ekaterina Komendantskaya.