# 为什么 Ego 必须在两组里？MDAG 分组逻辑详解

## 你的理解 vs 实际逻辑

### 你的理解（部分正确）
> "先进行有策略的分组，然后将每组和 ego 进行比较，比较的值大于阈值就是该组里有恶意"

### 实际逻辑（更准确）
1. **先进行有策略的分组**（基于视角差异度）
2. **每个组都包含 ego**（ego 是可信的基准）
3. **对每个组内的特征进行融合**（包括 ego 的特征）
4. **将融合后的特征与 ego-only 的参考特征进行比较**
5. **CPS 分数高表示可疑，低表示可信**

## 详细流程

### Step 1: 建立参考基准
```python
# 第 142-143 行
base_voxel_dict = _prepare_subset_features_with_grad(cav_content, [0], model, device)
reference_feature = base_voxel_dict['spatial_features'][0]  # 只有 ego 的特征
```
**作用**: 创建一个"纯净"的参考特征，只包含 ego 自己的观测。

### Step 2: MDAG 分组
```python
# 第 170-183 行
group1 = [0, 2]  # Ego + 车辆2（视角差异最大）
group2 = [0, 1]  # Ego + 车辆1（视角差异较小）
```

**为什么 ego 必须在两组里？**

#### 原因 1: 融合需要 ego 的特征
```python
# 第 222 行
fused_feature = voxel_feature_dict['spatial_features'].mean(dim=0)
```
这行代码对组内**所有车辆的特征**进行平均融合。如果组里没有 ego，就无法融合 ego 的特征。

#### 原因 2: Ego 是可信的基准
- Ego 是防御者自己，是**唯一可信的车辆**
- 其他车辆都可能是攻击者
- 融合时必须有 ego 参与，才能"稀释"恶意特征的影响

#### 原因 3: 比较的是"融合特征 vs ego-only 特征"
```python
# 第 225 行
similarity_score = compute_similarity_score(fused_feature, reference_feature)
#                                 ↑              ↑
#                         融合后的特征      ego-only 的参考特征
```

**关键理解**：
- `fused_feature`: 组内所有车辆（包括 ego）的特征融合
- `reference_feature`: 只有 ego 的特征（纯净基准）
- 如果融合特征与 ego-only 特征相似 → 说明组内车辆可信
- 如果融合特征与 ego-only 特征差异大 → 说明组内可能有恶意车辆

### Step 3: 计算 CPS 分数
```python
# 第 246-249 行
cps_score = (
    lambda1 * (1.0 - similarity_score) +      # 相似度越低，CPS 越高
    lambda2 * (1.0 - gradient_consistency) + # 梯度一致性越低，CPS 越高
    lambda3 * energy_shift_normalized         # 能量偏移越大，CPS 越高
)
```

**CPS 分数的含义**：
- **CPS = 0.0**: 融合特征与 ego-only 特征完全相同（最可信）
- **CPS < tau**: 融合特征与 ego-only 特征相似（可信）
- **CPS > tau**: 融合特征与 ego-only 特征差异大（可疑，可能有恶意车辆）

## 可视化示例

### 场景：3 辆车（Ego, Vehicle1, Vehicle2）

```
┌─────────────────────────────────────────────────────────┐
│ Step 1: 建立参考基准                                      │
├─────────────────────────────────────────────────────────┤
│ reference_feature = ego_only_feature                     │
│ (只有 ego 的特征，作为"纯净"基准)                         │
└─────────────────────────────────────────────────────────┘

┌─────────────────────────────────────────────────────────┐
│ Step 2: MDAG 分组                                        │
├─────────────────────────────────────────────────────────┤
│ Group 1 (强对抗组): [Ego, Vehicle2]                      │
│   - 视角差异最大（接近 90° 或 180°）                      │
│   - 如果 Vehicle2 是攻击者，融合后会明显偏离 ego         │
│                                                          │
│ Group 2 (弱对抗组): [Ego, Vehicle1]                      │
│   - 视角差异较小（接近 0°）                              │
│   - 如果 Vehicle1 是攻击者，融合后可能不明显             │
└─────────────────────────────────────────────────────────┘

┌─────────────────────────────────────────────────────────┐
│ Step 3: 特征融合                                         │
├─────────────────────────────────────────────────────────┤
│ Group 1 融合:                                             │
│   fused_feature_1 = mean([ego_feature, vehicle2_feature])│
│                                                          │
│ Group 2 融合:                                             │
│   fused_feature_2 = mean([ego_feature, vehicle1_feature])│
└─────────────────────────────────────────────────────────┘

┌─────────────────────────────────────────────────────────┐
│ Step 4: 与参考基准比较                                    │
├─────────────────────────────────────────────────────────┤
│ 比较 1: fused_feature_1 vs reference_feature             │
│   - 如果 Vehicle2 是攻击者                               │
│   - fused_feature_1 会包含恶意特征                        │
│   - 与 reference_feature 差异大 → CPS 高 → 可疑          │
│                                                          │
│ 比较 2: fused_feature_2 vs reference_feature             │
│   - 如果 Vehicle1 是攻击者                               │
│   - fused_feature_2 会包含恶意特征                        │
│   - 与 reference_feature 差异大 → CPS 高 → 可疑          │
└─────────────────────────────────────────────────────────┘

┌─────────────────────────────────────────────────────────┐
│ Step 5: 选择最佳组                                       │
├─────────────────────────────────────────────────────────┤
│ 选择 CPS 分数最低的组（最可信）                           │
│ 如果所有组的 CPS > tau，则使用 ego-only（最安全）        │
└─────────────────────────────────────────────────────────┘
```

## 为什么不能"将每组和 ego 进行比较"？

### 错误理解
```
Group 1 = [Vehicle1, Vehicle2]  # 没有 ego
比较: Group1 的特征 vs ego 的特征
```

### 问题
1. **无法融合**: 如果组里没有 ego，融合时就没有可信的特征参与
2. **比较不公平**: 比较的是"多车融合" vs "单 ego"，维度不匹配
3. **无法稀释**: 如果组里全是可疑车辆，融合后全是恶意特征

### 正确理解
```
Group 1 = [Ego, Vehicle2]  # 包含 ego
融合: mean([ego_feature, vehicle2_feature]) = fused_feature
比较: fused_feature vs ego_only_feature
```

### 优势
1. **有可信基准**: Ego 参与融合，提供可信特征
2. **公平比较**: 都是融合特征，维度一致
3. **能检测恶意**: 如果 Vehicle2 是攻击者，融合特征会偏离 ego-only 特征

## 实际例子

### 场景：Vehicle1 是攻击者

```
┌─────────────────────────────────────────────────────────┐
│ Group 1: [Ego, Vehicle2] (Vehicle2 是正常的)             │
├─────────────────────────────────────────────────────────┤
│ fused_feature_1 = mean([ego_feature, vehicle2_feature])  │
│   ≈ ego_feature (因为 Vehicle2 正常)                     │
│                                                          │
│ CPS_1 = similarity(fused_feature_1, ego_feature)         │
│       = 高相似度 → 低 CPS → 可信 ✓                       │
└─────────────────────────────────────────────────────────┘

┌─────────────────────────────────────────────────────────┐
│ Group 2: [Ego, Vehicle1] (Vehicle1 是攻击者)             │
├─────────────────────────────────────────────────────────┤
│ fused_feature_2 = mean([ego_feature, vehicle1_feature])  │
│   ≠ ego_feature (因为 Vehicle1 是恶意的)                 │
│                                                          │
│ CPS_2 = similarity(fused_feature_2, ego_feature)         │
│       = 低相似度 → 高 CPS → 可疑 ✗                       │
└─────────────────────────────────────────────────────────┘

结果: 选择 Group 1（CPS 更低，更可信）
```

## 总结

### 关键点
1. **Ego 必须在两组里**，因为：
   - 融合需要 ego 的可信特征
   - Ego 是唯一的可信基准
   - 比较的是"融合特征 vs ego-only 特征"

2. **比较逻辑**：
   - 不是"组 vs ego"
   - 而是"融合特征（包含 ego）vs ego-only 特征"

3. **CPS 分数**：
   - 低 CPS = 融合特征与 ego-only 相似 = 可信
   - 高 CPS = 融合特征与 ego-only 差异大 = 可疑

### 你的理解修正
> "先进行有策略的分组（每组包含 ego），然后对每组内的特征进行融合，将融合后的特征与 ego-only 的参考特征进行比较。如果 CPS 分数大于阈值，说明该组里可能有恶意车辆。"

这样理解就完全正确了！🎯


