# Video Acceleration Demo (Baseline vs FlashBlock)

This demo provides a qualitative comparison between a Baseline method and our proposed FlashBlock approach across multiple video categories.
All videos are precomputed and organized for deterministic, side-by-side visualization.

---

## Directory Structure

demo/
├── app.py
├── index.html
├── videos/
│   ├── <category_name>/
│   │   ├── baseline/
│   │   │   ├── video1.mp4
│   │   │   ├── video2.mp4
│   │   │   └── ...
│   │   └── ours/
│   │       ├── video1.mp4
│   │       ├── video2.mp4
│   │       └── ...
│   └── ...

- Each category contains exactly 5 videos.
- Videos in baseline/ and ours/ share identical filenames.
- The ours/ folder corresponds to the FlashBlock method.
- Videos are aligned by filename and displayed in a fixed grid.

---

## How to Run

### Requirements
- Python >= 3.8

### Install dependencies

pip install fastapi uvicorn

### Launch the demo

uvicorn app:app --port 8000

Then open your browser and visit:

http://localhost:8000

No GPU or additional dependencies are required.

---

## Demo Layout and Interaction

- Each category is shown as a separate block.
- Videos are arranged in two rows:
  - First row: Baseline
  - Second row: FlashBlock
- Each row contains five videos aligned horizontally.
- Videos in the same column (Baseline vs FlashBlock) are synchronized:
  - Play and pause are linked
  - Seeking (timeline dragging) is linked

This layout mirrors the qualitative figures commonly used in research papers.
