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

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

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

- `--epochs/--scan-epochs/--seed`
- `--batch-size/--hidden`
- `--enc-channels`：编码器通道数列表（字符串，如 `16,32`）
- `--steps`：时间步数（ConvRNN 展开步数）
- `--kernel-size`：卷积核大小
- `--train-encoder/--freeze-encoder`：是否训练编码器
- `--train-limit/--test-limit`：子采样（便于 smoke test）
- `--time-weighting {none,final,late}`
- `--step-labels {final,fptt}`
- `--tbptt-short/--tbptt-long`
- `--no-eprop` / `--no-plot` / `--plot-path`

## MNIST（Static Image）：Row alias

- 快速 smoke
  - `python Compare_CNN/task/classification/row_mnist.py --epochs 1 --scan-epochs 1 --train-limit 1024 --test-limit 256 --no-plot`
- 正常跑
  - `python Compare_CNN/task/classification/row_mnist.py --epochs 40 --scan-epochs 5 --batch-size 64 --hidden 128 --enc-channels 16,32 --steps 12 --kernel-size 3 --seed 42 --plot-path plots/cnn_row_mnist`

## MNIST（Static Image）：Pixel alias

- 快速 smoke
  - `python Compare_CNN/task/classification/pixel_mnist.py --epochs 1 --scan-epochs 1 --train-limit 1024 --test-limit 256 --no-plot`
- 正常跑
  - `python Compare_CNN/task/classification/pixel_mnist.py --epochs 30 --scan-epochs 5 --batch-size 64 --hidden 128 --enc-channels 16,32 --steps 12 --kernel-size 3 --seed 42 --plot-path plots/cnn_pixel_mnist`

## Permuted MNIST（Static Image）

- 快速 smoke
  - `python Compare_CNN/task/classification/permute_mnist.py --epochs 1 --scan-epochs 1 --train-limit 1024 --test-limit 256 --permute-seed 1234 --no-plot`
- 正常跑
  - `python Compare_CNN/task/classification/permute_mnist.py --epochs 50 --scan-epochs 5 --batch-size 64 --hidden 128 --enc-channels 16,32 --steps 12 --kernel-size 3 --seed 42 --permute-seed 1234 --plot-path plots/cnn_permute_mnist`

## Fashion MNIST（Static Image）

- 快速 smoke
  - `python Compare_CNN/task/classification/fashion_mnist.py --epochs 1 --scan-epochs 1 --train-limit 1024 --test-limit 256 --no-plot`
- 正常跑
  - `python Compare_CNN/task/classification/fashion_mnist.py --epochs 50 --scan-epochs 5 --batch-size 64 --hidden 128 --enc-channels 16,32 --steps 12 --kernel-size 3 --seed 42 --plot-path plots/cnn_fashion_mnist`

## CIFAR-10（Static Image）

- 快速 smoke
  - `python Compare_CNN/task/classification/seq_cifar10.py --epochs 1 --scan-epochs 1 --train-limit 1024 --test-limit 256 --no-plot`
- 正常跑
  - `python Compare_CNN/task/classification/seq_cifar10.py --epochs 30 --scan-epochs 5 --batch-size 64 --hidden 256 --enc-channels 32,64 --steps 12 --kernel-size 3 --seed 42 --plot-path plots/cnn_seq_cifar10`

## DVS-CIFAR10（事件帧）

通过 `--dvs-root` 指向原始数据目录，或 `--dvs-npz` 指向预处理 `.npz`。

- 注意：全分辨率 DVS-CIFAR10（128x128, time_bins=10, polarity=2）仅 `x_train` 的 float32 就需要约 11 GiB 内存，16GB 机器很容易 OOM。
- 推荐：使用 `--dvs-spatial-downsample 4`（32x32）并指定独立缓存 `--dvs-npz data/dvs_cifar10/dvs_cifar10_ds4.npz`。

- 快速 smoke（你已准备好数据时）
  - `python Compare_CNN/task/classification/dvs_cifar10.py --epochs 1 --scan-epochs 1 --train-limit 128 --test-limit 64 --dvs-root data/dvs_cifar10 --dvs-time-bins 10 --dvs-spatial-downsample 4 --dvs-npz data/dvs_cifar10/dvs_cifar10_ds4.npz --no-plot`
- 正常跑
  - `python Compare_CNN/task/classification/dvs_cifar10.py --epochs 50 --scan-epochs 5 --batch-size 64 --hidden 256 --enc-channels 32,64 --steps 12 --kernel-size 3 --seed 42 --dvs-root data/dvs_cifar10 --dvs-time-bins 10 --dvs-spatial-downsample 4 --dvs-npz data/dvs_cifar10/dvs_cifar10_ds4.npz --plot-path plots/cnn_dvs_cifar10`

## DVS-Gesture（事件帧）

通过 `--gesture-root` 指向原始数据目录，或 `--gesture-npz` 指向预处理 `.npz`。

- 提示：如果遇到内存问题，使用 `--gesture-spatial-downsample 4`（32x32）和/或减小 `--gesture-time-bins`。

- 快速 smoke（你已准备好数据时）
  - `python Compare_CNN/task/classification/dvs_gesture.py --epochs 1 --scan-epochs 1 --train-limit 64 --test-limit 32 --gesture-root data/dvs_gesture --gesture-time-bins 20 --gesture-spatial-downsample 4 --gesture-npz data/dvs_gesture/dvs_gesture_ds4.npz --no-plot`
- 正常跑
  - `python Compare_CNN/task/classification/dvs_gesture.py --epochs 100 --scan-epochs 5 --batch-size 64 --hidden 256 --enc-channels 32,64 --steps 12 --kernel-size 3 --seed 42 --gesture-root data/dvs_gesture --gesture-time-bins 20 --gesture-spatial-downsample 4 --gesture-npz data/dvs_gesture/dvs_gesture_ds4.npz --plot-path plots/cnn_dvs_gesture`

## 单方法对照：Strict FPTT-only（Row MNIST）

- 快速 smoke
  - `python Compare_CNN/task/classification/fptt_only_mnist.py --epochs 1 --train-limit 1024 --test-limit 256 --no-plot`
- 正常跑（固定 gain 的 FPTT 对照）
  - `python Compare_CNN/task/classification/fptt_only_mnist.py --epochs 40 --batch-size 64 --hidden 128 --enc-channels 16,32 --steps 12 --kernel-size 3 --seed 42 --gain 1.986 --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/cnn_row_mnist_fptt_only`
