mmrotate
MMRotate 是一个基于 PyTorch 开发的开源旋转目标检测工具箱,隶属于 OpenMMLab 项目系列。它主要解决传统水平检测框在处理航拍图像、遥感地图或密集排列物体时精度不足的问题,通过引入旋转边界框,能够更精准地定位任意角度的目标。
这款工具非常适合计算机视觉领域的研究人员、算法工程师以及高校开发者使用。无论是希望复现前沿论文成果,还是需要在实际项目中部署高效的检测模型,MMRotate 都能提供强有力的支持。其核心亮点在于灵活 modular(模块化)的设计架构,允许用户像搭积木一样自由组合不同组件来构建新模型。同时,它原生支持三种主流的旋转角度表示方法,有效解决了不同学术标准间的兼容难题。工具箱内不仅集成了多种强基准模型,还收录了包括最新实时检测器 RTMDet 在内的最先进(SOTA)算法,在保持高精度的同时兼顾了推理速度,是进行旋转目标检测研究与开发的理想选择。
使用场景
某遥感测绘团队正利用无人机航拍图像进行港口集装箱与船舶的自动化清点,需精准识别密集排列且任意角度旋转的目标。
没有 mmrotate 时
- 检测框冗余严重:传统水平检测框(Horizontal BBox)无法贴合倾斜物体,导致相邻集装箱的边界框大面积重叠,后续非极大值抑制(NMS)极易误删真实目标。
- 角度适配成本高:面对不同论文中定义的旋转角度表示法(如 OpenCV 定义 vs 长边定义),开发人员需手动编写复杂的坐标转换代码,极易引入几何误差。
- 模型复现困难:缺乏统一的旋转检测基准框架,尝试复现 SOTA 算法时需从零搭建数据加载与损失函数模块,研发周期长达数周。
- 小目标漏检率高:通用检测器未针对航拍图中微小的旋转船只进行优化,在密集场景下漏检率居高不下。
使用 mmrotate 后
- 精准贴合目标:直接调用内置的旋转框检测头,输出带角度参数的五维边界框,完美贴合倾斜集装箱,彻底解决密集遮挡下的误删问题。
- 多表示法无缝切换:利用其模块化设计,一键切换三种主流角度表示方式,无需关心底层数学转换,确保几何计算零误差。
- 快速落地 SOTA 算法:基于预置的 RTMDet 等强基线模型,仅需修改配置文件即可训练高精度旋转检测器,将算法验证周期从数周缩短至数天。
- 专用优化提升精度:借助针对航拍场景优化的数据增强与锚点策略,显著提升了对微小旋转船舶的召回率,清点准确率突破 95%。
mmrotate 通过提供标准化的旋转检测全流程方案,让团队从繁琐的几何算法实现中解放出来,专注于业务场景的精度调优。
运行环境要求
- Linux
需要 NVIDIA GPU,具体显存取决于模型大小和数据集,示例中使用了 RTX 3090,支持 CUDA 10.1+
未说明

快速开始
English | 简体中文
简介
MMRotate 是一个基于 PyTorch 的开源旋转目标检测工具箱。 它是 OpenMMLab 项目的一部分。 主分支支持 PyTorch 1.6+。
主要特性
支持多种角度表示
MMRotate 提供三种主流的角度表示方式,以满足不同论文中的设置需求。
模块化设计
我们将旋转目标检测框架分解为多个组件, 这使得通过组合不同的模块来构建新模型变得更加容易和灵活。
强大的基线与最先进方法
该工具箱提供了旋转目标检测领域的强大基线和最先进方法。
最新动态
亮点
我们很高兴地宣布我们在实时目标识别任务上的最新成果——RTMDet,这是一系列全卷积单阶段检测器。RTMDet 不仅在从小型到超大型的各种模型尺寸上实现了最佳的参数与精度平衡,还在实例分割和旋转目标检测任务上取得了新的最先进性能。详细信息请参阅技术报告。预训练模型可在这里找到。
| 任务 | 数据集 | AP | FPS(TRT FP16 BS1 3090) |
|---|---|---|---|
| 目标检测 | COCO | 52.8 | 322 |
| 实例分割 | COCO | 44.6 | 188 |
| 转角目标检测 | DOTA | 78.9(单尺度)/81.3(多尺度) | 121 |
0.3.4 版本于 2023 年 1 月 2 日发布:
- 修复了与 numpy、scikit-learn 和 e2cnn 的兼容性问题。
- 支持旋转变换中的空补丁。
- 在 RRandomCrop 验证中使用 iof。
有关详细信息和发布历史,请参阅 changelog.md。
安装
MMRotate 依赖于 PyTorch、MMCV 和 MMDetection。 以下是快速安装步骤。 更多详细说明请参阅 安装指南。
conda create -n open-mmlab python=3.7 pytorch==1.7.0 cudatoolkit=10.1 torchvision -c pytorch -y
conda activate open-mmlab
pip install openmim
mim install mmcv-full
mim install mmdet
git clone https://github.com/open-mmlab/mmrotate.git
cd mmrotate
pip install -r requirements/build.txt
pip install -v -e .
开始使用
请参阅 get_started.md 了解 MMRotate 的基本用法。 我们还提供了 colab 教程,以及其他教程,包括:
模型 zoo
结果和模型可在各方法配置目录的 README.md 文件中找到。 汇总信息请参阅 Model Zoo 页面。
支持的算法:
- 旋转 RetinaNet-OBB/HBB (ICCV'2017)
- 旋转 FasterRCNN-OBB (TPAMI'2017)
- 旋转 RepPoints-OBB (ICCV'2019)
- 旋转 FCOS (ICCV'2019)
- RoI Transformer (CVPR'2019)
- Gliding Vertex (TPAMI'2020)
- 旋转 ATSS-OBB (CVPR'2020)
- CSL (ECCV'2020)
- R3Det (AAAI'2021)
- S2A-Net (TGRS'2021)
- ReDet (CVPR'2021)
- Beyond Bounding-Box (CVPR'2021)
- Oriented R-CNN (ICCV'2021)
- GWD (ICML'2021)
- KLD (NeurIPS'2021)
- SASM (AAAI'2022)
- Oriented RepPoints (CVPR'2022)
- KFIoU (arXiv)
- G-Rep (敬请期待)
数据准备
请参考 data_preparation.md 来准备数据。
常见问题解答
常见问题解答请参阅 FAQ。
贡献
我们欢迎所有有助于改进 MMRotate 的贡献。请参阅 CONTRIBUTING.md 了解贡献指南。
致谢
MMRotate 是一个开源项目,由来自不同院校和公司的研究人员与工程师共同贡献而成。我们感谢所有实现其方法或添加新功能的贡献者,以及提供宝贵反馈的用户。我们希望该工具箱和基准能够为不断壮大的研究社区服务,提供一个灵活的工具集,用于复现现有方法并开发新的方法。
引用
如果您在研究中使用了本工具箱或基准,请引用该项目。
@inproceedings{zhou2022mmrotate,
title = {MMRotate: A Rotated Object Detection Benchmark using PyTorch},
author = {Zhou, Yue and Yang, Xue and Zhang, Gefan and Wang, Jiabao and Liu, Yanyi and
Hou, Liping and Jiang, Xue and Liu, Xingzhao and Yan, Junchi and Lyu, Chengqi and
Zhang, Wenwei and Chen, Kai},
booktitle={Proceedings of the 30th ACM International Conference on Multimedia},
year={2022}
}
许可证
本项目采用 Apache 2.0 许可证 发布。
OpenMMLab 中的项目
- MMCV: OpenMMLab 计算机视觉基础库。
- MIM: MIM 用于安装 OpenMMLab 的软件包。
- MMClassification: OpenMMLab 图像分类工具箱及基准。
- MMDetection: OpenMMLab 目标检测工具箱及基准。
- MMDetection3D: OpenMMLab 下一代通用 3D 目标检测平台。
- MMRotate: OpenMMLab 旋转目标检测工具箱及基准。
- MMSegmentation: OpenMMLab 语义分割工具箱及基准。
- MMOCR: OpenMMLab 文本检测、识别和理解工具箱。
- MMPose: OpenMMLab 人体姿态估计工具箱及基准。
- MMHuman3D: OpenMMLab 3D 人体参数化模型工具箱及基准。
- MMSelfSup: OpenMMLab 自监督学习工具箱及基准。
- MMRazor: OpenMMLab 模型压缩工具箱及基准。
- MMFewShot: OpenMMLab 少样本学习工具箱及基准。
- MMAction2: OpenMMLab 下一代动作理解工具箱及基准。
- MMTracking: OpenMMLab 视频感知工具箱及基准。
- MMFlow: OpenMMLab 光流计算工具箱及基准。
- MMEditing: OpenMMLab 图像和视频编辑工具箱。
- MMGeneration: OpenMMLab 图像和视频生成模型工具箱。
- MMDeploy: OpenMMLab 模型部署框架。
版本历史
v0.3.42023/02/01v1.0.0rc12023/01/03v1.0.0rc02022/11/07v0.3.32022/10/27v0.3.22022/07/06v0.3.12022/06/06v0.3.02022/04/30v0.2.02022/04/01v0.1.12022/03/14v0.1.02022/02/18常见问题
相似工具推荐
openclaw
OpenClaw 是一款专为个人打造的本地化 AI 助手,旨在让你在自己的设备上拥有完全可控的智能伙伴。它打破了传统 AI 助手局限于特定网页或应用的束缚,能够直接接入你日常使用的各类通讯渠道,包括微信、WhatsApp、Telegram、Discord、iMessage 等数十种平台。无论你在哪个聊天软件中发送消息,OpenClaw 都能即时响应,甚至支持在 macOS、iOS 和 Android 设备上进行语音交互,并提供实时的画布渲染功能供你操控。 这款工具主要解决了用户对数据隐私、响应速度以及“始终在线”体验的需求。通过将 AI 部署在本地,用户无需依赖云端服务即可享受快速、私密的智能辅助,真正实现了“你的数据,你做主”。其独特的技术亮点在于强大的网关架构,将控制平面与核心助手分离,确保跨平台通信的流畅性与扩展性。 OpenClaw 非常适合希望构建个性化工作流的技术爱好者、开发者,以及注重隐私保护且不愿被单一生态绑定的普通用户。只要具备基础的终端操作能力(支持 macOS、Linux 及 Windows WSL2),即可通过简单的命令行引导完成部署。如果你渴望拥有一个懂你
stable-diffusion-webui
stable-diffusion-webui 是一个基于 Gradio 构建的网页版操作界面,旨在让用户能够轻松地在本地运行和使用强大的 Stable Diffusion 图像生成模型。它解决了原始模型依赖命令行、操作门槛高且功能分散的痛点,将复杂的 AI 绘图流程整合进一个直观易用的图形化平台。 无论是希望快速上手的普通创作者、需要精细控制画面细节的设计师,还是想要深入探索模型潜力的开发者与研究人员,都能从中获益。其核心亮点在于极高的功能丰富度:不仅支持文生图、图生图、局部重绘(Inpainting)和外绘(Outpainting)等基础模式,还独创了注意力机制调整、提示词矩阵、负向提示词以及“高清修复”等高级功能。此外,它内置了 GFPGAN 和 CodeFormer 等人脸修复工具,支持多种神经网络放大算法,并允许用户通过插件系统无限扩展能力。即使是显存有限的设备,stable-diffusion-webui 也提供了相应的优化选项,让高质量的 AI 艺术创作变得触手可及。
everything-claude-code
everything-claude-code 是一套专为 AI 编程助手(如 Claude Code、Codex、Cursor 等)打造的高性能优化系统。它不仅仅是一组配置文件,而是一个经过长期实战打磨的完整框架,旨在解决 AI 代理在实际开发中面临的效率低下、记忆丢失、安全隐患及缺乏持续学习能力等核心痛点。 通过引入技能模块化、直觉增强、记忆持久化机制以及内置的安全扫描功能,everything-claude-code 能显著提升 AI 在复杂任务中的表现,帮助开发者构建更稳定、更智能的生产级 AI 代理。其独特的“研究优先”开发理念和针对 Token 消耗的优化策略,使得模型响应更快、成本更低,同时有效防御潜在的攻击向量。 这套工具特别适合软件开发者、AI 研究人员以及希望深度定制 AI 工作流的技术团队使用。无论您是在构建大型代码库,还是需要 AI 协助进行安全审计与自动化测试,everything-claude-code 都能提供强大的底层支持。作为一个曾荣获 Anthropic 黑客大奖的开源项目,它融合了多语言支持与丰富的实战钩子(hooks),让 AI 真正成长为懂上
ComfyUI
ComfyUI 是一款功能强大且高度模块化的视觉 AI 引擎,专为设计和执行复杂的 Stable Diffusion 图像生成流程而打造。它摒弃了传统的代码编写模式,采用直观的节点式流程图界面,让用户通过连接不同的功能模块即可构建个性化的生成管线。 这一设计巧妙解决了高级 AI 绘图工作流配置复杂、灵活性不足的痛点。用户无需具备编程背景,也能自由组合模型、调整参数并实时预览效果,轻松实现从基础文生图到多步骤高清修复等各类复杂任务。ComfyUI 拥有极佳的兼容性,不仅支持 Windows、macOS 和 Linux 全平台,还广泛适配 NVIDIA、AMD、Intel 及苹果 Silicon 等多种硬件架构,并率先支持 SDXL、Flux、SD3 等前沿模型。 无论是希望深入探索算法潜力的研究人员和开发者,还是追求极致创作自由度的设计师与资深 AI 绘画爱好者,ComfyUI 都能提供强大的支持。其独特的模块化架构允许社区不断扩展新功能,使其成为当前最灵活、生态最丰富的开源扩散模型工具之一,帮助用户将创意高效转化为现实。
gemini-cli
gemini-cli 是一款由谷歌推出的开源 AI 命令行工具,它将强大的 Gemini 大模型能力直接集成到用户的终端环境中。对于习惯在命令行工作的开发者而言,它提供了一条从输入提示词到获取模型响应的最短路径,无需切换窗口即可享受智能辅助。 这款工具主要解决了开发过程中频繁上下文切换的痛点,让用户能在熟悉的终端界面内直接完成代码理解、生成、调试以及自动化运维任务。无论是查询大型代码库、根据草图生成应用,还是执行复杂的 Git 操作,gemini-cli 都能通过自然语言指令高效处理。 它特别适合广大软件工程师、DevOps 人员及技术研究人员使用。其核心亮点包括支持高达 100 万 token 的超长上下文窗口,具备出色的逻辑推理能力;内置 Google 搜索、文件操作及 Shell 命令执行等实用工具;更独特的是,它支持 MCP(模型上下文协议),允许用户灵活扩展自定义集成,连接如图像生成等外部能力。此外,个人谷歌账号即可享受免费的额度支持,且项目基于 Apache 2.0 协议完全开源,是提升终端工作效率的理想助手。
markitdown
MarkItDown 是一款由微软 AutoGen 团队打造的轻量级 Python 工具,专为将各类文件高效转换为 Markdown 格式而设计。它支持 PDF、Word、Excel、PPT、图片(含 OCR)、音频(含语音转录)、HTML 乃至 YouTube 链接等多种格式的解析,能够精准提取文档中的标题、列表、表格和链接等关键结构信息。 在人工智能应用日益普及的今天,大语言模型(LLM)虽擅长处理文本,却难以直接读取复杂的二进制办公文档。MarkItDown 恰好解决了这一痛点,它将非结构化或半结构化的文件转化为模型“原生理解”且 Token 效率极高的 Markdown 格式,成为连接本地文件与 AI 分析 pipeline 的理想桥梁。此外,它还提供了 MCP(模型上下文协议)服务器,可无缝集成到 Claude Desktop 等 LLM 应用中。 这款工具特别适合开发者、数据科学家及 AI 研究人员使用,尤其是那些需要构建文档检索增强生成(RAG)系统、进行批量文本分析或希望让 AI 助手直接“阅读”本地文件的用户。虽然生成的内容也具备一定可读性,但其核心优势在于为机器