# LENS (Small Maps - Setting A)

This directory contains the core implementation for data preprocessing, U-Net training, and evaluation on standard/small maps (e.g., mazes, random maps, warehouse) under Setting A.

# 1. Data Preprocessing

First, generate agent-centric data using the expert policy:
Bash
python data_preprocessing.py \
    --map-config-dir ../dataset/dataset_configs/ \
    --map-pattern "medium-mazes-seed-*" \ # --map-pattern "training-random-seed-*" 
    --agent-counts 32 \
    --output-dir dataset_pfg
Next, combine the generated .npz files into a single PyTorch .pt dataset:

Bash
python convert_pfg_npz_to_pt_new.py \
    --data_dirs dataset_pfg \
    --out_file new_randomLOC_mixed_dataset.pt


## 2. Train U-Net
Train the Potential Field Generator (U-Net) using Distributed Data Parallel (DDP). Ensure the dataset path in train_unet_new.py matches your .pt output file.

Bash
torchrun --nproc_per_node=1 train_unet_new.py


## 3. Evaluation
You can test the model directly using the local script below, or use the unified wrapper in the root directory.

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