# cltag 使用说明

## 目录结构

```
cltag/
├── datasets/           # 数据集加载器
│   ├── __init__.py
│   ├── ade20k_dataset.py
│   └── voc2012_dataset.py
├── evaluation/         # 评估脚本
│   ├── __init__.py
│   ├── test_zeroshot_ade20k.py
│   ├── test_zeroshot_voc.py
│   ├── test_zeroshot_voc_split.py
│   └── quick_zeroshot_test.py
├── models/            # 模型相关
│   ├── __init__.py
│   └── inference_ram_plus_clean.py
├── training/          # 训练脚本（可自行扩展）
│   └── __init__.py
├── analysis/          # 分析工具
│   ├── __init__.py
│   ├── analyze_tag_mapping.py
│   ├── enhanced_tag_mapping.py
│   ├── improved_mapping.py
│   └── ram_tag_analysis.json
└── docs/              # 文档
    ├── README.md
    └── ZEROSHOT_EVALUATION.md
```

## 使用方法

确保在 `cltag` 目录下运行所有脚本：

```bash
cd /home/gyf/iclr/recognize-anything/cltag
```

### 1. 零样本评估

#### VOC2012 评估
```bash
python evaluation/test_zeroshot_voc.py \
  --pretrained /home/gyf/iclr/recognize-anything/pretrained/ram_plus_swin_large_14m.pth \
  --voc-data-root /home/gyf/iclr/recognize-anything/VOC2012 \
  --split val \
  --device cuda:1
```

#### ADE20K 评估
```bash
python evaluation/test_zeroshot_ade20k.py \
  --pretrained /home/gyf/iclr/recognize-anything/pretrained/ram_plus_swin_large_14m.pth \
  --ade20k-data-root /home/gyf/iclr/recognize-anything/ADE20K \
  --split val \
  --device cuda:1
```

### 2. 分析工具

```bash
python analysis/analyze_tag_mapping.py
```

## 注意事项

1. 所有脚本都已更新导入路径，必须从 `cltag` 根目录运行
2. 确保激活正确的conda环境 (recog)
3. 所有子目录都有 `__init__.py` 文件，支持模块化导入
4. 文档位于 `docs/` 目录下

## 导入修复

移动文件后，所有导入都已修复：
- `from voc2012_dataset import ...` → `from datasets.voc2012_dataset import ...`
- `from ade20k_dataset import ...` → `from datasets.ade20k_dataset import ...`
每个脚本都添加了正确的 `sys.path` 设置来支持相对导入。
