# Hermes Agent for Lean-based agent for Informal Mathematics

## Requirements
- Supported platform: Linux
- Python 3.10+
- Recommended Lean version is 4.9.0 for Goedel-V2-Prover/Autoformalizer

## Installation 

1. **Install Lean 4**

   Follow the instructions on the [Lean 4 installation page](https://leanprover.github.io/lean4/doc/quickstart.html) to set up Lean 4.

2. Setup REPL

    You may follow the REPL installation and setup guide [here](https://github.com/leanprover-community/repl).

## Usage

To use Hermes agent, please set up ```translation, prover, lean``` configuration files and launch vLLM servers that host the specified models. Instantiate the agent as follows:

```python
scheduler = Lean4ServerScheduler(
            max_concurrent_requests=lean4server_cfg.get("lean_max_concurrent_requests", 4),
            timeout=lean4server_cfg.get("lean_timeout", 120),
            memory_limit=lean4server_cfg.get("lean_memory_limit", 10),
            name=lean4server_cfg.get("name", 'test-server'))

reasoner = HermesReasoner(scheduler=scheduler,
                              translator_config=TRANSLATOR_CONFIG,
                              prover_config=PROVER_CONFIG,
                              embedding_model=embedding_model,
                              user_id='abc123')

scheduler.close()
```

Then, to load the agent into the base model, you may refer to [LangChain Guide](https://docs.langchain.com/oss/python/langchain/tools). In short, you need to supply the LLM with knowledge about the tool as follows:

```python
agent = create_react_agent(
        model=llm,
        tools=[reasoner],
        prompt=prompt
    )
```
Where ```model``` is a base LLM class and prompt is the math problem. Please refer to ```demo.py``` file for more information. 