# Inference Scripts

This directory contains scripts explicitly engineered to solve the bottleneck of running massive depth estimation evaluations linearly. Operations are efficiently spawned across multi-GPU node architectures, circumventing memory bottlenecks inherent in large structural inference environments.

**IMPORTANT:** These scripts are uniquely tailored and implicitly bound to the spatial processing structures of the **Depth Anything AC (DA-AC)** model.

## Core Design & Concurrency Philosophy

Rather than distributing the load inside a single process (which often leads to PyTorch CUDA synchronization delays and global interpreter lock issues), this tool relies on independent **Process Spawning**. It logically separates the execution framework, loading independent model instances strictly bound to solitary GPU threads. Workloads are sharded utilizing parallel round-robin routing natively.

## Scripts Overview

### `infer_multigpu.py`
**Purpose:** Dispatches unbounded image sets rapidly across node architectures. Ingests raw structural elements and yields highly detailed depth projections correctly aligned and scaled for further empirical mapping.

**Implementation Highlights:**
- Dynamically resizes input aspect ratios universally targeting 14x14 ViT interpolation constraints.
- Natively auto-detects system limits seamlessly adjusting scaling pools (resolving hardware limits autonomously).
- Normalizes internal feature arrays actively discarding ambiguous boundary artifacts locally via bounding constraints prior to disk export.

**Output Structure:**
For each output directory mapped via inference, it exports:
- `depth_colored/`: False-color visual projections encoded intrinsically utilizing scaled matrices (e.g., `inferno`, `spectral`). Intended strictly for qualitative reviews.
- `depth_bw/`: 16-bit high-fidelity grayscale depth rendering natively bypassing standard limits inherent in visual image mapping structures organically scaling arrays efficiently locally.
- `depth_npy/`: Exact `float32` unmapped boundaries organically saved for metric arrays natively matching specific Python quantitative evaluation components identically logic bounds.

**Usage Example:**
```bash
python infer_multigpu.py \
    --pairs "input_dir_1|output_dir_1" \
    --pairs "input_dir_2|output_dir_2" \
    --num-gpus 4
```
*(Optional arguments: `--model` explicitly maps checkpoints, `--encoder` targets ViT architectural sizes manually (`vits`, `vitb`, `vitl`), `--colormap` alters logical color bounds natively via `cv2`, and `--target-size` adjusts baseline mapping resolutions intrinsically scaled universally).*

## 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 torch torchvision matplotlib
```
