APP下载

基于孪生卷积神经网络的目标跟踪算法研究

2021-08-09邹超杨国平

智能计算机与应用 2021年3期
关键词:目标跟踪卷积神经网络

邹超 杨国平

摘 要: 传统的目标跟踪算法采用人工特征描述物体特征,这类人工设计的特征不能全面地表达一个物体的特点,在跟踪过程中这些特征点容易受到外界因素的影响,导致跟踪效果不稳定。基于卷积神经网络的目标跟踪算法由于采用卷积神经网络提取物体的深层次特征,这类特征能够模仿人脑描述学习一个物体的深层特征,使得在跟踪中具有较高的稳定性,目标不容易丢失且跟踪的准确性更高,能够适应复杂多变的环境鲁棒性更好。本文提出的算法采用Tensorflow搭建网络框架,离线训练模型,然后利用OpenCV调用训练好的模型进行目标跟踪实验。算法在确保较高的跟踪准确性基础上,又得到了较快的跟踪速度、且显示出很强的实时性,具有一定的实际应用价值。

关键词: 目标跟踪; 卷积神经网络; Tensorflow; OpenCV

文章编号: 2095-2163(2021)03-0177-04 中图分类号:TP183;TP391.41 文献标志码:J

【Abstract】The traditional target tracking algorithm uses artificial features to describe the characteristics of the object, this kind of artificial features can not fully express the characteristics of an object, so in the practical application of environmental changes these characteristic points will lead to inaccurate tracking, and the consequences become serious when the target is lost. The target tracking algorithm based on convolutional neural network uses convolutional neural network to extract the deep-level features of an object, which can describe the features of an object in a more comprehensive way, thus resulting in higher stability in the tracking process, less target loss and higher tracking accuracy, and being able to adapt to complex and changeable environments. The algorithm proposed in this paper uses Tensorflow to build network framework and offline train model, and then uses OpenCV to call the trained model for target tracking experiment. The algorithm not only keeps the tracking accuracy, but also has fast tracking speed and real time, which has certain practical application value.

【Key words】 target tracking; convolutional neural network; Tensorflow;  OpenCV

0 引 言

随着深度学习[1]的不断发展成熟,其应用范围也在不断扩大。最近很多学者将其引用到目标跟踪中。目标跟踪是计算机视觉领域的一个经典应用,通过跟踪单个或者多个移动目标,可以获取目标的位置、运动速度、方向等信息为相关的任务提供信息支持和消除误差。其应用诸如手势操作、行人行为预测、车辆跟踪、机器人抓手等。经典的目标跟踪算法主要有CamShift[2]为代表的运用目标的色彩特征的跟踪算法、以KCF[3]代表的核相关滤波算法、卡尔曼滤波算法[4]、粒子滤波算法[5]以及利用物体的特征点实现跟踪诸如基于SIFT特征点、SURF特征点的目标跟踪算法等。这些算法均通过人工设计的特征来表达物体,然后通过分析人工特征实现对目标的跟踪。

Mean-Shift、CamShift通过物体的色彩信息计算出色彩分布直方图,然后利用直方图的分布实现对目标的跟踪。基于SIFT和SURF特征点的算法主要运用人工设计的角点、即一些灰度突变的位置点实现对目标的跟踪。这些方法受限于人工设计的特征的局限性和容易受到诸如光照变化、物体形变、旋转、运动模糊等因素的影响,导致跟踪的准确性不够高、目标漂移甚至丢失目标。核相关滤波算法(Kernel Correlation Filter,KCF),是在2014年由Henriques等人提出來的。以KCF为代表的核相关滤波跟踪算法在速度上具有较大的优势,能够满足实时性的要求,但是其难以应对目标的尺度变化、遮挡、重叠等问题。

针对这些问题,很多学者提出了一些改进算法结合多尺度、多通道等方法提高核相关算法的准确性。所以找到一种合适的特征能够全面、准确地描述一个物体成为目标跟踪领域里的研究热点,从色彩特征到角点特征,从单通道特征到多通道特征都不能完全满足跟踪的需求,此外融合的特征信息越多必然会造成算法结构的冗余、庞大的数据处理对算法的实时性造成影响。卷积神经网络CNN处理图片类似于人的大脑,处理得到的是更高层次、更高维度的信息,所以将其应用在目标识别领域是必然的趋势,其处理图像信息的方法同样可以运用在目标跟踪领域中用于提取目标的特征。

1 网络结构与模型

近年来,孪生卷积神经网络被广泛运用在目标跟踪领域,一些使用孪生卷积神经网络的目标跟踪算法在各项比赛中都取得了不错的成绩。有些算法为了提高跟踪的准确性和算法的鲁棒性将网络结构设计得比较复杂、深度较深,在准确性提高的同时也导致了算法在跟踪速度上的表现不够优秀。并且,结构越深、越复杂的网络参数也会越多,算法的运行对硬件条件要求更高且难以满足实际工程应用的要求,不具有实际应用价值。所以本文设计一种类似于孪生卷积神经网络[6]的结构神经网络,网络结构如图1所示。

网络结构采用双路五层卷积网络提取物体特征,然后合并连接上三层全连接层通过回归的方式得出目标所在位置。这样的卷积网络深度比较合适、结构简单,五层卷积参数较少,对硬件的需求不高,可以达到实时的跟踪效果。算法设计流程拟详述如下。

Step 1 输入1:输入图像大小为127*127*3,以目标图像位置为中心,假设目标框的大小为w*h,则以目标框的位置为中心剪裁大小为2w*2h的图像;

输入2:输入图像大小为227*227*3,以目标图像位置为中心,假设目标框的大小为w*h,则以目标框的位置为中心剪裁大小为2w*2h的图像。

Step 2 将输入1和输入2输入到CNN中,进行卷积提取目标特征。

Layer1:使用11*11*96的卷积核进行卷积,卷积步长为4,使用ReLU函数作为激活函数,最大池化操作,使用3*3的核步长为2,再进行正则化后输入到Layer2中。

Layer2:使用5*5*256的卷积核进行卷积,边缘补充2行2列,卷积步长为2,ReLU激活函数,最大池化,采用3*3的核,步长为2,再进行正则化输入到Layer3中。

Layer3:卷积核为3*3*384,激活函数为ReLU。

Layer4:卷积核为3*3*384,激活函数为ReLU。

Layer5:卷积核为3*3*256,补充边缘一行一列进行卷积操作,激活函数为ReLU,最大池化,采用3*3的核,步长为2。

Step 3 将2个输入经过卷积得到数据互相关运算到一起。

Step 4 将互相关运算之后的数据输入到全连接层。

Fc-layer6 输出4 096维数据,激活函数为ReLU,drop_out_ratio为0.5。

Fc-layer7 输出4 096维数据,激活函数为ReLU,drop_out_ratio为0.5。

Fc-layer8 输出4维数据(目标框的左上角和右下角坐标位置)。

卷积部分是并行的2个卷积网络,同时对目标和待搜索区域进行卷积。考虑物体的移动特性,一般情况下目标在下一帧的位置不会距离上一帧的目标位置太远,所以对下一帧的卷积并不是对整个区域进行卷积,以上一幀中目标的位置为中心,通过裁切得到2倍于目标框大小的搜索图像送入卷积网络提取特征,最后通过全连接层学习出t帧和t+1帧的目标位置关系,得出bounding box。返回的bounding box 由4个数据组成,分别为跟踪得到的目标框的左上角坐标位置和右下角坐标位置。

2 重要参数设定

激活函数选用ReLU激活函数。常用的激活函数有sigmoid激活函数、tanh激活函数以及ReLU激活函数。对于线性函数而言,ReLU的表达能力更强,尤其体现在深度网络中。而对于非线性函数而言,ReLU由于非负区间的梯度为常数,因此不存在梯度消失问题使得模型的收敛速度维持在一个稳定状态。ReLU函数图像如图2所示。

由图2可知,ReLU函数的数学定义形式如下:

损失函数采用L1-Loss。损失函数可以避免误差在反向传播时出现梯度消失或者梯度爆炸的情况,表现在训练时网络过快或者过慢的收敛,导致网络无法学习到特征。这里需用到如下数学公式:

其中,y表示实际的输出,d表示真实值。

在训练网络时,由于参与模型的计算参数太多,而训练样本有限,训练出来的模型很容易产生过拟合的现象。过拟合顾名思义就是训练出来的模型过度拟合训练集的数据,表现出来就是在训练数据上损失函数较小,预测准确率较高;但是在测试数据上损失函数比较大,这样训练出来的模型泛化能力不强。为了提高模型的泛化能力,对网络中的神经元进行剔除很有必要,采用的dropout-ratio为0.5,即随机地让全连接层一半的神经元不参与运算。

3 模型训练与实验

3.1 模型训练

一个神经网络模型的优劣不仅与网络的结构、算法等因素有关,在很大程度上也取决于训练网络数据的质量。一个标注准确、复杂程度高、场景全面的数据集可以使训练得到的模型准确率高、鲁棒性好和泛化能力强。训练的样本使用阿姆斯特丹普通视频跟踪库的307个视频和OTB100[7]中的98个类别100个视频序列。OTB100中的视频序列见图3。阿姆斯特丹普通视频跟踪库涵盖了多种视频情况,例如:照明、透明度、镜面反射、与类似物体混淆、杂乱、遮挡、缩放、严重形状变化、运动模式、低对比度等。OTB100[7]中标记了98个物体,每一帧图片中的物体位置均有相应的标记,100个视频序列对应100个groundtruth_rect.txt,存放着每个序列中目标的位置。模型使用Tensor flow搭建并训练,测试集则是来源于VOT 2014 Tracking Challenge中的25部视频,视频的每一帧都注释有遮挡、光照变化、运动、大小变化、机位移动等变化形式。

使用Tensorflow训练好模型并保存,使用OpenCV调用模型进行跟踪实验。目前,OpenCV dnn模块支持Caffe、TensorFlow、Torch、PyTorch等深度学习框架。

3.2 实验结果

实验结果如图4所示。实验发现所设计的网络结构可以很好地提取到物体的特征,实现跟踪。跟踪的准确性较高、速度较快,具有一定的实际应用价值。例如,图4(a)中的人脸有遮挡、变形,图4(b)中的汽车有距离、尺度变化,图4(c)中的踢足球的人有大小、形变等变化,图4(d)中出现多个与目标相似的行人和自行车。算法能够应对这些变化并实现跟踪。

4 結束语

模型采用了五层卷积再加上三层全连接,结构类似于CaffeNet。实验发现算法能够应对遮挡、形变、运动模糊、尺度变化等挑战实现良好的跟踪效果。就整体而言,算法在跟踪的准确性和速度上表现都还好。算法在GTX1050TI+INTER I5平台上能够达到100+FPS的效果,即使在只有CPU的条件下也能够稳定在20+FPS,有着不错的实时性表现。算法的泛化能力依然有较大的改进空间,需要加大训练的数据量,微调参数来提高模型的泛化能力。

参考文献

[1]  罗海波, 许凌云, 惠斌,等. 基于深度学习的目标跟踪方法研究现状与展望[J]. 红外与激光工程, 2017, 46(5):6-12.

[2] 邬大鹏, 程卫平, 于盛林. 基于帧间差分和运动估计的Camshift 目标跟踪算法[J]. 光电工程, 2010, 37(1):55-60.

[3] HENRIQUES J F, RUI C, MARTINS P, et al. High-speed tracking with kernelized correlation filters [J].IEEE Transactions on Pattern Analysis Machine Intelligence, 2015, 37(3): 583-596.

[4] 汪颖进, 张桂林. 新的基于Kalman滤波的跟踪方法[J]. 红外与激光工程, 2004, 33(5):505-508.

[5] 王法胜, 鲁明羽, 赵清杰,等. 粒子滤波算法[J]. 计算机学报, 2014, 37(8):1679-1694.

[6] HELD D, THRUN S, SAVARESE S. Learning to track at 100 FPS with Deep Regression Networks[M]//LEIBE B, MATAS J, SEBE N, et al. Learning to track at 100 Fps with deep regression networks. Computer Vision-Eccv 2016. Lecture Notes In Computer Scienc. Cham:Springer, 2016,9905:749-765.

[7] WU Yi, JONGWOO L, YANG M H. Object tracking benchmark[J]. IEEE Transactions on Pattern Analysis & Machine Intelligence, 2018,37(9):1834-1848.

猜你喜欢

目标跟踪卷积神经网络
多视角目标检测与跟踪技术的研究与实现
基于深度卷积神经网络的物体识别算法
基于改进连续自适应均值漂移的视频目标跟踪算法
深度学习算法应用于岩石图像处理的可行性研究
基于深度卷积网络的人脸年龄分析算法与实现
基于卷积神经网络的树叶识别的算法的研究
空管自动化系统中航迹滤波算法的应用与改进
基于车牌识别的机混车道视频测速算法