# 基于 YoloV3 的机坪飞机图像识别
[TOC]
已经上传利用hilens接入多路视频的方案,可以参考文件夹下“Hilens接多路视频流方案”内容。
## 1. 应用价值
与道路交通不同的是,航空器在地面运行时难以通过高架、隧道等方式将航班滑行路径分离,由于飞机起降架次的增多,加上恶劣天气的影响,跑道侵入事件已成为民航领域航空器地面安全运行的头等问题,跑道安全事故在民用航空事故中占有很大比例,因此对与在机场跑道和滑行道上运行的航空器、车辆等目标的身份、位置及其动态的掌控程度,很大程度上决定了跑道运行安全的系数。
机场地面运行的航空器和其他载具一般都经由塔台进行统一调度管理,塔台的核心职责是确保航班“安全、有序、高效”运行,塔台管制人员通过“看到-了解-判断-行动”这一决策过程对数量众多的航空器和地面载具进行统一指挥,而“看到”和“了解”这两个过程往往会对管制决策起到决定性作用。
随着机场规模增加,平面布局变得日益复杂化,对于大型机场的塔台而言,单点视野物理受限,以及数字化程度提升的同时,客观上造成屏幕变多、信息量变大,“看到”和“了解”形成了较大的挑战,人的主观能动性很强,但往往难以面面俱到。
基于上述背景,我们设计了跑道侵入防护系统,用于加强跑道侵入事件的防范。“光电盯防子系统”是该系统的重要实时核心,该子系统具备较完整的“基于视频流的航空器目标识别和跟踪”能力,主要工作是将机场平面各个关键点采集到的实时视频流送入基于华为云ModelArts框架的“航空器识别模型”进行处理,识别出画面中飞行器对象的像素坐标等一次参数后,对其进行空间位置换算,以及包括速度、运行方向等在内的二次参数的计算,并在系统运行数据中找到相匹配的航班信息对目标进行信息标记,以AR信息增强的形式呈现在监视器上,让管制员以“抬头显示”的形式在单一屏幕中直观了解到足够全面的动态信息。同时该系统会在后台对所有目标的轨迹和矢量动态数据进行监控和推算,让计算机能够代替或辅助管制人员在全局范围对每一个航班、每一个道口进行实时盯防,提前预知潜在运行风险,从而降低事故发生的概率。
本项目即为该系统的“航空器识别模型”子系统。基于YoloV3模型,能够实现较为准确的目标识别和坐标输出,依托ModelArts训练推理系统,可以实现的”航空器识别模型“服务,实现从“看到”到“了解”的关键一步。
## 2. 开发流程
本项目基于Yolo模型,其主要程序参考华为“ModelArts/开发环境/notebook”,Examples中的mxnet_objection_detection项目构建。
#### a. 基本流程与yolov3
本项目基本流程如图,基本遵循从华为提供的样例代码开始进行修改,并最终调整应用的过程。如开发其它类型基于华为样例代码的工程,同样可以参考本开发流程。开发流程示意图如下:
![develop_flow](./md_img/develop_flow.png)
本项目使用yolov3模型,该模型是经典的目标检测模型。可以实现快速、准确的目标检测。其采用darknet_53作为特征提取网络,并采用多层级检测的方式,实现对大小不同的目标进行快速检测。详细内容可以参考论文原文: [YOLOv3: An Incremental Improvement](https://arxiv.org/pdf/1804.02767v1.pdf)
#### b. 标注并准备训练数据
模型开发的第一步就是进行数据,由于MA提供的数据准备函数是基于PASCAL VOC 系列数据集的,其中每一张图片对应一个xml标注数据文件。具体可是可以参考[PASCAL VOC](http://host.robots.ox.ac.uk/pascal/VOC/) 系列数据集的描述和详细内容。
标注数据与调整数据集结构是一件非常麻烦的事情,但是ModelArts已经对目标检测的标注提供了完善的数据标注工具支持。本项目也采用ModelArts提供的数据标注工具进行相关工作。具体地说,将采用ModelArts提供的“数据管理/数据集”功能创建“目标检测”数据集以进行标注工作。具体流程可以参考官方[数据管理使用指南](https://support.huaweicloud.com/engineers-modelarts/modelarts_23_0003.html)。
由于后续我们将在notebook中训练,因此得到的数据集还需进一步处理。先标注数据,然后发布数据集,标注数据会保存在`obs://数据集输出位置/dataset-****/annotation/数据版本号/annotations`中,其保存形式为与图片名称相同的xml格式文件。将xml标注文件与对应的图像文件放在同一文件夹中,则可以构筑本项目所需数据集。为方便起见,图像与标注文件文件夹仍保存在obs中的同一文件夹中。
除了单纯的提取数据之外,还可以根据个人需求进行简单的数据加工,比如重新改写标注名称等等。由于本项目中无需额外处理,因此具体方法不再赘述。
#### c. 获得参考代码
参考代码有两个来源,一个是华为提供的notebook example中的notebook代码,另一个是notebook中需要下载的库代码,本小节将描述两个代码具体的获得办法。
参考notebook代码可以在ModelArts Jupyter Notebook下通过Examples中的mxnet_objection_detection打开。具体位置如图:
![notebook_example](./md_img/notebook_example.png)
而其他的参考代码获得方法则略有不同。我们可以在notebook文件中看到,该notebook正常运行需要通过wget下载代码,该代码即为我们需要的参考代码。位置如图:
![download_code](./md_img/download_code.png)
在公网也可以正常下载,可以使用如下命令直接下载然后解压缩获得参考代码:`wget https://ai-course-common-20.obs.cn-north-1.myhuaweicloud.com/object_detection/object_detection.tar.gz`
#### d. 修改数据准备代码,加载数据
方便起见,notebook代码和其他参考代码放到一个文件中进行使用,且都存储于obs上。其他参考代码主要用于提供python库包,所以不用修改,修改内容集中在notebook代码中。修改内容较为繁杂,具体修改内容可以通过对比本项目提供的notebook文件和原始notebook参考代码来确定。这里仅就其中较为关键的部分进行说明。
参考下图新建notebook,然后使用“mxnet_object_detection.ipynb”作为基础代码,以进行修改。
![juptyer](./md_img/load_model.png)
**修改文件读取方式,加载其他代码和文件**
MA的初始工作目录是`/home/ma-user/work`,所有文件操作都是基于本地系统的,不能直接使用obs中的程序与数据,因此需要修改数据读取方式。在notebook开始位置添加代码:
```python
import moxing as mox
mox.file.shift('os', 'mox')
```
执行后,即可使得python在大部分文件操作中支持obs系统,比如从obs中复制文件到本地系统:
```python
shutil.copytree("s3://youziyolo/youzi/src","./src")
```
其中`s3://`为obs文件路径前缀。
notebook原始代码中有修改本地工作目录的内容。在本项目中本地工作目录工作位置不用修高,保持`/home/ma-user/work`即可。此外,本项目中所有的代码在一开始就已经上传到obs中了,无需用wget下载对应代码,而是通过从obs中复制的方法获得代码和数据。可以参考如下代码(自行操作使需要根据个人指定的obs路径进行修改):
```python
shutil.copytree("s3://youziyolo/youzi/src","./src") # 程序源代码
shutil.copytree("s3://youziyolo/youzi/model","./model") # 预训练模型
shutil.copytree("s3://youziyolo/youzi/data/raw","./rawdata") # 原
Java程序员-张凯
- 粉丝: 1w+
- 资源: 7524
最新资源
- DeepSeek-deepseek
- DeepSeek-deepseek
- cursor-cursor
- Masuit.LuceneEFCore.SearchEngine-搜索引擎
- "MATLAB R2018a下Ricker小波及频率切片小波变换的生成与应用",Ricker小波及其频率切片小波变 代码运行环境为MATLAB r2018a,小波基的选择根据领域的不同而不同,例如机械
- easy4cursor-cursor
- DeepSeek-deepseek
- es-client-搜索引擎
- DrissionPage-机器人
- 基于PLC的全自动洗衣机控制系统设计:从硬件选型到软件实现的全流程解析 ,基于PLC全自动洗衣机控制系统设计 含Word文档一整套 前 言\\t1 第一章 绪 论\\t2 第一节 研究背景研
- 基于RBF调节与神经网络PID的永磁同步电机PMSM控制:双闭环与单闭环系统说明文档,RBF调节PID,永磁同步电机PMSM,神经网络PID,径向基函数,自整定PID 有双闭环和单闭环两个文件,简单的
- 三相异步电动机直接矢量PWM与SVPWM控制MATLAB Simulink仿真模型研究及机械特性分析,三相异步电动机直接矢量pwm控制与svpwm控制MATLAB Simulink仿真模型 1
- cocos-engine-cocos资源
- Remote WOL MicroPython-硬件开发资源
- C语言实现扩展卡尔曼滤波EKF进行锂电池SOC估计:包含定参与FFRLS,跨平台运行成功并附图表展示,(C语言版)扩展卡尔曼滤波EKF进行锂电池SOC估计的C语言版本实现,和matlab版本一样包含定
- lanqiaobeibesai-蓝桥杯资源
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈