Project Icon

DN-DETR

创新查询去噪技术加速目标检测训练

DN-DETR通过创新的查询去噪技术加速DETR目标检测模型训练。该方法仅需50%训练周期即可达到基线模型性能,大幅提高训练效率。项目开源了DN-DETR、DN-Deformable-DETR等多个模型实现,并提供详细的模型库、使用指南和安装说明,便于研究者复现结果或将去噪训练应用于其他模型。

DN-DETR:通过引入查询去噪加速DETR训练

作者:冯力*张浩*刘世龙郭健倪明选张磊

本仓库是DN-DETR的官方实现。该论文被CVPR 2022接收(得分112口头报告)。代码现已开放。 [CVPR论文链接] [扩展版论文链接] [中文解读]

新闻

[2022/12]:我们在arxiv上发布了DN-DETR的扩展版,这是论文链接!我们将去噪训练应用于基于CNN的模型Faster R-CNN、分割模型Mask2Former以及其他类DETR模型如Anchor DETR和DETR,以提高这些模型的性能。

[2022/12]:Mask DINO的代码已开放!Mask DINO在COCO数据集上使用ResNet-50和SwinL骨干网络(无额外检测数据)分别达到了51.759.0的框AP,在相同设置下超越了DINO!

[2022/11]:基于DN-DETR的DINO实现已在本仓库中发布。感谢@Vallum!这个优化版本在ResNet-50下能在36轮训练中达到50.8 ~ 51.0 AP

[2022/9]:我们发布了一个工具箱detrex,提供了许多最先进的基于Transformer的检测算法。其中包括性能更好的DN-DETR。欢迎使用!

[2022/7]:DINO的代码已在这里开放!

[2022/6]:我们发布了一个统一的检测和分割模型Mask DINO,在三个分割任务上都取得了最佳结果(COCO实例分割榜单54.5 AP,COCO全景分割榜单59.4 PQ,以及ADE20K语义分割榜单60.8 mIoU)!代码将在这里开放。

[2022/5]:我们的代码已开放!使用ResNet-50在COCO上达到了更好的性能49.5AP。

[2022/4]:DAB-DETR的代码已在这里开放。

[2022/3]:我们创建了一个仓库Awesome Detection Transformer,展示了关于用于检测和分割的transformer的论文。欢迎关注!

[2022/3]:DN-DETR被选为CVPR2022的口头报告

[2022/3]:我们发布了另一项工作DINO:DETR with Improved DeNoising Anchor Boxes for End-to-End Object Detection,首次将DETR类模型确立为榜单上的SOTA模型。同样基于DN。代码将在这里开放。

简介

  1. 我们提出了一种新颖的去噪训练方法,以加速DETR训练,并对DETR类方法收敛缓慢问题提供了深入理解。
  2. DN仅是一种训练方法,可插入许多DETR类模型甚至传统模型中以提升性能。
  3. DN-DETR在使用ResNet-50骨干网络进行12和50轮训练时,分别达到了43.448.6的AP。与相同设置下的基线模型相比,DN-DETR仅用**50%**的训练轮数就达到了可比的性能。
  4. 我们优化后的模型取得了更好的性能。DN-Deformable-DETR使用ResNet-50骨干网络达到了49.5的AP。

模型

我们在DAB-DETR的基础上添加了去噪部分以加速训练收敛。这只增加了最少的计算量,并在推理时会被移除。 DN-DETR 我们进行了广泛的实验来验证我们的去噪训练的有效性,例如收敛曲线比较。您可以参考我们的论文获取更多实验结果。 DN-DETR

模型库

我们提供了DAB-DETRDAB-Deformable-DETR(仅可变形编码器)DAB-Deformable-DETR下的模型(参见DAB-DETR的代码论文了解更多详情)。

您也可以参考我们的

[Google Drive模型库]

[百度网盘模型库](提取码niet)。

50轮训练设置

名称骨干网络边界框AP日志/配置/检查点我们的论文中的位置
0DN-DETR-R50R5044.41谷歌云盘 / 百度网盘 表1
2DN-DETR-R50-DC5R5046.3谷歌云盘 / 百度网盘 表1
5DN-DAB-可变形-DETR
(仅可变形编码器)3
R5048.6谷歌云盘 / 百度网盘 表3
6DN-DAB-可变形-DETR-R50-v24R5049.5(24轮训练为48.4)谷歌云盘 / 百度网盘 优化实现,在编码器和解码器中都使用可变形注意力。更多详情请参见DAB-DETR
### 12轮训练设置
名称骨干网络边界框AP日志/配置/检查点我们的论文中的位置
1DN-DAB-DETR-R50-DC5(3模式)2R5041.7谷歌云盘 / 百度网盘 表2
4DN-DAB-DETR-R101-DC5(3模式)2R10142.8谷歌云盘 / 百度网盘 表2
5DN-DAB-Deformable-DETR
(仅可变形编码器)3
R5043.4谷歌云盘 / 百度网盘 表2
5DN-DAB-Deformable-DETR
(仅可变形编码器)3
R10144.1谷歌云盘 / 百度网盘 表2

注意:

  • 1:由于我们优化了代码,结果相比论文中报告的有所提升(从44.144.4)。我们没有重新运行其他模型,所以你可能会获得比我们论文中报告的更好的性能
  • 2:标记为(3模式)的模型使用多种模式嵌入进行训练(更多详情请参考Anchor DETR或DAB-DETR)。
  • 3:此模型基于DAB-Deformable-DETR(仅可变形编码器),是DAB-DETR的多尺度版本。由于仅在编码器中使用可变形注意力,需要16个GPU进行训练。
  • 4:此模型基于DAB-Deformable-DETR,是一个优化的可变形DETR实现。更多详情请参见DAB-DETR我们鼓励你使用这个可变形版本,因为它在编码器和解码器中都使用了可变形注意力,更加轻量级(即可以用4/8个A100 GPU训练)并且收敛更快(即在24轮内达到48.4,与50轮的DAB-Deformable-DETR相当)。

使用方法

如何在你自己的模型中使用去噪训练

我们的代码大部分遵循DAB-DETR,并添加了用于去噪训练的额外组件,这些组件封装在dn_components.py文件中。主要包括3个函数:prepare_for_dndn_post_proces(前两个用于在检测前向函数中处理去噪部分)和compute_dn_loss(用于计算去噪损失)。你可以导入这些函数并将它们添加到你自己的检测模型中。 如果你想在自己的检测模型中使用它,你也可以比较DN-DETR和DAB-DETR,看看这些函数是如何添加的。

我们也鼓励你将其应用到其他类DETR模型甚至传统检测模型中,并在这个仓库中更新结果。

安装

我们使用DAB-DETR项目作为我们的代码基础,因此我们的DN-DETR不需要额外的依赖。对于DN-Deformable-DETR,你需要手动编译可变形注意力算子。

我们在python=3.7.3,pytorch=1.9.0,cuda=11.1环境下测试了我们的模型。其他版本可能也适用。

  1. 克隆此仓库
git clone https://github.com/IDEA-Research/DN-DETR.git
cd DN-DETR
  1. 安装Pytorch和torchvision

按照https://pytorch.org/get-started/locally/的说明进行操作。

# 示例:
conda install -c pytorch pytorch torchvision
  1. 安装其他所需包
pip install -r requirements.txt
  1. 编译CUDA算子
cd models/dn_dab_deformable_detr/ops
python setup.py build install
# 单元测试(应该看到所有检查都为True)
python test.py
cd ../../..

数据

请下载COCO 2017数据集并按以下方式组织:

COCODIR/
  ├── train2017/
  ├── val2017/
  └── annotations/
  	├── instances_train2017.json
  	└── instances_val2017.json

运行

我们以标准的DN-DETR-R50DN-Deformable-DETR-R50为例进行训练和评估。

评估我们预训练的模型

此链接下载我们的DN-DETR-R50模型检查点,并执行以下命令。 你可以预期最终AP约为44.4

对于我们的DN-DAB-Deformable-DETR_Deformable_Encoder_Only(在此下载)。预期的最终AP为48.6

对于我们的DN-DAB-Deformable-DETR(在此下载),预期的最终AP为49.5

# 对于dn_detr:44.1 AP;优化结果为44.4AP
python main.py -m dn_dab_detr \
  --output_dir logs/dn_DABDETR/R50 \
  --batch_size 1 \
  --coco_path /path/to/your/COCODIR \ # 替换为你的COCO路径
  --resume /path/to/our/checkpoint \ # 替换为你的检查点路径
  --use_dn \
  --eval

# 对于dn_deformable_detr:49.5 AP
python main.py -m dn_deformable_detr \
  --output_dir logs/dab_deformable_detr/R50 \
  --batch_size 1 \
  --coco_path /path/to/your/COCODIR \ # 替换为你的COCO路径
  --resume /path/to/our/checkpoint \ # 替换为你的检查点路径
  --transformer_activation relu \
  --use_dn \
  --eval
  
# 对于dn_deformable_detr_deformable_encoder_only:48.6 AP
python main.py -m dn_dab_deformable_detr_deformable_encoder_only 
  --output_dir logs/dab_deformable_detr/R50 \
  --batch_size 1 \
  --coco_path /path/to/your/COCODIR \ # 替换为你的COCO路径
  --resume /path/to/our/checkpoint \ # 替换为你的检查点路径
  --transformer_activation relu \
  --num_patterns 3 \  # 使用3个模式嵌入
  --use_dn  \
  --eval

训练你自己的模型

同样,你也可以在单个进程上训练我们的模型:

# 对于dn_detr
python main.py -m dn_dab_detr \
  --output_dir logs/dn_DABDETR/R50 \
  --batch_size 1 \
  --epochs 50 \
  --lr_drop 40 \
  --coco_path /path/to/your/COCODIR  # 替换为你的COCO路径
  --use_dn

分布式运行

然而,由于训练耗时较长,我们建议在多设备上训练模型。

如果你计划在使用Slurm的集群上训练模型,这里是一个训练命令示例:

# 对于dn_detr:44.4 AP
python run_with_submitit.py \
  --timeout 3000 \
  --job_name DNDETR \
  --coco_path /path/to/your/COCODIR \
  -m dn_dab_detr \
  --job_dir logs/dn_DABDETR/R50_%j \
  --batch_size 2 \
  --ngpus 8 \
  --nodes 1 \
  --epochs 50 \
  --lr_drop 40 \
  --use_dn

# 对于dn_dab_deformable_detr:49.5 AP
python run_with_submitit.py \
  --timeout 3000 \
  --job_name dn_dab_deformable_detr \
  --coco_path /path/to/your/COCODIR \
  -m dab_deformable_detr \
  --transformer_activation relu \
  --job_dir logs/dn_dab_deformable_detr/R50_%j \
  --batch_size 2 \
  --ngpus 8 \
  --nodes 1 \
  --epochs 50 \
  --lr_drop 40 \
  --use_dn

# 对于dn_dab_deformable_detr_deformable_encoder_only:48.6 AP
python run_with_submitit.py \
  --timeout 3000 \
  --job_name dn_dab_deformable_detr_deformable_encoder_only \
  --coco_path /path/to/your/COCODIR \
  -m dn_dab_deformable_detr_deformable_encoder_only \
  --transformer_activation relu \
  --job_dir logs/dn_dab_deformable_detr/R50_%j \
  --num_patterns 3 \ 
  --batch_size 1 \
  --ngpus 8 \
  --nodes 2 \
  --epochs 50 \
  --lr_drop 40 \
  --use_dn

如果你想训练我们的DC版本或多模式版本,添加

--dilation  # 对于DC版本

--num_patterns 3  # 对于3个模式

但是,这需要额外的训练资源和内存,即使用16个GPU。

最终的AP应该与我们的相似或更好,因为我们优化后的结果比论文中报告的性能更好(例如,我们报告DN-DETR44.1,但我们的新结果可以达到44.4。 如果你得到更好的结果,不要感到惊讶!)。

我们的训练设置与DAB-DETR相同,但添加了一个参数--use_dn,你也可以参考DAB-DETR

注意:

  • 结果对批量大小敏感。我们默认使用16(每个GPU 2张图像 x 8个GPU)。

或者在单个节点上使用多进程运行:

# 对于dn_dab_detr:44.4 AP
python -m torch.distributed.launch --nproc_per_node=8 \
  main.py -m dn_dab_detr \
  --output_dir logs/dn_DABDETR/R50 \
  --batch_size 2 \
  --epochs 50 \
  --lr_drop 40 \
  --coco_path /path/to/your/COCODIR \
  --use_dn
# 对于dn_deformable_detr: 49.5 AP
python -m torch.distributed.launch --nproc_per_node=8 \
  main.py -m dn_dab_deformable_detr \
  --output_dir logs/dn_dab_deformable_detr/R50 \
  --batch_size 2 \
  --epochs 50 \
  --lr_drop 40 \
  --transformer_activation relu \
  --coco_path /path/to/your/COCODIR \
  --use_dn

相关链接

我们的工作基于DAB-DETR。我们还发布了另一个基于DN-DETR和DAB-DETR的SOAT检测模型DINO

  • DINO: 使用改进的去噪锚框的端到端目标检测DETR。 Hao Zhang*, Feng Li*, Shilong Liu*, Lei Zhang, Hang Su, Jun Zhu, Lionel M. Ni, Heung-Yeung Shum。 arxiv 2022。 [论文] [代码]

  • DAB-DETR: 动态锚框是DETR更好的查询。 Shilong Liu, Feng Li, Hao Zhang, Xiao Yang, Xianbiao Qi, Hang Su, Jun Zhu, Lei Zhang。 国际学习表示会议(ICLR)2022。 [论文] [代码]

许可证

DN-DETR在Apache 2.0许可下发布。更多信息请参见LICENSE文件。

版权所有 (c) IDEA。保留所有权利。

根据Apache许可证2.0版("许可证")获得许可;除非符合许可证,否则您不得使用这些文件。您可以在http://www.apache.org/licenses/LICENSE-2.0 获取许可证副本。

除非适用法律要求或书面同意,根据许可证分发的软件是基于"按原样"分发的,不附带任何明示或暗示的担保或条件。请参阅许可证以了解许可证下的特定语言和限制。

引用

如果您发现我们的工作对您的研究有帮助,请考虑引用以下BibTeX条目。

@inproceedings{li2022dn,
  title={Dn-detr: 通过引入查询去噪加速detr训练},
  author={Li, Feng and Zhang, Hao and Liu, Shilong and Guo, Jian and Ni, Lionel M and Zhang, Lei},
  booktitle={计算机视觉与模式识别IEEE/CVF会议论文集},
  pages={13619--13627},
  year={2022}
}
项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号