Skip to content

AKU-hub/ICRA2021

Repository files navigation

ICRA 2021 RoboMaster AI Challenge

该项目是ICRA2021 RoboMaster AI Challenge 同舟共济的哥哥战队的感知、定位、导航、决策、规划技术方案中的感知功能代码展示

Contact: [email protected]. Any questions or discussions are welcomed!

目录

比赛简介

ICRA RoboMaster 机甲大师高校人工智能挑战赛(RMUA, RoboMaster University AI Challenge) 自2017年起已连续五年由 DJI RoboMaster 组委会与全球机器人和自动化大会联合主办,并先后在新加坡、澳大利亚、加拿大和中国西安落地执行。该赛事吸引了全球大量顶尖学府、科研机构 参与竞赛和学术研讨,进一步扩大了 RoboMaster 在国际机器人学术领域的影响力。比赛需要参赛队综合运用机械、电控和算法等技术知识,自主研发全自动射击机器人参赛,对综合技术能力要求极高。

组委会提供统一标准的机器人平台,该机器人平台具备发射弹丸、攻击检测等统一标准的接口。参加比赛 的队伍需自行研发算法,配合搭载的传感器和运算设备来实现机器人的自主决策、运动、射击。参赛队伍需要准备一到两台机器人, 在 5.1m * 8.1m 的比赛场地上进行全自动射击对抗。比赛过程中,机器人通过识别并发射弹丸击 打对方的装甲模块,以减少对方的血量。比赛结束时,机器人总伤害量高的一方获得比赛胜利。

introduction

感知系统

感知模块功能是通过安装在机器人的机载相机和场地四周的哨岗相机,获取周围的信息。包括检测机器人和装甲板,识别机器人的阵营和编号,获取机器人的位置和姿态,输入给下游决策和规划模块。

  • 哨岗相机
    • 配置: 两台深度相机, 分别放于对角处
    • 功能: 负责检测场地全局信息, 包括类别、位置、编号、位姿等
  • 机载相机
    • 配置: 大恒工业相机和USB相机
    • 功能: 负责检测敌方装甲板, 直接决定射击方向(必须打到装甲板敌方才会掉血)

robot

RM AI机器人

哨岗算法

1.设计思路

我方制定的哨岗感知算法的任务包括检测敌方机器人位置、姿态以及编号

  • 敌方机器人位置识别: 要干掉敌方, 首先要知道对方在哪
  • 敌方机器人姿态识别: 比赛规定, 击中敌方侧面和背面的伤害量分别是正面的两倍和三倍, 因此识别 出敌方姿态, 有利于执行绕后策略, 进行偷袭
  • 敌方机器人编号识别: 从战术角度讲, 集中火力先秒掉一个或者收掉残血, 有利于胜利, 因此知道敌方 机器人编号, 有利于执行围攻收割策略

2.哨岗系统架构

哨岗检测系统pipeline如下: 每个哨岗相机采集图像经过检测算法,输出装甲板和机器人检测框; 输出的装 甲板或者机器人经过自分类器得到机器人颜色和ID号,经过坐标变换得到机器人在世界坐标下的位置,经过位姿估计 模型得到机器人的位姿信息, 最后经过工程后处理, 进一步提升性能, 从而获得整个哨岗感知得到的机器人的位置、颜色、ID、位姿等 信息。两个哨岗和两个机器人的信息经过信息融合模块,最终输出4个机器人的信息。

pipeline

3.检测模型

  • 设计思路

    • 首先是算法选型: 理论上由于赛场上瞬息万变, 检测fps应越高越好(后期发现大多数队伍都是遵循这个原则, 有的甚至超过了1000fps), 但是经我们仔细研究场地发现, 哨岗其实主要用于当敌方消失在机载相机视野时以及执行特殊战术决策时(比如绕后), 因此并不需要 太高fps, 反而更倾向于高精度, 因为错误的感知信息会严重影响决策系统。所以, 我们最终选择了当时的SOTA检测算法 CenterNet2, fps大概5左右, 足够了。
    • 其次是ID获取方案: 最开始我们选用的是基于DeepSORT的多目标跟踪方案, 但后期发现世界赛场情况比较复杂, 受到障碍物遮挡等 情况会丢失目标, 导致跟踪失败。因此最终我们采用直接检测的方法, 直接标注装甲板上的ID标签进行检测, 因此这就对检测算法性能提出更高 的要求
    • 最后是确定label: 根据上述方案, 目标显然就是机器人和装甲板; 下面就是ID问题, 每方两辆, ID就是1和2, 最后就是颜色问题, 本来由于双方是红蓝对抗, 只有两种颜色, 但需要注意 的是, 当某个机器人被干掉时, 颜色会熄灭, 这就诞生了第三种颜色, 因此颜色为red、blue、black。所有label如下所示: label
  • 模型介绍

    model

    • 数据增强
      • Albumentations: 因机器人对颜色敏感, 去掉色彩类增强
      • Imagecorruptions: 增加鲁棒性
      • Mosiac: 离线生成, 扩充数据集, 变相增加BS
      • Mixup: 让模型更加鲁棒性的区分很相近的类别
    • 自分类器: 本次比赛颜色是区分阵营的唯一办法, 因此分类性能尤为重要, 为进一步提升分类性能, 我们设计了一个自分类器。 首先,通过裁剪ground-truth边界框得到图像patch, 并将每个patch的大小调整为64*64来构建训练集, 然后选择ResNet18作为分类器网络(实验验证约有1% 的提点)。
  • 检测结果

    map

    • 受条件限制, 我们是在地下室搭建的场地, 因此拍出来的图像质量较差, 实际赛场上AP可达到90%以上
  • 运行效果图

    visualized

4.姿态估计

  • 算法流程
    • Pipeline: 由检测模型输出机器人检测框bbox, 根据bbox得到机器人图像patch, resize为64*64, 输入 到ResNet18姿态分类网络, 得到姿态类别
    • Training: 根据机器人GT裁剪图像patch, resize, 打标, 训练

pose

  • 位姿结果
Class Accuracy
0 83.2%
1 88.8%
2 84.7%
3 89.7%
4 80.3%
5 85.8%
6 89.5%
7 94.6%

5.工程后处理

  • 由于比赛对精度要求较高, 我们对检测结果进行后处理, 进一步提升性能
  • 我们仔细观察结果后发现:
    • 机器人的错检主要是类别上(死车灯条并不会完全熄灭, 容易识别错), 但是几乎没有漏检或误检, 即定位 非常转
    • 装甲板的错检主要是定位上的(经常会误识别一些障碍物), 但基本不会把类别分错
    • 因此我们对结果进行融合后处理, 机器人颜色以装甲板的识别为准, 但同时装甲板的框必须在机器人的检测框内 才算有效, 经过后处理, 在赛场的精度基本可以达到99%以上
    • 同样的, 对于坐标变换(即相机标定), 优先以装甲板的位置为准, 因为机器人框内还包含背景, 对于深度相机 存在干扰

postprocess

赛事总结

  • 本次比赛更多的其实还是考验的工程实践能力, 无论算法在数据集上精度有多高, 如果无法落地或者稳定性不会,那就 没有意义
  • 其次也很考验团队合作能力, 要实现全自动机器人, 感知、定位、导航、决策、规划缺一不可, 比方说, 即便我 把感知精度提到100%, 那最后如果机器人都动不起来, 那又有何意义
  • 最后, 经过我们团队之间的不懈努力, 成功取得了中国赛一等奖

PS:有些方案赛后才研究出,比赛中并未使用

后续会继续更新一些比赛中的战术策略, 敬请期待!

About

ICRA 2021 RoboMaster AI Challenge

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages