# LODGE: Joint Hierarchical Task Planning and Learning of Domain Models with Grounded Execution

This repository is the official implementation of [LODGE: Joint Hierarchical Task Planning and Learning of Domain Models with Grounded Execution](#)

## Getting Started

**Environment**

To install environment

```bash
pixi install
pixi run build-val
cd 3rdparty/llm-pddl-planning
pixi install
cd ../3rdparty/LLMs-World-Models-for-Planning
pixi install
```

**Setup LLM keys**
in [.env](./env), define the OPENAI and OPENROUTER API Keys


# Experiments

For furniture bench: Start the simulation backend (in a separate terminal)
```bash
cd packages/furniture-bench
# download isaac-gym to ./packages/furniture-bench/3rdparty/isaac-gym
pixi run simulation
```

## Domain Learning
Following script will run all baselines and LODGE for learning the three domain models.
```bash
pixi shell
> ./reproduce.sh -g
```
This will run all methods and in the end print a table similar to Table 1 in the paper.

## Predicate Learning
Domain learning on furniture bench must be ran before this will work (as it uses the interactions during domain learning).
To evaluate predicate learning with LODGE against Pix2Pred and InterPreT, run
```bash
pixi shell
> ./reproduce-pred-grounding.sh -g
```

## Run LLM Planning Baselines

```bash
python demos/ipc/scripts/run_llm_planning_baseline.py --engine %ENGINE --task %TASK
# and
python demos/ipc/scripts/run_llm_planning_baseline.py --engine %ENGINE --task %TASK --eval # for evaluation
```
