yolov5 deepsort-船舶目标检测+目标跟踪+单目测距+速度测量
目标跟踪是一种计算机视觉技术,通过分析图像或视频数据中的目标,实时追踪目标的位置和运动轨迹。在本文中,我们将详细介绍目标跟踪的原理、方法和应用,并探讨其在各个领域中的潜在价值。
1. 目标跟踪技术的基本原理
目标跟踪技术的基本原理是通过提取目标特征,通过计算机算法实现目标在图像或视频序列中的连续追踪。目标特征可以包括颜色、纹理、形状等方面的信息。基于特征的跟踪方法通常包括卡尔曼滤波器、粒子滤波器等。此外,还有基于深度学习的目标跟踪方法,通过神经网络实现目标的快速准确跟踪。
2. 目标跟踪技术的分类和方法
目标跟踪技术可以根据跟踪的目标类型进行分类,如人体跟踪、车辆跟踪、物体跟踪等。根据跟踪方法的不同,可以分为基于特征的跟踪方法和基于深度学习的跟踪方法。基于特征的跟踪方法包括相关滤波器、稀疏表示、聚集跟踪等。基于深度学习的跟踪方法常使用卷积神经网络进行特征提取和跟踪。
3. 目标跟踪技术的应用领域
目标跟踪技术在许多领域中具有广泛的应用价值。在智能监控领域,目标跟踪可以发现和追踪可疑人物或物品,提高安全性。在交通领域,目标跟踪可以用于车辆跟踪和交通流量监测等应用。在无人驾驶领域,目标跟踪是实现自动驾驶的关键技术之一。此外,目标跟踪还可应用于机器人导航、虚拟现实等领域。
4. 目标跟踪技术的挑战和改进方向
尽管目标跟踪技术已经取得了显著的进展,但仍面临一些挑战。其中之一是复杂背景下的目标跟踪,如目标与背景颜色相似或部分遮挡。另一个挑战是目标丢失和重新跟踪的问题,特别是在快速运动或目标与其他目标相似的情况下。未来的改进方向包括结合多模态信息的跟踪、引入强化学习等技术来提高跟踪精度和鲁棒性。
总结而言,目标跟踪技术是计算机视觉领域中的重要研究方向,具有广泛的应用前景。随着技术的不断发展和改进,目标跟踪将在智能监控、交通、无人驾驶等领域中起到越来越重要的作用,为社会的发展和进步做出积极贡献。
简介
YOLOv5是一种流行的目标检测算法,它是YOLO系列算法的最新版本。YOLOv5采用了一种新的架构,可以在保持高准确性的同时提高检测速度。在本文中,我们将介绍如何使用YOLOv5算法来进行船舶跟踪和测距。
算法流程
首先,我们需要准备一个船舶检测模型。我们可以使用YOLOv5算法对一组带有船舶的图像进行训练,以便模型可以学习如何检测船舶。在训练之后,我们可以使用该模型来检测新图像中的船舶。

一旦我们有了一个船舶检测模型,就可以开始跟踪船舶。我们可以使用跟踪算法,例如Kalman滤波器或卡尔曼滤波器和粒子滤波器,来跟踪检测到的船舶。这些算法可以使用检测到的船舶位置和速度信息来估算船舶的未来位置,并且能够在目标运动模式发生变化时进行自适应。
在跟踪船舶时,我们还可以使用光流算法来估算船舶的速度和方向。光流是一种计算像素在连续帧之间的运动的方法,这可以用来估算船舶的速度和方向。通过将光流算法与跟踪算法结合使用,我们可以更好地跟踪船舶,并估算出船舶的未来位置和速度。
运行demo.py代码
def main():func_status = {}func_status['headpose'] = Nonename = 'demo'det = Detector()cap = cv2.VideoCapture(VIDEO_PATH)fps = int(cap.get(5))print('fps:', fps)t = int(1000/fps)size = NonevideoWriter = Nonewhile True:# try:_, im = cap.read()if im is None:breakresult1 = det.feedCap(im, func_status)result = result1['frame']#object1 = result['list_of_ids']boxes=result1['obj_bboxes']
#########################################curr_x=0curr_y=0if boxes:print("-----------",boxes)print('------------type:',type(boxes))for l in range(len(boxes)):x1, y1, x2, y2, lbl, conf=boxes[l][0],boxes[l][1],boxes[l][2],boxes[l][3],boxes[l][4],boxes[l][5]result_speed = calculate_velocity(curr_x, curr_y, x2, y2, 1, 0.5)/3.6curr_x=x1curr_y =y1print("速度:", result_speed)actual_height=20actual_width=100triangle_height=y2-y1triangle_width=x2-x1focal_length=10distance=calculate_distance(actual_height, actual_width, triangle_height, triangle_width, focal_length)print("di----------s",type(distance))if distance <10 and result_speed>10:color=(0,255,255)result = draw_boxes(result, boxes, identities=None, offset=(0, 0), color=color,distance=distance,speed=result_speed)else:color=(255,0,0)
————————————————
版权声明:本文为CSDN博主「阿利同学」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/ALiLiLiYa/article/details/131741399
最后,我们可以使用摄像头的参数和船舶图像的尺寸来测量船舶的距离。通过计算船舶在图像中的像素大小,然后使用相机参数和船舶的实际大小来计算船舶与相机之间的距离。这可以用于跟踪船舶并估算船舶的远近。
结果
单目标

多目标跟踪

总结
总之,使用YOLOv5算法进行船舶跟踪和测距是一种高效准确的方法。通过训练一个船舶检测模型,并结合跟踪算法和光流算法来跟踪船舶,我们可以估算出船舶的未来位置和速度。然后,使用摄像头的参数和船舶图像的尺寸来测量船舶的距离,我们可以更好地了解船舶的远近。
相关文章:
yolov5 deepsort-船舶目标检测+目标跟踪+单目测距+速度测量
目标跟踪是一种计算机视觉技术,通过分析图像或视频数据中的目标,实时追踪目标的位置和运动轨迹。在本文中,我们将详细介绍目标跟踪的原理、方法和应用,并探讨其在各个领域中的潜在价值。 1. 目标跟踪技术的基本原理 目标跟踪技术的…...
Wireshark与其他工具的整合
第一章:Wireshark基础及捕获技巧 1.1 Wireshark基础知识回顾 1.2 高级捕获技巧:过滤器和捕获选项 1.3 Wireshark与其他抓包工具的比较 第二章:网络协议分析 2.1 网络协议分析:TCP、UDP、ICMP等 2.2 高级协议分析:HTTP…...
DDD架构实践
ddd架构浅析 背景介绍 什么是ddd架构,是以ddd思想为参考,做出一份符合ddd思想的框架。 随着技术的迭代升级,越来越多的瓶颈暴露出来,性能瓶颈,系统复杂度瓶颈,这些都逐一被迭代出的技术产物解决。最终的…...
Bert-vits2-v2.2新版本本地训练推理整合包(原神八重神子英文模型miko)
近日,Bert-vits2-v2.2如约更新,该新版本v2.2主要把Emotion 模型换用CLAP多模态模型,推理支持输入text prompt提示词和audio prompt提示语音来进行引导风格化合成,让推理音色更具情感特色,并且推出了新的预处理webuI&am…...
认识缓存,一文读懂Cookie,Session缓存机制。
🏆作者简介,普修罗双战士,一直追求不断学习和成长,在技术的道路上持续探索和实践。 🏆多年互联网行业从业经验,历任核心研发工程师,项目技术负责人。 🎉欢迎 👍点赞✍评论…...
关于react native项目中使用react-native-wechat-lib@3.0.4
关于react native项目中使用react-native-wechat-lib3.0.4 插件官网安装依赖包(Android和iOS下载插件完成后记得更新依赖,)Android中配置1.在项目文件夹下面创建文件夹wxapi(如上图)2.在文件MainApplication.java中如下…...
【LeetCode刷题笔记(8-1)】【Python】【接雨水】【动态规划】【困难】
文章目录 引言接雨水题目描述提示 解决方案1:【动态规划】结束语 接雨水 引言 编写通过所有测试案例的代码并不简单,通常需要深思熟虑和理性分析。虽然这些代码能够通过所有的测试案例,但如果不了解代码背后的思考过程,那么这些代…...
pycharm通过ssh连接远程服务器的docker容器进行运行和调试代码
pycharm连接远程服务器的docker容器通常有两种方法: 第一种:pycharm通过ssh连接已在运行中的docker容器 第二种:pycharm连接docker镜像,pycharm运行代码再自动创建容器 第一种方法比较通用简单,作者比较推崇。 条件…...
Chrome2023新版收藏栏UI改回旧版
版本 120.0.6099.109(正式版本)Chrome浏览器菜单新版、旧版的差异 想要将书签、功能内容改回旧版的朋友可以网址栏输入:「chrome://flags」,接着搜寻「Chrome Refresh 2023」。 最后将 Chrome Refresh 2023、Chrome Refresh 2023…...
WebSocket与JavaScript:实现实时获取位置
一、WebSocket介绍 WebSocket是一种在单个TCP连接上进行全双工通信的协议。与传统的HTTP请求相比,WebSocket能够在服务器和客户端之间建立持久连接,实现实时数据传输。WebSocket提供了较低的延迟和高效的数据传输。在实时舆情监测中,它能够实…...
一种解决Qt5发布release文件引发的无法定位程序输入点错误的方法
目录 本地环境问题描述分析解决方案 本地环境 本文将不会解释如何利用Qt5编译生成release类型的可执行文件以及如何利用windeployqt生成可执行的依赖库,请自行百度。 环境值操作系统Windows 10 专业版(22H2)Qt版本Qt 5.15.2Qt Creator版本5.0…...
UE4/UE5 日志插件(基于spdlog)
1 解决问题 对于高频日志序列化到本地的需求,spdlog肯定完美满足。 源码地址:https://github.com/gabime/spdlog 博主下载的版本为 spdlog-1.12.0,各位大佬可以根绝自己爱好选择。 2 过程介绍 大概目录: SpdlogLibC目录下是对…...
微信小程序ios中非cover组件点击重复触发地图tap事件
现象: map中使用view组件的click事件会重复触发地图的tap组件,只在ios上出现 <map id"maps" style"width: 100vw;height: 100vh;" :latitude"latitude" :longitude"longitude":markers"markers"…...
7.26 SpringBoot项目实战【还书】
文章目录 前言一、编写控制器二、编写服务层三、Git提交前言 本文是项目实战 业务接口 的最后一篇,上文 曾说过【还书】的 入口是【我的借阅记录】,因为【还书】是基于一次借阅记录而言,另外在4.2 数据库设计 曾分析过【还书】的业务场景,需要执行两步操作: 更新【借阅记…...
Golang中使用errors返回调用堆栈信息
Golang的errors包返回堆栈信息 标准库errors提供了处理错误的方法。比如常用的 func New(text string) error 用该方法处理错误信息,就只会输出自定义的 text 到控制台或者日志文件,没有其它辅助排查的信息输出,所以常规我们就只能根据 te…...
Web前端-HTML(常用标签)
文章目录 1. HTML常用标签1.1 排版标签1)标题标签h (熟记)2)段落标签p ( 熟记)3)水平线标签hr(认识)4)换行标签br (熟记)5)div 和 span标签(重点)6)排版标签总结 1.2 标签属性1.3 图像标签img (重点)1.4 链…...
一 OpenCV中的数据类型
1. cv::Mat 2. cv::Point 主要用来表示二维点,也有表示三维点的模板类型; cv::Point p(int, int) 最常用 ① cv::Point_<T> ② cv::Point2i cv::Point_<int> ③ cv::Point2f cv::Point_<float> ④ cv::Point2d …...
59. 螺旋矩阵 II(java实现,史上最详细教程,想学会的进!!!)
今天来分享一下螺旋矩阵的解题思路及代码的实现。 题目描述如下: 首先拿到这道题,首先不要慌张,我们来仔细分析一下会发现并没有那么难。 首先看下边界的元素是1、2、3递增的,那么我们也许可以根据这一点先把边界的元素一个一个给…...
vue 将后端返回的二进制流进行处理并实现下载
什么是二进制流文件? 二进制文件是一种计算机文件格式,它的数据以二进制形式存储,与文本文件不同。二进制文件可以包含任意类型的数据,例如图像、音频、视频、可执行文件、压缩文件等,而文本文件则仅仅包含 ASCII 码或…...
PyCharm连接远程服务器
要求:PyCharm专业版才支持远程服务 一、创建远程连接 先建立本地与远程服务器之间的SSH连接 1、配置连接 2、建立SSH连接,选择文件传输协议 SFTP 3、设置服务器名(可以随意命名) 4、配置 SSH连接 点击 172.18.1.202 配置…...
[2025CVPR]DeepVideo-R1:基于难度感知回归GRPO的视频强化微调框架详解
突破视频大语言模型推理瓶颈,在多个视频基准上实现SOTA性能 一、核心问题与创新亮点 1.1 GRPO在视频任务中的两大挑战 安全措施依赖问题 GRPO使用min和clip函数限制策略更新幅度,导致: 梯度抑制:当新旧策略差异过大时梯度消失收敛困难:策略无法充分优化# 传统GRPO的梯…...
深入浅出:JavaScript 中的 `window.crypto.getRandomValues()` 方法
深入浅出:JavaScript 中的 window.crypto.getRandomValues() 方法 在现代 Web 开发中,随机数的生成看似简单,却隐藏着许多玄机。无论是生成密码、加密密钥,还是创建安全令牌,随机数的质量直接关系到系统的安全性。Jav…...
srs linux
下载编译运行 git clone https:///ossrs/srs.git ./configure --h265on make 编译完成后即可启动SRS # 启动 ./objs/srs -c conf/srs.conf # 查看日志 tail -n 30 -f ./objs/srs.log 开放端口 默认RTMP接收推流端口是1935,SRS管理页面端口是8080,可…...
OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别
OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别 直接训练提示词嵌入向量的核心区别 您提到的代码: prompt_embedding = initial_embedding.clone().requires_grad_(True) optimizer = torch.optim.Adam([prompt_embedding...
【开发技术】.Net使用FFmpeg视频特定帧上绘制内容
目录 一、目的 二、解决方案 2.1 什么是FFmpeg 2.2 FFmpeg主要功能 2.3 使用Xabe.FFmpeg调用FFmpeg功能 2.4 使用 FFmpeg 的 drawbox 滤镜来绘制 ROI 三、总结 一、目的 当前市场上有很多目标检测智能识别的相关算法,当前调用一个医疗行业的AI识别算法后返回…...
学校时钟系统,标准考场时钟系统,AI亮相2025高考,赛思时钟系统为教育公平筑起“精准防线”
2025年#高考 将在近日拉开帷幕,#AI 监考一度冲上热搜。当AI深度融入高考,#时间同步 不再是辅助功能,而是决定AI监考系统成败的“生命线”。 AI亮相2025高考,40种异常行为0.5秒精准识别 2025年高考即将拉开帷幕,江西、…...
LLMs 系列实操科普(1)
写在前面: 本期内容我们继续 Andrej Karpathy 的《How I use LLMs》讲座内容,原视频时长 ~130 分钟,以实操演示主流的一些 LLMs 的使用,由于涉及到实操,实际上并不适合以文字整理,但还是决定尽量整理一份笔…...
实战三:开发网页端界面完成黑白视频转为彩色视频
一、需求描述 设计一个简单的视频上色应用,用户可以通过网页界面上传黑白视频,系统会自动将其转换为彩色视频。整个过程对用户来说非常简单直观,不需要了解技术细节。 效果图 二、实现思路 总体思路: 用户通过Gradio界面上…...
vue3 daterange正则踩坑
<el-form-item label"空置时间" prop"vacantTime"> <el-date-picker v-model"form.vacantTime" type"daterange" start-placeholder"开始日期" end-placeholder"结束日期" clearable :editable"fal…...
全面解析数据库:从基础概念到前沿应用
在数字化时代,数据已成为企业和社会发展的核心资产,而数据库作为存储、管理和处理数据的关键工具,在各个领域发挥着举足轻重的作用。从电商平台的商品信息管理,到社交网络的用户数据存储,再到金融行业的交易记录处理&a…...
