# SCOPE: Evolving Symbolic World for Planning in Open-Ended Environments

## Overview
Recent works have explored integrating Vision-Language Models (VLMs) with classical planners that rely on symbolic representations of planning problem to generate long-horizon plans for complex embodied tasks. However, in open-ended environments, these symbolic representations obtained from perception are often incomplete, leading to suboptimal performance. To address this, we introduce SCOPE, a self-adaptive symbolic planning framework that supports refining action plans and evolving the symbolic world—the symbolic representations of open-ended environments. SCOPE comprises two synergistic modules: a Symbolic Execution Simulator (SESim) that conducts symbolic validation and real execution of action plans, leveraging the feedback to refine the plans and evolve the symbolic world; and a Self-Adaptive Symbolic Memory (SASMem) that further distills feedback into evolving symbolic knowledge to enhance long-horizon planning and modeling of the symbolic world. Experiments in open-ended environments show that SCOPE significantly improves the completeness of the symbolic world, the success rate of plans under environment perturbations, and cross-task grounding and adaptability across diverse embodied scenarios.

<img src="images/pipeline.png" />

## Installation

### 1. Clone this repository

### 2. Set up Python environment
We recommend using conda:
```bash
conda create -n scope python==3.9
conda activate scope
pip install -r requirements.txt
```
### 3. Install VAL(validator) and FastDownward (planner)
* VAL:[VAL plan validation software](https://github.com/KCL-Planning/VAL)
* FastDownward:[FastDownward](https://github.com/aibasel/downward.git)
```
SCOPE/
├── fast-downward-24.06.1/
├── val/
├── SCOPE/
      └── virtualhome/
```
To verify installation:

```bash
python fast-downward.py --validate --alias lama-first domain.pddl problem.pddl
```
### 4. Install VirtualHome (simulator)
Clone [VirtualHome](https://github.com/xavierpuigf/virtualhome) and install it by running:
```
pip install -e .
```
#### Download Unity Simulator
Download the VirtualHome UnitySimulator executable and move it under `virtualhome/simulation/unity_simulator`.
- [Download](http://virtual-home.org//release/simulator/v2.0/v2.3.0/windows_exec.zip) Windows version.

## Quickstart
To run a reproducible test:

```bash
cd SCOPE
python main.py \
    --agent gpt-4o \
    --start_taskid 0 \
    --end_taskid 1 \
    --memory \
    --envid 0 \
    --save_dir result/ \
    --mode eval
```
This will execute a symbolic planning and execution pipeline with logging output saved to result/.

<img src="images/Example.png" />
