基于Python+OpenCV高速公路行驶车辆的速度检测系统

简介:

基于Python和OpenCV的高速公路行驶车辆的速度检测系统旨在实时监测高速公路上的车辆,并测量它们的速度。该系统可以用于交通监控、道路安全管理等领域,为相关部门提供重要的数据支持。

系统实现:

  1. 视频流输入:系统可以从摄像头实时获取视频流,也可以从预先录制的视频文件中读取数据。这个视频流是系统的主要输入源,用于检测和跟踪车辆。

  2. 车辆检测:利用OpenCV中的目标检测技术,系统能够自动检测视频流中出现的车辆。这可以通过预训练的分类器(如Haar级联分类器)或深度学习模型(如YOLO)来实现。

  3. 车辆跟踪:一旦检测到车辆,系统会对它们进行跟踪,以捕获它们在连续帧之间的运动轨迹。OpenCV提供了多种对象追踪算法,可以根据实际情况选择合适的算法。

  4. 速度计算:通过分析车辆在视频中的运动轨迹,系统可以计算出它们的速度。这需要考虑摄像头的视角、帧率以及像素到实际距离的转换关系。

  5. 结果显示:系统会将检测到的车辆以及它们的速度信息绘制到视频流中,以便用户进行实时观察。同时,系统也可以将结果输出到控制台或文件中,供进一步分析和处理。

代码整体逻辑思路:

导入库文件:代码开始时导入了必要的库文件,包括用于GUI的Tkinter,用于图像处理的OpenCV,用于图像操作的PIL,以及其他标准的Python库,如os、time、uuid和math。

创建GUI:使用Tkinter创建GUI窗口,窗口大小为700x700像素,设置为不可调整大小。

显示图像:从文件中打开图像文件"z.png",使用PIL库加载图像,并使用Tkinter的Label部件将其显示在GUI窗口中。

导入视频文件:提供了一个函数callback(),用于打开文件对话框以选择视频文件,并在文本框中显示选择的文件路径。

上传视频文件:提供了一个函数upload(),用于获取文本框中的视频文件路径,然后执行车辆速度测量的主要功能。

车辆速度测量:这部分代码主要是用于处理视频文件和进行车辆速度测量。它包括以下主要步骤:
        设置背景减法器并定义一些常量和参数。
        使用OpenCV打开视频文件,并获取视频的帧率和分辨率。
        实现卡尔曼滤波器来对车辆的运动进行估计和跟踪。
        循环读取视频的每一帧,并进行以下操作:
                对每一帧应用背景减法器,以便检测移动的物体。
                查找视频帧中的物体轮廓,并根据其大小和位置进行筛选。
                跟踪和测量车辆的速度。
                在视频帧上绘制检测到的车辆轨迹和速度信息。
                在GUI窗口中显示处理后的视频帧。
                GUI控件绑定:将“选择测试视频”和“车辆测速”按钮与相应的函数绑定,以便在点击按钮时执行相应的操作。

运行主循环:通过调用root.mainloop()来启动Tkinter的主事件循环,使GUI应用保持运行状态,等待用户交互。

 界面展示:

部分代码:

    def calculate_speed (trails, fps):# distance: distance on the frame# location: x, y coordinates on the frame# fps: framerate# mmp: meter per pixeldist = cv2.norm(trails[0], trails[10])   #Calculates an absolute array normdist_x = trails[0][0] - trails[10][0]dist_y = trails[0][1] - trails[10][1]mmp_y = 0.2 / (3 * (1 + (3.22 / 432)) * trails[0][1])mmp_x = 0.2 / (5 * (1 + (1.5 / 773)) * (width - trails[0][1]))real_dist = math.sqrt(dist_x * mmp_x * dist_x * mmp_x + dist_y * mmp_y * dist_y * mmp_y)return real_dist * fps * 250 / 3.6def get_frame():" Grabs a frame from the video vcture and resizes it. "rval, frame = vc.read()   if rval:(h, w) = frame.shape[:2]frame = cv2.resize(frame, (int(w * RESIZE_RATIO), int(h * RESIZE_RATIO)), interpolation=cv2.INTER_CUBIC)return rval, frame

完整代码:基于Python+OpenCV公路行驶车辆的速度检测系统(包搭建环境跑通程序)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/351283.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

快速理解 Node.js 版本差异:3 分钟指南

Node.js 是一个广泛使用的 JavaScript 运行时环境,允许开发者在服务器端运行 JavaScript 代码。随着技术的发展,Node.js 不断推出新版本,引入新特性和改进。了解不同版本之间的差异对于开发者来说至关重要。以下是一个快速指南,帮…

Docker安装Nginx(各种错误版)

Docker安装-CSDN博客 看过程就一点点看,看结果直接看最后 安装启动Docker之后 docker run -d -p 81:81 --name nginx nginx 这样没有指定版本 docker run:启动一个新的容器。-d:以分离模式运行容器(后台运行)。-p 81:81&…

【制作100个unity游戏之29】使用unity复刻经典游戏《愤怒的小鸟》(完结,附带项目源码)

最终效果 文章目录 最终效果前言素材下载简单搭建环境控制小鸟生成弹簧 限制小鸟的控制范围弹簧线的显示隐藏飞行新增木头木头销毁不同血量的木头状态配置更多物品爆炸效果创建敌人的小猪创建多个小鸟循环游戏结束相机跟随加分特效不同定义技能的鸟加速鸟回旋鸟爆炸鸟效果 轨迹…

【MySQL】服务器配置和管理

本文使用的MySQL版本是8.0 MySQL服务器介绍 MySQL服务器通常说的是mysqld程序。 mysqld 是 MySQL 数据库服务器的核心程序,负责处理客户端的请求、管理数据库和执行数据库操作。管理员可以通过配置文件和各种工具来管理和监控 mysqld 服务器的运行 官方文档&…

YOLOv10涨点改进SPPF创新结构,重新设计全局平均池化层和全局最大池化层,增强全局视角信息和不同尺度大小的特征

本文改进:SPPF_improve利用全局平均池化层和全局最大池化层,加入一些全局背景信息和边缘信息,从而获取全局视角信息并减轻不同尺度大小所带来的影响,强烈推荐,适合直接使用,paper创新级。 目录 1,YOLOv10介绍 1.1 C2fUIB介绍 1.2 PSA介绍 1.3 SCDown 2.SPP &SP…

Hvv--知攻善防应急响应靶机--Linux1

HW–应急响应靶机–Linux1 所有靶机均来自 知攻善防实验室 靶机整理: 夸克网盘:https://pan.quark.cn/s/4b6dffd0c51a#/list/share百度云盘:https://pan.baidu.com/s/1NnrS5asrS1Pw6LUbexewuA?pwdtxmy 官方WP:https://mp.weixin.…

工业自动化领域常见的通讯协议

工业自动化领域常见的通讯协议,包括PROFINET、PROFIBUS、Modbus、Ethernet/IP、CANopen、DeviceNet和BACnet。通过分析这些协议的技术特点、应用场景及优势,比较它们在工业自动化中的性能和适用性,帮助选择最合适的协议以优化系统性能和可靠性…

基于某评论的TF-IDF下的LDA主题模型分析

完整代码: import numpy as np import re import pandas as pd import jieba from sklearn.feature_extraction.text import TfidfVectorizer from sklearn.decomposition import LatentDirichletAllocationdf1 pd.read_csv(小红书评论.csv) # 读取同目录下csv文件…

Java | Leetcode Java题解之第151题反转字符串中的单词

题目: 题解: class Solution {public String reverseWords(String s) {StringBuilder sb trimSpaces(s);// 翻转字符串reverse(sb, 0, sb.length() - 1);// 翻转每个单词reverseEachWord(sb);return sb.toString();}public StringBuilder trimSpaces(S…

HAL库开发--SPI的配置方式和读写操作

知不足而奋进 望远山而前行 目录 文章目录 前言 目标 内容 需求 SPI配置 SPI编码 OLED驱动拷贝 OLED的GPIO初始化修改 实现SPI的读写 总结 前言 SPI(Serial Peripheral Interface)是一种常见的串行通信协议,在嵌入式系统中被广泛…

记录一次root过程

设备: Redmi k40s 第一步, 解锁BL(会重置手机系统!!!所有数据都会没有!!!) 由于更新了澎湃OS系统, 解锁BL很麻烦, 需要社区5级以上还要答题。 但是,这个手机…

Java基础——网络编程(一)

初识网络编程 网络编程:在网络通信协议下,不同计算机上运行的程序,进行的数据传输 应用场景:即时通信、网游对战、金融证券、国际贸易、邮件…… BS架构的优缺点: 1、不需要开发客户端,只需要页面服务端 2、…

可视化大屏开发系列——页面布局

页面布局是可视化大屏的基础,想要拥有一个基本美观的大屏,就得考虑页面整体模块的宽高自适应,我们自然就会想到具有强大灵活性flex布局,再借助百分比布局来辅助。至此,大屏页面布局问题即可得到解决。 写在前面&#x…

Java高级技术探索:深入理解JVM内存分区与GC机制

文章目录 引言JVM内存分区概览垃圾回收机制(GC)GC算法基础常见垃圾回收器ParNew /Serial old 收集器运行示意图 优化实践结语 引言 Java作为一门广泛应用于企业级开发的编程语言,其背后的Java虚拟机(JVM)扮演着至关重…

机器人建模、运动学与动力学仿真分析(importrobot,loadrobot,smimport)

机器人建模、运动学与动力学仿真分析是机器人设计和开发过程中的关键步骤。 一、机器人建模 机器人建模是描述机器人物理结构和运动特性的过程。其中,URDF(Unified Robot Description Format)是一种常用的机器人模型描述方法。通过URDF&…

植物大战僵尸杂交版全新版v2.1解决全屏问题

文章目录 🚋一、植物大战僵尸杂交版❤️1. 游戏介绍💥2. 如何下载《植物大战僵尸杂交版》 🚀二、解决最新2.1版的全屏问题🌈三、画质增强以及减少闪退 🚋一、植物大战僵尸杂交版 《植物大战僵尸杂交版》是一款在原版《…

代码随想录-Day31

455. 分发饼干 假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。 对每个孩子 i,都有一个胃口值 g[i],这是能让孩子们满足胃口的饼干的最小尺寸;并且每块饼干 j,都…

Vue32-挂载流程

一、init阶段 生命周期本质是函数。 1-1、beforeCreate函数 注意: 此时vue没有_data,即:data中的数据没有收到。 1-2、create函数 二、生成虚拟DOM阶段 注意: 因为没有template选项,所以,整个div root都…

第3章 Unity 3D着色器系统

3.1 从一个外观着色器程序谈起 新建名为basic_diffuse.shader的文件,被一个名为basic_diffuse.mat的材质文件所引用,而basic_diffuse.mat文件则被场景中名为Sphere的game object的MeshRenderer组件所使用。 basic_diffuse.shader代码文件的内容如下所示…

C# WPF入门学习主线篇(二十一)—— 静态资源和动态资源

C# WPF入门学习主线篇(二十一)—— 静态资源和动态资源 欢迎来到C# WPF入门学习系列的第二十一篇。在上一章中,我们介绍了WPF中的资源和样式。本篇文章将深入探讨静态资源(StaticResource)和动态资源(Dynam…