2024-04-11 12:37:58 -07:00
# PyPantograph
2024-04-19 16:47:35 -07:00
2024-04-11 12:37:58 -07:00
Python interface to the Pantograph library
2024-04-19 16:47:35 -07:00
2024-06-03 11:01:45 -07:00
# Getting started
2024-07-15 15:06:08 -07:00
Note: For [self-contained `install.sh` script for lean ](https://github.com/brando90/learning_lean/blob/main/install.sh ).
2024-04-19 16:47:35 -07:00
2024-04-29 18:30:50 -07:00
## Install 1: With Conda and Pip in the SNAP cluster
2024-04-29 12:23:28 -07:00
```bash
2024-06-03 12:50:41 -07:00
# - Install Lean 4 manually (elan & lake): gets install script (doesn't save it) & directly gives it to sh to install it
2024-04-29 12:23:28 -07:00
curl -sSf https://raw.githubusercontent.com/leanprover/elan/master/elan-init.sh | sh -s -- -y
2024-06-03 12:50:41 -07:00
# (install command from the Lean4 official instlal guide, not the one we use)
2024-04-29 18:30:50 -07:00
# curl -sSf https://raw.githubusercontent.com/leanprover/elan/master/elan-init.sh | sh -s
2024-04-29 12:23:28 -07:00
2024-04-29 18:30:50 -07:00
# - Make sure Lean4 tools (lean, lake) are available
2024-06-03 12:50:41 -07:00
echo $PATH | tr ':' '\n'
2024-04-29 12:53:54 -07:00
export PATH="$HOME/.elan/bin:$PATH"
echo 'export PATH="$HOME/.elan/bin:$PATH"' >> ~/.bashrc
2024-06-03 12:50:41 -07:00
# bash
2024-04-29 12:53:54 -07:00
elan
lake
2024-04-29 18:30:50 -07:00
# - Create and activate the right python env (this is needed so that poetry build works)
2024-04-29 12:23:28 -07:00
conda create -n pypantograph_env python=3.11 -y
conda activate pypantograph_env
2024-04-29 18:30:50 -07:00
#conda remove --name pypantograph_env --all
2024-04-29 12:23:28 -07:00
2024-04-29 18:30:50 -07:00
# - Install poetry with python venv (needs seperate install so poetry & your projs deps don't crash)
2024-04-29 12:53:54 -07:00
mkdir $HOME/.virtualenvs
2024-04-29 18:30:50 -07:00
# put the follow BEFORE your conda init stuff in your .bashrc
2024-04-29 12:53:54 -07:00
export VENV_PATH=$HOME/.virtualenvs/venv_for_poetry
export PATH="$VENV_PATH/bin:$PATH"
2024-04-29 18:30:50 -07:00
# now actually install poetry in a python env after creating an python env for poetry with venv
2024-04-29 12:53:54 -07:00
python3 -m venv $VENV_PATH
$VENV_PATH/bin/pip install -U pip setuptools
$VENV_PATH/bin/pip install poetry
poetry
2024-04-29 18:30:50 -07:00
# - Init the git submodules (i.e., make git aware of them/track them) + fetch/clone/update (and double check submodule is inited)
git submodule init
git submodule update --init
# - For snap make sure the repo is sym linked you're using your
git clone git@github.com:lenianiva/PyPantograph.git
2024-06-03 17:31:27 -07:00
# git checkout <your-branch>
git checkout brando
2024-04-29 12:53:54 -07:00
ln -s $AFS/PyPantograph $HOME/PyPantograph
2024-04-29 18:30:50 -07:00
# - Build the PyPantograph proj (build the py distribution, py deps and custom (lean4) installs). Note: pip install -e doesn't work on the dist .whl builds etc so you instead the next command
2024-04-29 12:23:28 -07:00
cd $HOME/PyPantograph
poetry build
2024-04-19 16:47:35 -07:00
```
2024-04-22 22:59:29 -07:00
To run server tests:
2024-04-19 16:47:35 -07:00
``` bash
python -m pantograph.server
2024-09-13 17:54:11 -07:00
python -m pantograph.search
2024-04-19 16:47:35 -07:00
```
2024-04-22 22:59:29 -07:00
The tests in `pantograph/server.py` also serve as simple interaction examples
2024-04-19 16:47:35 -07:00
2024-07-01 12:18:00 -07:00
## Examples
2024-09-13 18:18:16 -07:00
For API interaction examples, see `examples/README.md`
An agent based on the `sglang` library is provided in
`pantograph/search_llm.py` . To use this agent, set the environment variable
`OPENAI_API_KEY` , and run
```bash
python3 -m pantograph.search_llm
```
## Experiments
In `experiments/` , there is an experiment on running a LLM prover on miniF2F
data. Run with
```sh
python3 experiments/miniF2F_search.py [--dry-run]
```
2024-09-06 22:41:34 -07:00
## Referencing
```bib
@misc {pantograph,
title = "Pantograph, A Machine-to-Machine Interface for Lean 4",
author = {Aniva, Leni and Miranda, Brando and Sun, Chuyue},
year = 2024,
howpublished = {\url{https://github.com/lenianiva/PyPantograph}}
}
```
2024-09-26 19:26:59 -07:00
2024-04-29 18:30:50 -07:00
# - Install pypantograph in editable mode (only pyproject.toml (or setup.py!) needed! Assuming your at the proj root)
cd $HOME/PyPantograph
2024-04-29 12:23:28 -07:00
pip install -e .
2024-04-29 18:30:50 -07:00
# - Confirm intalls
2024-04-29 12:23:28 -07:00
pip list | grep pantograph
pip list | grep vllm
2024-04-29 12:53:54 -07:00
pip list | grep torch
2024-04-29 18:30:50 -07:00
# - Make sure the PyPantrograph server tests by Leni work
cd ~/PyPantograph
2024-04-29 12:53:54 -07:00
python $HOME/PyPantograph/pantograph/server.py
python $HOME/PyPantograph/test_vllm.py
2024-04-29 12:23:28 -07:00
```
2024-04-29 18:30:50 -07:00
Note: the tests in `pantograph/server.py` also serve as simple interaction examples
References:
- My SNAP `.bashrc` : https://github.com/brando90/snap-cluster-setup/blob/main/.bashrc
- Especially useful for Conda vs Poetry export order
- Poetry in SNAP: https://github.com/brando90/snap-cluster-setup?tab=readme-ov-file#poetry
- Gitsubmodules: https://github.com/brando90/snap-cluster-setup?tab=readme-ov-file#git-submodules
- Lean in SNAP: https://github.com/brando90/snap-cluster-setup?tab=readme-ov-file#lean-in-snap
- ChatGPT: https://chat.openai.com/c/e01336a7-6f67-4cd2-b6cd-09b8ee8aef5a
# Install 2: With only Poetry in the SNAP cluster
```bash
# - Install Lean4 manually (elan and lake), 1st one is the SNAP one, 2nd is the most common one
curl -sSf https://raw.githubusercontent.com/leanprover/elan/master/elan-init.sh | sh -s -- -y
# curl -sSf https://raw.githubusercontent.com/leanprover/elan/master/elan-init.sh | sh -s
# - Make sure Lean4 tools (lean, lake) are available
export PATH="$HOME/.elan/bin:$PATH"
echo 'export PATH="$HOME/.elan/bin:$PATH"' >> ~/.bashrc
bash
elan
lake
# - Init the git submodules (i.e., make git aware of them/track them) + fetch/clone/update (and double check submodule is inited)
git submodule init
2024-07-11 15:49:37 -07:00
git submodule update --init --recursive
git clone git@github.com:lenianiva/PyPantograph.git --recurse-submodules
2024-04-29 18:30:50 -07:00
# - For snap make sure the repo is sym linked you're using your
git clone git@github.com:lenianiva/PyPantograph.git
git checkout < your-branch >
ln -s $AFS/PyPantograph $HOME/PyPantograph
# - Install poetry with python venv (needs seperate install so poetry & your projs deps don't crash)
mkdir $HOME/.virtualenvs
# - Put the follow BEFORE your conda init stuff in your .bashrc
export VENV_PATH=$HOME/.virtualenvs/venv_for_poetry
export PATH="$VENV_PATH/bin:$PATH"
# - Now actually install poetry in a python env after creating an python env for poetry with venv
python3 -m venv $VENV_PATH
$VENV_PATH/bin/pip install -U pip setuptools
$VENV_PATH/bin/pip install poetry
poetry
# poetry build is only needed when you build a python distribution e.g., .whl or .tar.gz and want to distribute it. You can't use those files for edtiable development anyway
# # - Build the PyPantograph proj (build the py distribution, py deps and custom (lean4) installs)
# cd $HOME/PyPantograph
# poetry build
# - Install pypantograph in editable mode with poetry
2024-07-11 15:49:37 -07:00
cd $HOME/PyPantograph
2024-04-29 18:30:50 -07:00
#Installs the project and its dependencies into the virtual environment, creating the environment if it doesn't exist, in editable mode. This will run our custom build for Lean already (the build.py file!)
poetry install
# if it create a new python env, check it out
poetry env list
# activate the current poetry env in a new shell
poetry shell
# - Confirm intalls
# poetry show | grep pantograph # note, doesn't do anything since poetry already only works by installing things in editable mode
poetry show | grep vllm
poetry show | grep torch
# - Make sure the PyPantrograph server tests by Leni work
cd ~/PyPantograph
2024-07-11 15:49:37 -07:00
python -m pantograph.server
# python $HOME/PyPantograph/pantograph/server.py
# python $HOME/PyPantograph/test_vllm.py