# SSIM功能快速参考

## 一句话总结

现在可以选择使用 **SSIM（快速）** 或 **梯度一致性（精确）** 来计算特征一致性。

---

## 快速切换

### 使用梯度一致性（默认）
```python
cps_defense(..., compute_gradients=True, use_ssim=False)
```

### 使用SSIM
```python
cps_defense(..., compute_gradients=True, use_ssim=True)
```

---

## 如何判断正在使用哪种方法？

查看日志输出：

```
✅ 使用梯度一致性：
[MDAG] 【使用梯度一致性方法】进行特征一致性计算
[CPS] 使用梯度一致性方法

✅ 使用SSIM：
[MDAG] 【使用SSIM方法】进行特征一致性计算
[CPS] 使用SSIM方法计算特征一致性
```

---

## 什么时候用哪个？

| 场景 | 推荐方法 | 原因 |
|-----|---------|------|
| GPU资源充足，追求最高精度 | 梯度一致性 | 考虑因果关系 |
| GPU资源有限，需要快速推理 | SSIM | 速度快，内存低 |
| 实时应用 | SSIM | 计算效率高 |
| 研究/对比实验 | 都试试 | 对比效果 |

---

## 性能对比

| 指标 | 梯度一致性 | SSIM |
|-----|-----------|------|
| 速度 | ⭐ | ⭐⭐⭐ |
| 内存 | 高 | 低 |
| 精度 | ⭐⭐⭐ | ⭐⭐ |

---

## 参数详解

```python
def cps_defense(
    ...,
    compute_gradients=False,  # True才会计算一致性
    use_ssim=False,          # True=SSIM, False=梯度一致性
    ...
):
```

⚠️ **重要**：`compute_gradients`必须为`True`，`use_ssim`才有效！

---

## 命令行使用

```bash
# 梯度一致性
python script.py --compute_gradients

# SSIM
python script.py --compute_gradients --use_ssim
```

---

## 完整示例

```python
from defense.cps_defense import cps_defense

# SSIM示例（推荐用于实时场景）
pred_box, pred_score, gt_box, cps_score, defense_info = cps_defense(
    batch_data=batch_data,
    model=model,
    dataset=dataset,
    perturbation=perturbation,
    attacker_idx=1,
    sampling_budget=10,
    lambda1=1.0,
    lambda2=1.0,  # SSIM权重
    lambda3=1.0,
    tau=0.68,
    compute_gradients=True,  # ✅ 开启
    use_ssim=True,           # ✅ 使用SSIM
    use_mdag=True
)

print(f"使用方法: {'SSIM' if use_ssim else '梯度一致性'}")
print(f"CPS分数: {cps_score:.4f}")
print(f"良性车辆: {defense_info['benign_agents']}")
```

---

## 故障排查

### 问题1：日志中没有看到方法标识

**原因**: `compute_gradients=False`

**解决**: 设置 `compute_gradients=True`

### 问题2：SSIM和梯度一致性结果差异大

**正常现象**: 两种方法原理不同，结果可能有差异。建议根据实际效果选择。

### 问题3：GPU内存不足

**解决**: 使用SSIM方法 (`use_ssim=True`)

---

## 更多信息

- 📖 详细指南：`SSIM_USAGE_GUIDE.md`
- 💻 代码示例：`example_ssim_usage.py`
- 📝 修改总结：`SSIM_MODIFICATION_SUMMARY.md`
- 🔧 主代码：`cps_defense.py`

---

## 代码位置

### 核心函数

1. **SSIM计算**: `cps_defense.py` - `compute_ssim()` (Line 134-192)
2. **梯度一致性**: `cps_defense.py` - `compute_gradient_consistency()` (Line 55-131)
3. **选择逻辑**: `cps_defense.py` - `compute_group_cps()` (Line 284-299)

### 调用位置

- `compute_group_cps()` - Line 286-295
- `recursive_group_screening()` - 传递参数
- `cps_defense()` - MDAG分支 (Line 527-540)
- `cps_defense()` - RoboSAC分支 (Line 638-645)

---

**最后更新**: 2025-12-10

