# Dataset Processing

This directory contains the foundational pipeline required to prepare, synthesize, and extract high-fidelity spatial data systematically. It is conceptually split between physical stereoscopic lens rectification and deep-learning disparity extractions utilizing the cutting-edge **FoundationStereo** transformer model.

## Core Philosophical Architecture

Generating valid evaluation matrices requires pristine dataset inputs structurally guaranteeing that geometric models evaluate exactly matching physical logic mapping. 
These scripts are implicitly tied chronologically to one another naturally mapping raw isolated sequences seamlessly into evaluatable `npy` arrays.

## Scripts Overview & Execution Order

### 1. `rectify_stereo.py`
**Purpose:** Prepares unaligned fisheye image arrays translating them completely into physically identical parallel baselines.
**Description:** It aggressively bends complex wide-angle distortion (typically observed explicitly on rovers) identically scaling pixels via calibrated camera matrices (`K_r`, `D_r`). It forces matching 3D structures organically onto completely shared horizontal mapping coordinates flawlessly without loss.

```bash
python rectify_stereo.py \
    --input_dir separated_images_test1 \
    --calib_dir calibration \
    --output_dir rectified_images_test1
```

### 2. `check_rectification_visual.py`
**Purpose:** Qualitative Verification.
**Description:** Visually projects aligned bounding boxes natively concatenating rectified bounds cleanly mapping parallel tracking traces automatically bridging isolated fields dynamically. Produces visual Anaglyphs separating scale intuitively checking human valid limits perfectly.

```bash
python check_rectification_visual.py \
    --input_dir rectified_images_test1 \
    --output_dir rectification_visual_check \
    --num_pairs 5
```

### 3. `create_fs_outputs.py`
**Purpose:** Dense scale extraction bypassing monocular ambiguities implicitly mapping disparities robustly via FoundationStereo.
**Description:** Systematically iterates parallel pairs dynamically checking features perfectly aligned by step 1 bounding them seamlessly calculating rigid subpixel disparities intelligently. Handles massive processing loads directly orchestrating Multi-GPU concurrency natively. Extracts `.npy` boundaries intelligently throwing out outliers effectively leveraging standard IQR or Otsu distributions systematically.

```bash
python create_fs_outputs.py \
    --input_path /path/to/rectified_images \
    --output_path /path/to/foundation_out \
    --foundation_repo /path/to/FoundationStereo \
    --ckpt /path/to/checkpoint/model_best_bp2.pth \
    --scale 0.5 \
    --disp_outlier_method depth_25m_global
```
*(Optional features support focal constraints explicitly calculating valid depth limits dynamically natively outputting raw evaluation maps).*

## 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 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 imageio tqdm
```
