Skip to main content

PyEuclid: A Versatile Formal Plane Geometry System in Python

Project description

[#259] PyEuclid: A Versatile Formal Plane Geometry System in Python

Claimed Badges

Available badge, functional badge, and reusable badge

Computational Recourses

We conduct our experiments on a server running Ubuntu 22.04.5 LTS with an AMD Ryzen Threadripper 2990WX processor, utilizing 30 CPU cores in parallel (2 cores per process, each allocated 4 GB of memory). On this setup, experiments on the JGEX-AG-231 dataset take approximately 2 hours to complete, while the Geometry3K dataset takes around 1 hour.

Additionally, we run sequential experiments on an Apple MacBook Pro with an M3 chip, using 2 CPU cores and 4 GB of memory. On this setup, processing the Geometry3K dataset takes approximately 7~8 hours.

Folder Structure

.
├── cache/                                # Cached diagrams sampled from JGEX-AG-231
├── data/                                 # Benchmark datasets (JGEX-AG-231, Geometry3K)
├── pyeuclid/
│   ├── engine/                           # Core reasoning components: inference rules, deductive database, algebraic system, proof generator
│   └── formalization/                    # Problem formalization: relations, construction rules, state management, diagram handling
├── Dockerfile                            # Docker configuration for containerized setup
├── requirements.txt                      # List of required Python packages
├── setup.py                              # Setup script to build and install PyEuclid
└── test.py                               # Run experiments on test datasets

Installation

You can get started with PyEuclid using Docker or a local installation.

From PyPI

pip install pyeuclid

Note: benchmark datasets (data/) and cache.tar.gz are not bundled with the PyPI package. Install from source if you need the datasets for experiments.

You can either build the Docker image locally or pull it from Docker Hub:

# Build the Docker image locally
docker build -t pyeuclid .
# Alternatively, pull the image from Docker Hub
docker pull dahubao/pyeuclid
# After obtaining the image, run
docker run -it pyeuclid bash

To install PyEuclid locally without Docker, run:

conda create -n pyeuclid python=3.11 -y
conda activate pyeuclid
cd PyEuclid
pip install .
tar -xvzf cache.tar.gz

After installation, verify that everything is working by running:

python test_single.py --help
python test_single.py --show-proof

If you see output like Solved in 8.90s, the setup is successful.

Note: PyEuclid uses Gurobi as a component of its proof generator. To solve more complex problems, you may need a Gurobi academic license, as the free version has a limit of 2000 variables and constraints, which may not be sufficient for certain cases.

Evaluation

We provide both sequential and parallel methods to run experiments on the JGEX-AG-231 and Geometry3K datasets:

python test.py                            # Run sequentially on a single machine
sbatch slurm.sh                           # Run in parallel on a compute cluster via SLURM

Releasing to PyPI

This project follows Semantic Versioning. To publish a new release:

  1. Update the version in pyproject.toml and pyeuclid/__init__.py.
  2. Commit the changes and create a tag that matches the version (e.g., v1.0.1).
  3. Push the tag: git push origin v1.0.1.
  4. GitHub Actions will build, check, and upload the package to PyPI, then create a GitHub release (requires PYPI_API_TOKEN secret).

Extension

If you would like to improve the reasoning ability of PyEuclid, one straightforward way is to add more complex inference rule at pyeuclid/engine/inference_rule.py. Here is an example:

@register('complex')
class AreaHeronFormula(InferenceRule):
    def __init__(self, a: Point, b: Point, c: Point):
        super().__init__()
        self.a = a
        self.b = b
        self.c = c

    def condition(self):
        return [NotCollinear(self.a, self.b, self.c), Different(self.a, self.b, self.c), Lt(self.a, self.b), Lt(self.b, self.c)]

    def conclusion(self):
        s = (Length(self.a, self.b)+Length(self.a, self.c)+Length(self.b, self.c))/2
        return [Area(self.a, self.b, self.c)**2-(s*(s-Length(self.a, self.b))*(s-Length(self.a, self.c))*(s-Length(self.b, self.c)))]

You need to specify the condition and conclusion of the inference rule. The Lt relation defines a partial order on the names of the points to reduce equivalent permutations of the inference rule.

We also provide an interactive interface that allows PyEuclid to collaborate with a human user or a Large-Language-Model (LLM) agent. You can explicitly trigger a reasoning step by calling:

engine.step(conditions, conclusions)

PyEuclid will verify both the conditions and the desired conclusions, and automatically apply the appropriate theorems or algebraic equations to derive the conclusions from the given conditions.

License

PyEuclid is licensed under the MIT License.

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

pyeuclid-1.0.1.tar.gz (488.9 kB view details)

Uploaded Source

Built Distribution

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

pyeuclid-1.0.1-py3-none-any.whl (52.0 kB view details)

Uploaded Python 3

File details

Details for the file pyeuclid-1.0.1.tar.gz.

File metadata

  • Download URL: pyeuclid-1.0.1.tar.gz
  • Upload date:
  • Size: 488.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for pyeuclid-1.0.1.tar.gz
Algorithm Hash digest
SHA256 02af2a30513233660a3feb27ea4c86601afae64f3922dc6523b9ba57cba7690a
MD5 ae5bb83366bc862a40d70cb7ae97af10
BLAKE2b-256 8a4065da7516e2ab5dca92c3cfa5204cd47a20bb8f24505939b0c13812ae2da8

See more details on using hashes here.

File details

Details for the file pyeuclid-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: pyeuclid-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 52.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for pyeuclid-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 637a2bc351ded5356a20b2f4c3bcadff5c3a1b0884315aa5e18a52de6d20cf76
MD5 0c7f2009d418e23ee3a795b5a2136c0a
BLAKE2b-256 ecf31310733400bdac87525d2524010484ee0f7cb0d780f59fbe6b0674ea3812

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