# Visualization Scripts

This directory contains the pipeline for transforming raw depth predictions (`.npy` arrays) and ground-truth fields into high-quality, normalized qualitative visualizations.

A central design philosophy of these scripts is **Evaluation Parity**. Rather than applying arbitrary scaling to raw predictions for cosmetic purposes, all visualization logic here rigorously replicates the *exact clipping, masking, and alignments* executed during the quantitative metric evaluation. This ensures that the generated visual assets explicitly reflect the quantitative metrics being reported.

## Core Scripts

### 1. Prediction Processors (`process_*_npy.py`)
There are dedicated scripts for handling the spatial specifics of each evaluation dataset (`change`, `cheri`, `etna`, `lusnar`, `s3li`). 
- **Purpose**: Loads raw prediction data, spatially aligns the predictions back to the metric ground-truth space using global least-squares scaling and translation, and applies the dataset's exact maximum depth cutoffs and masks before writing output `.png` maps.
- **Output Types**: 
  - Standard false-color map generation (via OpenCV colormaps like `magma`, `inferno`, `turbo`).
  - `gray16` formats natively preserving absolute depth relations logically without mapping artifacts.
- **Example Usage**:
  ```bash
  python process_change_npy.py --input-dir <outputs> --output-dir <dest> --cmap magma
  ```

### 2. Ground-Truth Visualizer (`gt_visualize.py`)
- **Purpose**: Generates parallel ground-truth representations implementing the same spatial limits, masks, and boundary percentile truncations as the prediction scripts.
- Ensures the visual fields against which qualitative tracking happens reflect exactly what the models were mathematically tested against.
- **Supported Datasets**: All 6 benchmark suites (LunarSim, LuSNAR, Chang'e, Cheri, Etna, S3LI).
- **Example Usage**:
  ```bash
  python gt_visualize.py change cheri etna --cmap magma
  ```

### 3. Video Compiler (`GenerateVideos.py`)
- **Purpose**: Recursively walks directories looking for isolated sequences of frame predictions. Compiles sequences chronologically into continuous `.mp4` video format for easy review.
- Resolves irregular spatial dimensions dynamically on a per-sequence basis.
- **Example Usage**:
  ```bash
  python GenerateVideos.py --input-root <png_outputs> --output-root <video_dest> --fps 30
  ```

## Normalization Logic
Our normalization natively abandons strict minimum-maximum anchoring, which frequently collapses depth visualizations into washed-out arrays due to sparse extreme outliers (sensor noise). Instead, these scripts utilize **percentile bounding** (e.g., 2nd to 98th percentile). Within those bounds, logarithmic distributions are applied when appropriate to physically mimic human perception limits across expansive environments.

## Standalone Virtual Environment

This module is completely decoupled and is designed to operate strictly within its own isolated architectural state. 
To prevent cross-contamination with other system dependencies, it is highly recommended to instantiate a dedicated virtual environment solely for this directory.

```bash
# 1. Initialize strictly localized environment mapped directly to this execution boundary
python3 -m venv venv

# 2. Activate isolated boundaries explicitly 
source venv/bin/activate

# 3. Pull required foundational packages natively 
pip install --upgrade pip
pip install numpy opencv-python argparse
```
