# SNN-Driven Multimodal HAR — Project Overview

This repository contains two main parts:
- Dataprocess: scripts to construct Event–Skeleton pairs from RGB–Skeleton datasets (ROI crop + V2E conversion)
- Model: training/inference code for the SNN-based multimodal model (Skeleton + Event, SSE + SCM + DIB)

Below is a concise guide to help you run the data pipeline and the model without duplicating details already covered in the submodule READMEs.

## 1) Data Processing (Event–Skeleton Construction)
Location: `Dataprocess/ProcessEvent`
- Entry point: `generator.py`
- What it does:
  - Parses NTU RGB+D skeleton files to compute ROI per clip
  - Crops the RGB video to subject ROI (width×1.2, height×1.3)
  - Invokes V2E to generate event streams with the paper’s parameters (timestamp=0.01, pos/neg=0.15, sigma=0.03, dvs640, cutoff=15)

Prerequisites
- Install V2E dependencies under `Dataprocess/v2e` (see its `requirements.txt` or `environment.yml`).
- Ensure `v2e.py` is invokable from the working directory used by `generator.py`.

Inputs
- `Dataprocess/ProcessEvent/BaseData/Skeleton/*.skeleton`
- `Dataprocess/ProcessEvent/BaseData/RGB/.../*_rgb.avi`
- `Dataprocess/ProcessEvent/BaseData/action_classes_filtered.txt` (sample list)

Outputs
- Cropped event videos: `Dataprocess/ProcessEvent/Output/<sample>_dvs.avi`

Quick start (PowerShell)
```
# from repository root
python Dataprocess/ProcessEvent/generator.py
```
For more details, see:
- `Dataprocess/EVENT_SKELETON_GENERATOR_README.md`
- `Dataprocess/v2e/README.md`

## 2) Model Training & Inference
Location: `Model`
- Config: `Model/config/nturgbd-cross-subject/defaultMM.yaml`
- Training entry points:
  - `Model/trainMM.py` (top-level training script)
  - or `Model/mmodel/trainMM.py` (module-level)
- Key components (under `Model/mmodel/`):
  - Skeleton backbone (`Skeletonbackbone.py`), Event backbone (`Eventbackbone.py`)
  - Sparse Semantic Extractor (`Semanticlearning.py`)
  - Cross-modal fusion (SCM) and DIB (`Multimodal.py`, `ITHU.py`)

Prerequisites
- Install Python deps listed in `Model/requirements.txt`.
- Ensure dataset paths in the YAML point to your data.

Quick start (PowerShell)
```
# install deps (recommended in a virtual environment)
pip install -r Model/requirements.txt

# train with default cross-subject config
python Model/trainMM.py \
  --config Model/config/nturgbd-cross-subject/defaultMM.yaml \
  --work-dir runs/ntu_cs \
  --phase train
```
Tips
- Adjust batch size, GPUs, and data roots via the YAML or CLI overrides.
- For evaluation, set `--phase test` and use the trained checkpoint.

## Reproducibility Notes
- ROI factors and V2E parameters are aligned with the manuscript.
- DIB hyperparameters use the paper notation `(alpha, lambda1, lambda2)` and are non-trainable constants; set them at model init if needed.

## Where to Read More
- Data pipeline details: `Dataprocess/EVENT_SKELETON_GENERATOR_README.md`
- Model details and module descriptions: `Model/MODEL_README.md`
