# Compare_RNN/task/classification：分类任务运行命令

以下命令均从仓库根目录运行：`python Compare_RNN/task/classification/<script>.py ...`

## 通用参数（大多数脚本都有）

- `--epochs`：正式训练轮数（Stage 2）
- `--scan-epochs`：增益扫描轮数（Stage 1）
- `--seed`：随机种子
- `--train-limit/--test-limit`：子采样（便于 smoke test）
- `--time-weighting {none,final,late}`：时序 loss 加权策略
- `--step-labels {final,fptt}`：是否使用 FPTT surrogate 软标签（`final`=只监督最后一步）
- `--tbptt-short/--tbptt-long`：TBPTT 截断步数（用于与 full BPTT 对照）
- `--no-eprop`：跳过 E-Prop（若你只对 Local/BPTT/FPTT 感兴趣）
- `--no-plot`：关闭绘图与结果写盘
- `--plot-path`：指定输出目录（会生成 `*_summary.csv/json` 与多张图）

---

## 性能测量（Time / Memory / FLOPs）

如果你要在**同一套模型/数据**下，对不同训练算法统一测 `time + memory + FLOPs`（尽量硬口径），推荐直接用仓库内工具：

- 说明文档：`tools/README.md`
- 一键脚本（UCI HAR 上做 cost sweep）：`tools/profile_uci_har_cost_sweep.py`

最常见用法（需要 GPU + Nsight Compute `ncu`）：

```powershell
python tools/profile_uci_har_cost_sweep.py --device cuda --flops-mode ncu --out-dir plots/uci_har_cost_sweep  # if ERR_NVGPUCTRPERM, use --flops-mode torch
```

## MNIST：Row-Sequential（28 steps）

- 快速 smoke（小数据 + 少轮数）
  - `python Compare_RNN/task/classification/row_mnist.py --epochs 1 --scan-epochs 1 --train-limit 1024 --test-limit 256 --no-plot`
- 正常跑（默认超参）
  - `python Compare_RNN/task/classification/row_mnist.py --epochs 50 --scan-epochs 5 --batch-size 64 --hidden 128 --seed 42 --plot-path plots/rnn_row_mnist`

## MNIST：Pixel（784 steps）

- 快速 smoke
  - `python Compare_RNN/task/classification/pixel_mnist.py --epochs 1 --scan-epochs 1 --train-limit 512 --test-limit 128 --no-plot`
- 正常跑
  - `python Compare_RNN/task/classification/pixel_mnist.py --epochs 50 --scan-epochs 5 --batch-size 64 --hidden 256 --seed 42 --plot-path plots/rnn_pixel_mnist`

- 别名脚本（同配置）
  - `python Compare_RNN/task/classification/pixelmnist.py --epochs 20 --scan-epochs 5 --batch-size 64 --hidden 256 --seed 42 --plot-path plots/rnn_pixelmnist`

## MNIST：Permuted Pixel

- 快速 smoke
  - `python Compare_RNN/task/classification/permute_mnist.py --epochs 1 --scan-epochs 1 --train-limit 512 --test-limit 128 --permute-seed 1234 --no-plot`
- 正常跑
  - `python Compare_RNN/task/classification/permute_mnist.py --epochs 50 --scan-epochs 5 --batch-size 64 --hidden 256 --seed 42 --permute-seed 1234 --plot-path plots/rnn_permute_mnist`

## CIFAR-10：Row-Sequential（按行展开）

- 快速 smoke
  - `python Compare_RNN/task/classification/row_cifar10.py --epochs 1 --scan-epochs 1 --train-limit 1024 --test-limit 256 --no-plot`
- 正常跑
  - `python Compare_RNN/task/classification/row_cifar10.py --epochs 100 --scan-epochs 5 --batch-size 64 --hidden 128 --seed 42 --plot-path plots/rnn_row_cifar10`

## CIFAR-10：Sequential（按像素/patch 序列化，见脚本实现）

- 快速 smoke
  - `python Compare_RNN/task/classification/seq_cifar10.py --epochs 1 --scan-epochs 1 --train-limit 1024 --test-limit 256 --no-plot`
- 正常跑
  - `python Compare_RNN/task/classification/seq_cifar10.py --epochs 100 --scan-epochs 5 --batch-size 64 --hidden 256 --seed 42 --plot-path plots/rnn_seq_cifar10`

## Pixel CIFAR-10
- 快速 smoke
  - `python Compare_RNN/task/classification/pixelcifar10.py --epochs 1 --scan-epochs 1 --train-limit 1024 --test-limit 256 --no-plot`
- 正常跑
  - `python Compare_RNN/task/classification/pixelcifar10.py --epochs 100 --scan-epochs 5 --batch-size 64 --hidden 256 --seed 42 --plot-path plots/rnn_pixelcifar10`

> 区别：`seq_cifar10.py` 每步输入是 3 维（RGB），共 1024 steps；`pixelcifar10.py` 是 1 维像素流（RGB 全展开），共 3072 steps。

## DVS-CIFAR10（事件帧序列）

该任务需要事件数据（可通过 `--dvs-root` 指向原始数据目录，或 `--dvs-npz` 指向预处理后的 `.npz`）。

- 快速 smoke（你已准备好数据时）
  - `python Compare_RNN/task/classification/dvs_cifar10.py --epochs 1 --scan-epochs 1 --train-limit 128 --test-limit 64 --dvs-root <PATH_TO_DVS_CIFAR10> --dvs-time-bins 10 --no-plot`
- 正常跑
  - `python Compare_RNN/task/classification/dvs_cifar10.py --epochs 150 --scan-epochs 10 --batch-size 64 --hidden 192 --seed 42 --dvs-root <PATH_TO_DVS_CIFAR10> --plot-path plots/rnn_dvs_cifar10`

## SHD（Spiking Heidelberg Digits）

数据来源同上：`--shd-root` 或 `--shd-npz`。

- 快速 smoke
  - `python Compare_RNN/task/classification/shd.py --epochs 1 --scan-epochs 1 --train-limit 256 --test-limit 128 --shd-root <PATH_TO_SHD> --shd-time-bins 100 --no-plot`
- 正常跑
  - `python Compare_RNN/task/classification/shd.py --epochs 80 --scan-epochs 10 --batch-size 64 --hidden 256 --seed 42 --shd-root <PATH_TO_SHD> --plot-path plots/rnn_shd`

## UCI HAR（Human Activity Recognition）

支持 `--har-root/--har-npz` 指定数据位置（也可能在首次运行时自动下载并缓存，具体见 `sequence_utils.py`）。

- 快速 smoke
  - `python Compare_RNN/task/classification/uci_har.py --epochs 1 --scan-epochs 1 --train-limit 512 --test-limit 256 --no-plot`
- 正常跑
  - `python Compare_RNN/task/classification/uci_har.py --epochs 50 --scan-epochs 5 --batch-size 64 --hidden 128 --seed 42 --plot-path plots/rnn_uci_har`

## 单方法对照脚本

### BPTT-only（Row MNIST）

- 快速 smoke
  - `python Compare_RNN/task/classification/row_mnist_bptt_only.py --epochs 1 --train-limit 1024 --test-limit 256 --no-plot`
- 正常跑（固定 gain 的 BPTT 对照）
  - `python Compare_RNN/task/classification/row_mnist_bptt_only.py --epochs 40 --batch-size 64 --hidden 128 --seed 42 --gain 0.533 --plot-path plots/rnn_row_mnist_bptt_only`

### Strict FPTT-only（Row MNIST）

- 快速 smoke
  - `python Compare_RNN/task/classification/fptt_only_mnist.py --epochs 1 --train-limit 1024 --test-limit 256 --no-plot`
- 正常跑（固定 gain 的 FPTT 对照）
  - `python Compare_RNN/task/classification/fptt_only_mnist.py --epochs 40 --batch-size 64 --hidden 128 --seed 42 --gain 0.533 --parts 10 --clip 1.0 --alpha 0.1 --beta 0.5 --rho 0.0 --lmbda 1.0 --oracle-momentum 1.0 --warmup-epochs 20 --plot-path plots/rnn_row_mnist_fptt_only`
