# Event–Skeleton Pair Construction (ROI + V2E)

This module builds matched event streams from RGB videos using skeleton files as ROI guidance. It wraps the v2e emulator with reproducible parameters matching the manuscript.

## Layout
```
Dataprocess/
└── ProcessEvent/
    ├── BaseData/
    │   ├── RGB/                         # *_rgb.avi
    │   ├── Skeleton/                    # *.skeleton
    │   └── action_classes_filtered.txt  # sample list (no extensions)
    └── Output/                          # *_dvs.avi
```

## Parameters (aligned with paper)
- ROI expansion: width×1.2, height×1.3
- V2E: timestamp=0.01, pos_thres=0.15, neg_thres=0.15, sigma_thres=0.03, dvs640 (640×480), cutoff_hz=15, no SloMo

These are encoded in `ProcessEvent/generator.py` and passed to `Dataprocess/v2e/v2e.py`.

## Setup
1) Install v2e and deps (see `Dataprocess/v2e/requirements.txt` or `environment.yml`). Example:
```bash
pip install -r Dataprocess/v2e/requirements.txt
```
2) Ensure `v2e.py` is invokable from the working dir where you run the generator.

## Prepare Data
- Put `.skeleton` files and matching `*_rgb.avi` under `BaseData/`
- Fill `action_classes_filtered.txt` with sample IDs like `S018C001P008R001A066`

## Run
From repo root:
```bash
python Dataprocess/ProcessEvent/generator.py
```
What happens
- Loads sample list → parses skeleton → computes ROI → calls v2e → writes `Output/<sample>_dvs.avi`

## Troubleshooting
- No matching RGB video: check names under `BaseData/RGB` and list file
- Empty/invalid skeleton: the sample will be skipped with a message
- Wrong crop: verify ROI factors in `calculate_crop_parameters` and input video resolution
- v2e import errors: install its requirements; on Windows, you may need `Gooey` or run with `--ignore-gooey`

## Advanced
- To alter thresholds/resolution, edit `generate_v2e_command` in `generator.py`
- To batch different splits, point the list file to the desired subset

For v2e usage details, see `Dataprocess/v2e/README.md`.