# SCOPE (Semantic Cloud-Orchestrated Perception at Edge)

## Features

- Query decomposition with importance scores (optional)
- One-pass global matching over candidate frames (`scope`)
- Budgeted frame allocation across sub-queries
- Baselines preserved: `uniform`, `topk`, `aks`

## Requirements

- Python 3.8+
- PyTorch (required for most samplers / VLM backends)
- Optional: CUDA

## Quick Start

### 1) Preprocess (sampling)

```bash
python main.py \
  --stage preprocess \
  --sampler scope \
  --dataset_name longvideobench \
  --dataset_path ./datasets/longvideobench \
  --num_frames 16 \
  --num_workers 1 \
  --match_fps 1.0
```

### 2) Inference

```bash
python main.py \
  --stage inference \
  --sampler scope \
  --agent direct \
  --dataset_name longvideobench \
  --num_frames 16 \
  --model_path ./models/<your-vlm-model>
```

## Key Arguments

- `--match_fps`: candidate extraction FPS for global matching (e.g., `0.1/0.5/1/2`)
- `--num_frames`: final budget of sampled frames per task
- `--num_workers`: preprocessing workers

## Output Layout (example)

```
outputs/
      <dataset_name>/
    <model_name>/
      scope_direct_16frames/
        <timestamp>/
          detailed_results.json
          summary_report.json
```

## Sanity Check

```bash
python -m compileall .
python main.py --help
```
