Skip to main content

Isabelle REPL client

Project description

Isabelle REPL

Unofficial support for Isabelle's Read-Eval-Print-Loop.

Features

  • Python Client, easy for Machine Learning.
  • Full support for all Isabelle commands
  • Tracing the proof state and the output panel for each step of evaluation.
    • Plugin: collecting data from Isabelle's internal representations by plugins written in Isabelle/ML (example).
  • Socket based remote communication
  • Socket based Concurrency
  • State rollback (example)
  • Parsing terms & Retrival of lemmas (example)
  • Sledgehammer (example)
  • Retrivial of contextual information including assumptions, local facts, fixed terms, fixed types, and goals, in either the pretty-printed form or S expression (example).
  • Convertion between Isabelle's ASCII and Unicode (example)

Installation

We only support Isabelle2024. Since Isabelle2025 is going to release, the support for Isabelle2023 will not be updated any more.

Ensuring <ISABELLE-BASE-DIRECTORY>/bin is in your $PATH environment

git clone https://github.com/xqyww123/Isa-REPL.git
cd Isa-REPL
git checkout $(isabelle version) # Error can raise if you are using an unsupported version of Isabelle
isabelle components -u .
pip install IsaREPL

Start up the REPL server

# merely an example:
./repl_server.sh 127.0.0.1:6666 HOL ./tmp -o threads=16
# Note, you must explicitly indicate the number of cpu cores that you want to use,
# otherwise, Isabelle only takes 8 core by default

Run ./repl_server.sh to see the full explanation of the arguments and options.

Example Clients

Every interface of our client is will documented (it is highly recommended to read our source). Some examples are given in the example folder.

# Run an example
./examples/example_eval.py 127.0.0.1:6666

To evaluate a whole theory file

./examples/eval_file.py 127.0.0.1:6666 $(isabelle getenv -b ISABELLE_HOME)/src/HOL/List.thy

Notes

Known Issues

The REPL server (or the Isabelle system) becomes unstable when the number of parallel threads exceeds 100. We suggest to launch multiple servers if your machine has more than 64 cpu cores, and give every server at most 64 cores by setting option -o threads=64

Documents

All documents are given as docstrings attaching to Python client interfaces, see the source.

Concurrency

This REPL supports concurrent evaluation of multiple files. However, to ensure proper error tracking and result tracing, it disables Isabelle's concurrency between commands within a single theory file. While Isabelle typically executes by commands asynchronously (continuing to the next command before completion), this REPL enforces synchronous evaluation. Each command must complete before the next begins, allowing for accurate capture and reporting of any failures.

Sledgehammer (via our auto_sledgehamemr wrapper, see example) is still concurrent.

Communication Protocol

It is possible to implement a client in other languages. However, the document for the communication protocol is not provided and I refer you to read our source code, as it should be simple enough.

Contribution

Feel free to open any GitHub issue if you have any feature requests.

I am not a professional python developer, so contribution is highly welcome to enrich the client's features.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

isarepl-0.9.11.tar.gz (24.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

isarepl-0.9.11-py3-none-any.whl (29.5 kB view details)

Uploaded Python 3

File details

Details for the file isarepl-0.9.11.tar.gz.

File metadata

  • Download URL: isarepl-0.9.11.tar.gz
  • Upload date:
  • Size: 24.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for isarepl-0.9.11.tar.gz
Algorithm Hash digest
SHA256 a5c699baa26bf942405e81c0ca513d711a2efe7bcaf8272e8d60c11f14d3c6b8
MD5 983476ee3d6fb0bddcd3ac580832ada5
BLAKE2b-256 01fae063f265b01c542d35b29fa8f40d27c2d170be964b49267a73e097b26887

See more details on using hashes here.

File details

Details for the file isarepl-0.9.11-py3-none-any.whl.

File metadata

  • Download URL: isarepl-0.9.11-py3-none-any.whl
  • Upload date:
  • Size: 29.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for isarepl-0.9.11-py3-none-any.whl
Algorithm Hash digest
SHA256 22869c62a3e2806da813a8dca7c91413e5963156c03d191563f3f696ef749d62
MD5 4877b050d6288b4b33d6e0d6d048f8f2
BLAKE2b-256 c79153dd2c66e037d1d1fd16ca805acc5ec0ff7dcc18a5f7cfc4aa5361467a9d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page