# Compare_CNN 中文说明

## 目标与范围
- Compare_CNN 聚焦“卷积编码 + 卷积RNN”结构上的生物可解释学习规则对比。
- 对比算法包含：Local Rule、BPTT/TBPTT、E-Prop、Strict FPTT（分类任务为主）。
- 时间步并非输入序列本身，而是同一张图像经过编码后在RNN中的“迭代步”。

## 目录结构速览
- `task/common/conv_core.py`：核心引擎（数据加载、模型、训练/评估、Lyapunov 扫描、绘图）。
- `task/classification/*.py`：图像分类任务脚本（MNIST/CIFAR10/DVS-CIFAR10）。
- `task/classification/sequence_utils.py`：分类任务公共入口，重导出 `conv_core.py` 的函数。
- `task/regression/movie_clip.py`：合成视频片段回放任务（回归）。
- `task/regression/sequence_utils.py`：回归任务入口，实际调用 `Compare_RNN/task/common/sequence_core.py`。

## 数据表示与时间步
- 图像输入：`train_images/test_images` 为 `float32`，形状 `(N, C, H, W)`。
- 分类目标：`build_repeated_targets` 将类别 one-hot 复制到每个时间步，形状 `(N, classes, steps)`。
- `steps` 是RNN迭代步数，与图像本身的维度无直接关系。
- DVS-CIFAR10：
  - 原始数据 `(N, T, H, W)` 或 `(N, T, H, W, C)`。
  - `_dvs_to_channels` 会将时间/极性合并到通道维，变成 `(N, T)` 或 `(N, T*C)` 个通道。

## 核心引擎：`task/common/conv_core.py`

### 1) 通用工具与时间权重
- `resolve_device` / `to_tensor`：统一张量设备和dtype。
- `iterate_minibatches` / `split_train_val`：批次迭代与验证集切分。
- `build_time_weights` / `build_label_step_weights`：
  - `time_weighting` 控制每一步损失权重（`none/final/late`）。
  - `step_labels=fptt` 时使用“替代标签”权重策略。

### 2) 数据加载
- `load_mnist_images` / `load_fashion_mnist_images`：MNIST/FashionMNIST（优先本地 npz，失败时用 torchvision/tensorflow）。
- `load_permuted_mnist_images`：先读 MNIST，再做固定像素置换。
- `load_cifar10_images`：CIFAR-10（torchvision/tensorflow）。
- `load_dvs_cifar10_images`：
  - 支持 `--dvs-npz` 指定预处理文件。
  - 自动下载依赖 `tonic` + `aedat`。

### 3) 模型实现
- `SimpleCNNEncoder`：两层 `Conv2d + ReLU` 的轻量编码器。
- `TorchLocalRuleConvRNN`：
  - 逐步在线更新（无BPTT）。
  - `enable_fptt_surrogates` 启用 FPTT 软标签（`Q_t`）。
  - 可选训练编码器（`--train-encoder/--freeze-encoder`）。
- `TorchEPropConvRNN`：
  - 显式维护 eligibility traces。
  - `feedback=random/symmetric` 控制反馈矩阵。
- `TorchBPTTConvRNN`：
  - 标准 BPTT，可选 `tbptt_steps` 做截断。
  - `time_normalization` 控制损失按步归一化方式。
- `StrictFPTTConvClassifier`：
  - 分块序列（`parts`）+ 正则项 `FPTTRegularizer`。
  - `OracleBufferStore` 维护类条件的“oracle”分布。

### 4) 训练与评估
- `train_batches`：按 epoch 迭代训练；FPTT 软标签在每轮内累计后更新。
- `evaluate_classifier_final_step`：只用最后一步输出评估准确率与CE损失。
- `scan_gains_classification`：扫描增益并可计算 Lyapunov 指标。
- `run_classification_task`：总控流程（扫描 + 训练 + 评估 + 绘图）。

## 任务脚本（分类）
- `task/classification/pixel_mnist.py`：MNIST（像素别名）分类；主要控制 `--steps/--enc-channels/--step-labels`。
- `task/classification/row_mnist.py`：MNIST（行别名）分类；流程与 pixel 版本相同。
- `task/classification/permute_mnist.py`：MNIST 固定置换后分类。
- `task/classification/fashion_mnist.py`：Fashion-MNIST 分类。
- `task/classification/seq_cifar10.py`：CIFAR-10 静态图像分类。
- `task/classification/dvs_cifar10.py`：DVS-CIFAR10 分类（支持 `--dvs-npz` / `--dvs-root` / `--dvs-time-bins`）。
- `task/classification/fptt_only_mnist.py`：
  - 只训练 Strict FPTT 单模型，不做对比组。
  - 直接调用 `StrictFPTTConvClassifier` 和 `OracleBufferStore`。
- `task/classification/sequence_utils.py`：分类公共入口与数据加载重导出。

## 任务脚本（回归）
- `task/regression/movie_clip.py`：
  - 生成“运动小球”视频片段，目标是预测下一帧。
  - 通过 `run_regression_task` 调用 RNN 引擎（在 Compare_RNN）。
  - 支持 `--pred-mode` / `--pred-warmup` / `--eval-mode` 等评估方式。
- `task/regression/sequence_utils.py`：
  - 将 `Compare_RNN/task` 加入 `sys.path`。
  - 复用 `Compare_RNN/task/common/sequence_core.py` 的回归流程。

## 输出与绘图
- `--plot` 时在 `plots/` 目录下写入：
  - 指标曲线、Lyapunov 曲线、运行时统计等。
- `save_results_summary` 生成 `summary.json` 与 `summary.csv`。

## 默认运行方式（不加 `--`）
- 直接运行脚本即使用默认参数，例如：`python Compare_CNN/task/classification/pixel_mnist.py`。
- 每个脚本的默认值都写在 `argparse` 里，未传入 `--xxx` 时使用默认值。
- 分类脚本的常见默认行为：
  - `--step-labels final`（不启用 FPTT 软标签）。
  - `--time-weighting none`（不对时间步加权）。
  - `--no-eprop` 未启用（默认会加入 E-Prop 对照组）。
  - `--no-plot` 未启用（默认会画图并写入 `plots/`）。
  - `--train-encoder` 默认启用（脚本中 `set_defaults(train_encoder=True)`）。
- 训练轮数/隐藏维度/扫描轮数等具体默认值由各任务脚本决定。

## 常用参数（分类脚本通用）
- `--epochs` / `--scan-epochs`：训练与增益扫描轮数。
- `--steps`：RNN迭代步数。
- `--time-weighting {none,final,late}`：每步损失权重策略。
- `--step-labels {final,fptt}`：是否启用 FPTT 软标签。
- `--train-encoder` / `--freeze-encoder`：是否更新 CNN 编码器。
- `--no-eprop`：跳过 E-Prop 对照组。
- `--tbptt-short` / `--tbptt-long`：TBPTT 的截断长度设置。
- `--no-plot`：关闭绘图与结果写入。

## 运行示例
```bash
python Compare_CNN/task/classification/pixel_mnist.py --no-plot
python Compare_CNN/task/classification/dvs_cifar10.py --dvs-time-bins 10 --no-plot
python Compare_CNN/task/classification/fptt_only_mnist.py --gain 1.9 --no-plot
python Compare_CNN/task/regression/movie_clip.py --pred-mode rollout --no-plot
```

## 任务脚本命令索引（逐任务更详细）

已将 `Compare_CNN/task` 下每个任务的“可复制终端指令”按目录拆分写入对应 README：

- `Compare_CNN/task/README.md`
- `Compare_CNN/task/classification/README.md`
- `Compare_CNN/task/regression/README.md`
