# **Holistic Prompting**: Joint Reasoning with Reusable States and Shortcut Discovery
![alt text](data/overview_full.jpg)

# Installation
This repository can be used in two ways:
* To run single instances of our method. For this, simply execute the respective notebooks and adapt the parameters to your liking.
* Dispatch multiple runs on a slurm-managed cluster or standard multiprocessing for single nodes. This is implemented via the `papermill` library which allows to parameterize an existing notebook. This option is practical for larger experiments. See `run_experiments.ipynb` for our own experimental setup.
    * Note: If you change anything in the source notebook and then dispatch runs via papermill, you will propagate these changes!

In any case:
1) Clone the repository
2) Create a new environment in the root level of this repo. Make sure to name it `hp_env`.
3) Install the packages in `requirements.txt`. 


# Setup for Game24

## Running HP-BFS
* To create the datasets, run the desired sections in `create_datasets.ipnyb`.
* The algorithm is implemented in `hp_shortcut_rounds.ipynb`, which can be used to run single instances.
* Baselines are implemented in `baseline_tot.ipynb` and `baseline_io_cot.ipynb`.
* Hyperparameter search is dispatched from within `run_experiments.ipynb`.
* Results are compiled in `pretty_pictures.ipynb`.
* The error analysis is compiled in `error_analysis.ipynb`

# Setup for Retrosynthesis Planning

We utilize some code from the paper by (Hong et al.)[https://www.nature.com/articles/s42004-023-00911-8]. Their official github repo is added here as a submodule.
Make sure to:
1. Download and extract the data as described (here)[https://github.com/jjljkjljk/EG-MCTS?tab=readme-ov-file#2-download-the-data].
    2.  Their repo is located in this repo in `externals/eg-mcts/`. Add the respective files relative to that path.
    3.  We only need the `one_step_model` folder and the `origin_dict.csv`

`eg_mcts` package has submodules, too. Install them like this:
`pip install -e externals/eg-mcts/eg_mcts/packages/mlp_retrosyn`
`pip install -e externals/eg-mcts/eg_mcts/packages/rdchiral`

Finally, run:
`pip install -e externals/eg-mcts`

### Minor changes
* if pip crashes on `pip install -e externals/eg-mcts`:
    * Edit "version" field in externals/eg-mcts/setup.py to a valid version str
* Numpy deprecated np.ninf: Change the occurences in "externals/eg-mcts/eg_mcts/algorithm/search_tree.py" to `-np.inf`

## Running HP-MCGS

* See `retrosynthesis_hp.ipynb` for our implementation.
