结合YOLOv8实现目标追踪

博主使用YOLOv8在自制数据集上取得了不错的效果,考虑到后期的安排,需要在完成目标检测后完成目标追踪功能。因此在本篇博文中主要介绍结合YOLOv8实现目标追踪。
项目源码:

https://github.com/mikel-brostrom/yolov8_tracking

接下来便是调试过程,博主依旧使用的是远程服务器来运行项目。

环境部署

老生常谈,首先便是创建环境了

conda create -n tracking python=3.8

随后使用Pycharm连接服务器并将源码上传至服务器,这里可以选择使用服务器直接在github上下载。直接在命令行中输入下面命令即可。
这里博主还是推荐使用Pycahrm来进行上传,这样可以保证你本地的与服务器上的代码完全是一致的。

git clone --recurse-submodules https://github.com/mikel-brostrom/yolov8_tracking.git

下载成功如下图:

在这里插入图片描述
随后使用Pycharm连接下服务器上的cuda环境,并配置地址映射。
这里就不一一赘述了,有需要的可以参考博主的这篇博文:

云GPU服务器部署及pycharm远程连接

随后我们切换到yolov8_tracking文件夹下,并激活conda环境,并执行按照依赖命令

cd yolov8_tracking  #切换目录,这个目录名自己起
source activate tracking   #激活环境
pip install -r requirements.txt   #安装依赖

此外使用git命令时会将在yolov8文件夹内自动下载好我们的yolov8项目源码而不需要我们自己再去上传。
完成上面的配置后,我们运行该项目中的track.py文件
它会自动帮我们下载需要的权重文件,这个过程可能比较长,可以耐心的等待,当然博主推荐我们自己手动下载。
在这里插入图片描述
随后我们将下载好的权重文件放到指定位置后,我们再次运行track.py
报错:

qt.qpa.xcb: could not connect to display
qt.qpa.plugin: Could not load the Qt platform plugin “xcb” in “/home/ubuntu/.conda/envs/tracking/lib/python3.8/site-packages/cv2/qt/plugins” even though it was found.
This application failed to start because no Qt platform plugin could be initialized. Reinstalling the application may fix this problem.

先前博主就曾被这个困扰过,这是什么问题呢,我们都知道平时我们在本地运行时,为了方便实时观测数据变化,会使用plt作图来展示,而我们在使用pycharm时与服务器连接,他的图像无法回传到本地从而无法显示进而中断,如何解决呢?两种方法,第一是修改代码,可以将我们的变化图不再显示而是保存起来,等运行完成后观看即可,还有就是安装其提示:

qt.qpa.xcb: could not connect to display 10.0

我们修改下让其找到即可:在
Run-Edit Configurations, 在Environment variable添加

DISPLAY=localhost:10.0

在这里插入图片描述

完成后:

在这里插入图片描述
再次运行,该错误消失,报其他错误了,哈哈哈哈,呜呜呜

global obsensor_uvc_stream_channel.cpp:156 getStreamChannelGroup Camera index out of range

盲猜是由于远程服务器导致无法调用摄像头导致的,好吧,就先不考虑这个问题了,先使用本地环境跑吧。
切换回本地环境 python38
再次运行,摄像头成功调用。
然后又报错:
import lap
ModuleNotFoundError: No module named ‘lap’

原本以为使用pip安装一下就可以的,但却失败了,后来看到有人提到要使用该命令:

conda install -c conda-forge lap

OK了,今天就到这吧。

  • 0
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
目标追踪是通过将目标在连续帧中进行跟踪来实现的。结合YOLOv4或YOLOv5进行目标检测,可以实现目标追踪方法有多种,以下是一种简单的方法: 1. 使用YOLOv4或YOLOv5进行目标检测:首先,在视频的第一帧中使用YOLOv4或YOLOv5来检测出目标的位置和类别信息。 2. 初始化目标追踪器:在第一帧中,使用检测到的目标位置初始化一个目标追踪器,如基于卡尔曼滤波器的Kalman滤波器或基于相关滤波器的Correlation Filter等。这样可以根据初始位置预测目标在后续帧中的位置。 3. 目标追踪:对于每个后续帧,使用目标追踪器根据前一帧的预测位置来预测当前帧中目标的位置。可以使用特征匹配、光流法、神经网络等方法来提取目标的特征并更新追踪器的状态。 4. 目标重检测:定期(例如每隔几帧)使用YOLOv4或YOLOv5对当前帧进行目标检测,以防止目标追踪器出现漂移或丢失目标的情况。如果目标检测器检测到新的目标或原有目标无法再被检测到,则重新初始化目标追踪器。 5. 结果展示:将目标追踪的结果可视化或输出到文件中,以供后续分析或应用。 需要注意的是,以上只是一种基本的目标追踪方法,实际应用中可能需要根据具体情况进行调整和改进。此外,还有其他更复杂的目标追踪算法,如基于深度学习的Siamese网络、SORT(Simple Online and Realtime Tracking)等,可以根据需求和资源进行选择和尝试。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

彭祥.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值