# LENS: Supplementary Code

This repository contains the official implementation of LENS and scripts to reproduce the experiments presented in the paper.

## 📂 Repository Structure

- `LENS_s_settingA/` & `LENS_s_settingB/`: Code for data preprocessing, U-Net training, and evaluation on **Small maps** (e.g., mazes, random, warehouse).
- `LENS_l_settingA/` & `LENS_l_settingB/`: Code for evaluation on **Large maps** (e.g., City).
- `baseline/`: Evaluation scripts for baselines (LNS2, SCRIMP, GNN-CSPIBT, MAPF-GPT and Quality reference LACAM).
- `dataset/`: Configurations and map files for training and evaluation.
- `run_benchmark_wrapper_settingA.py` & `run_benchmark_wrapper_settingB.py`: Unified wrappers to automatically route evaluations to the correct script (`LENS_s` or `LENS_l`) based on the map pattern.

## 🛠️ Environment Setup

We recommend using Conda to set up the environment:
```bash
conda env create -f environment_LENS.yaml
conda activate LENS

🚀 Quick Start
1. Data Preprocessing & Training
To train the U-Net model from scratch, navigate to LENS_s_settingA/ (or Setting B) and follow the instructions in its README.md.

Generate agent-centric data using data_preprocessing.py.

Convert the .npz files to .pt format using convert_pfg_npz_to_pt_new.py.

Train the model using train_unet_new.py. 

**⚠️ Note on processed dataset and Pre-trained Weights:** > Due to the 100MB file size limit for supplementary materials, the pre-trained U-Net checkpoints and processed dataset are **too large to be included** in this compressed archive. Please follow **Step 1** below to train the model from scratch, or provide your own trained checkpoints to run the evaluations.

2. Evaluation (Testing)
We provide unified wrapper scripts at the root directory. They will automatically route the evaluation to the appropriate sub-module (LENS_s for small maps, LENS_l for large maps) based on the --map_pattern argument.

Example: Evaluating on Small Maps (Setting A)

Bash
python run_benchmark_wrapper_settingA.py \
    --map_config_dir dataset/eval_configs/ \
    --map_pattern "validation-mazes-seed-*" \
    --agent_counts 32 \
    --num_trials 1


Example: Evaluating on Large Maps (Setting B)

Bash
python run_benchmark_wrapper_settingB.py \
    --map_config_dir dataset/eval_configs/ \
    --map_pattern "City*" \
    --agent_counts 256 \
    --num_trials 1


map_pattern can be selected from below option:
 --map_pattern "validation-random-seed-*"
--map_pattern "wfi_warehouse"  
--map_pattern "puzzle-*"   
--map_pattern "validation-mazes-seed-*"  
--map_pattern "City*" 
