【车辆计数】基于matlab光流法行驶车辆检测计数【含Matlab源码 627期】

2024-04-11 07:58

本文主要是介绍【车辆计数】基于matlab光流法行驶车辆检测计数【含Matlab源码 627期】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

✅博主简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,Matlab项目合作可私信。
🍎个人主页:海神之光
🏆代码获取方式:
海神之光Matlab王者学习之路—代码获取方式
⛳️座右铭:行百里者,半于九十。

更多Matlab仿真内容点击👇
Matlab图像处理(进阶版)
路径规划(Matlab)
神经网络预测与分类(Matlab)
优化求解(Matlab)
语音处理(Matlab)
信号处理(Matlab)
车间调度(Matlab)

⛄一、光流场简介

1 案例背景
运动视觉研究的内容是如何从变化场景中的一系列不同时刻的图像中提取有关场景中物体的形状、位置和运动的信息。根据研究的方法,它可以分为两类:基于特征的方法和基于光流场的方法。基于特征的方法抽取特征点,是离散的;光流场属于运动数据研究范畴,是基于连续的图像序列,并直接对其进行运动估计,可以求得图像中每一像素处所对应物体的运动信息。
当物体运动时, 在图像上对应物体的亮度模式也在运动。光流(Optical Flow) 是指图像中亮度模式运动的速度,光流场是一种二维瞬时速度场,它是景物中可见点的三维速度矢量在成像表面的投影。光流不仅包含了被观察物体的运动信息,而且携带着有关场景的三维结构信息。本案例基于Computer Vision System Toolbox, 使用光流场算法对交通视频中汽车的运动进行检测和估计。

2 理论基础
2.1光流法检测运动原理
光流场是指图像灰度模式的表观运动,它是一种像素级的运动。光流法检测运动物体的基本原理是:根据各个像素点的速度矢量特征,可以对图像进行动态分析。如果图像中没有运动物体,则光流矢量在整个图像区域是连续变化的;当图像中有运动物体时,由于目标和图像背景存在相对运动,所以运动物体所形成的速度矢量必然和邻域背景速度矢量不同,从而检测出运动物体及其位置。但是光流法的优点在于,光流不仅携带了运动物体的运动信息,还携带了有关三维结构的丰富信息,它能够在不知道场景任何信息的情况下,检测出运动的图像。基于光流场的运动检测的步骤如图1所示。在理想情况下,光流场和二维运动场互相吻合,但这一命题不总是对的。如图2所示,一个均匀球体在某一光源照射下,亮度呈现一定的明暗模式。当球体绕中心轴旋转时,明暗模式并不随着表面运动,所以图像也没有变化,此时光流在任意地方都等于零,然而运动场却不等于零。如果球体不动而光源运动,则明暗模式将开始随着光源运动,此时光流不等于零但运动场为零。
在这里插入图片描述
图1基于光流场的运动检测的步骤 图2光流场和运动场的联系和区别
光流场的方法能够较好地用于二维运动估计,它也可以同时给出全局点的运动估计,但是光流场并不等价于运动场,因此其本身必然存在着一些问题:遮挡问题、孔径问题、光照问题等。

2.2 光流的主要计算方法
光流场的计算主要有基于梯度的方法、基于匹配的方法、基于能量的方法和基于相位的方法。另外,近几年神经网络动力学也颇受学者重视。基于梯度的方法利用图像灰度的梯度来计算光流,是研究得最多的方法,比如Horn-S chun ck算法、Lucas-Kanade算法和Nagel算法。基于梯度的方法以运动前后图像灰度保持不变作为先决条件,导出光流约束方程。由于光流约束方程并不能唯一地确定光流,因此需要导入其他约束。根据引入的约束不同,基于梯度的方法又可以分为全局约束方法和局部约束方法。全局约束的方法假定光流在整个图像范围内满足一定的约束条件;而局部约束的方法假定在给定点周围的一个小区域内,光流满足一定的约束条件。
基于匹配的方法包括基于特征匹配和基于区域匹配两种。基于区域匹配技术在视频编码中得到了广泛应用,它通过对图像序列中相邻两帧图像间的子块匹配来进行运动估值。在区域匹配算法中,图像被分割为子块,子块中所有像素的运动被认为是相同的,由于复杂的运动可以被近似地分解为一组平移运动之和,所以区域匹配算法采用的运动模型假设图像中的运动物体由做平移运动的刚体组成,且假设在图像场景中没有大的遮挡物。
基于能量的方法首先要对输入图像序列进行时空滤波处理,这是一种时间和空间整合。对于均匀的流场,要获得正确的速度估计,这种时空整合是非常必要的。然而,这样做会降低光流估计的空间和时间分辨率。尤其是当时空整合区域包含几个运动成分(如运动边缘)时,估计精度将会恶化。此外,基于能量的光流技术涉及大量的滤波器,因此存在高计算负荷的问题。然而可以预期,随着相应硬件的发展,在不久的将来,滤波将不再是一个严重的限制因素,所有这些技术都可以在帧速下加以实现。
基于相位的方法由Fleet和Jepson提出, 该算法根据带通滤波器输出的相位特性来确定光流。通过与带通速度调谐滤波器输出中的等相位轮廓相垂直的瞬时运动来定义分速度。带通滤波器按照尺度、速度和定向来分离输入信号。基于相位的光流技术的综合性能比较优秀,光流估计比较精确且具有较高的空间分辨率,对图像序列的适用范围也比较宽。
对于光流计算来讲,如果说前面的基于能量或相位的模型有一定的生物合理性的话,那么近几年出现的利用神经网络建立的视觉运动感知的神经动力学模型则是对生物视觉系统功能与结构的更为直接的模拟。尽管现有的神经动力学模型还不成熟,然而这些方法及其结论为其进一步研究打下了良好的基础,是将神经机制引入运动计算方面所做的极有意义的尝试。
目前,对光流的研究方兴未艾,新的计算方法还在不断涌现。这里对光流技术的发展趋势与方向提出以下看法。
(1)现有技术有各自的优点与缺陷,方法之间相互结合,优势互补,建立光流计算的多阶段或分层模型是光流技术发展的一个趋势。
(2)通过深入的研究发现,现有光流方法之间有许多共通之处。如微分法和匹配法的前提假设极为相似;某些基于能量的方法等效于区域匹配技术;而相位方法则将相位梯度用于法向速度的计算。
(3)尽管光流计算的神经动力学方法还很不成熟,然而对它的研究却具有极其深远的意义。随着生物视觉研究的不断深入,神经网络方法无疑会不断完善,也许光流计算乃至计算机视觉的根本出路就在于神经机制的引入。

2.3 梯度光流场约束方程
假定像素点(x,y)在1时刻的灰度值为I(x,y,t),在1+dr时刻,该像素点运动到新的位置(x+dx,y+dy),此时对应的灰度值为I(x+dx,y+dy,t+dr)。根据图像的一致性假设,当dt→0时,图像沿着运动轨迹的亮度保持不变,即:I(x,y,t)=I(x+dx,y+dy,t+dt)(23.1)
如果图像灰度随(x,y,t)缓慢变换,则将(23.1)式进行泰勒级数展开:
(1)在这里插入图片描述
如果图像灰度随(x,y,t)缓慢变换,则将(1)式进行泰勒级数展开:
在这里插入图片描述
于是
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
式中,VI-[1…1,]表示梯度方向;U=[u,可表示光流。(23.4)式称为光流约束方程,是
所有基于梯度的光流计算方法的基础。
考虑由u和v组成的二维空间,那么(4)式定义了一条直线,所有满足约束方程的U=[u,都在该直线上,如图3所示,该直线和梯度VI-[1…1,]垂直。由于光流约束方程包含u和v两个未知量,显然由一个方程并不能唯一确定,为了求解光流场,必须引入新的约束条件。
在这里插入图片描述
图3光流基本方程所确定的约束线
根据约束条件的不同,梯度光流法又分为全局约束方法和局部约束方法。全局约束方法假定光流在整个图像范围内满足一定的约束条件,而局部约束的方法假定在给定像素点周围的一个小区域内,光流满足于一定的约束条件。常用的基于梯度的光流计算方法如下。
(1)运动场平滑
Horn-S chun ck假设光流在整个图像上光滑变化, 即运动场既满足光流约束方程又满足全局平滑性。将光滑性测度同加权微分约束测度组合起来,其中加权参数控制图像流约束微分和光滑性微分之间的平衡。
(2)预测校正
Lucas-kanade假设在一个小的空间邻域上运动矢量保持恒定, 然后使用加权最小二乘的思想来估计光流,它是一种基于像素递归的光流算法,就是预测校正型的位移估算器。预测值可以作为前一个像素位置的运动估算值,或作为当前像素邻域内的运动估算线性组合。依据该像素上的位移帧差的梯度最小值,对预测做进一步的修正。
(3)平滑约束
与Hom-S chun ck算法一样, Nagel也使用了全局平滑约束来建立光流误差测度函数,
但是Nagel提出的一种面向平滑的约束, 并不是强加在亮度梯度变化最剧烈的方向(比如
边缘方向)上的,这样做的目的是为了处理遮挡。

2.4 Horn-S chun ck光流算法
Horn-S chun ck算法是一种全局约束的方法, 其提出了光流的平滑性约束条件, 即图像
上任一点的光流并不是独立的,光流在整个图像范围内平滑变化。所谓平滑,就是在给定
邻域内其速度分量平方和积分最小:
在这里插入图片描述
在实际情况下,(5)式可以使用下面的表达式代替:
在这里插入图片描述
式中,u和▼分别表示u邻域和v邻域中的均值。
根据光流基本方程(4) 式考虑光流误差, Horn-S chun ck算法将光流求解归结为如下极值问题:
在这里插入图片描述
式中,入控制平滑度,它的取值要考虑图中的噪声情况,如果噪声较强,则说明图像数据
本身的置信度较低,需要更多地依赖光流约束,所以1可以取较大的值;反之,可以取较
小的值。

⛄二、部分源代码

clear;close all;
SE = strel(‘rectangle’,[10 10]); %注意:结构元素必须具有适当的大小
BW1=imread(‘test5.jpg’);
subplot(221);imshow(BW1);title(‘原图’);
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%添加
GRAY=rgb2gray(BW1); %灰度图像1
h=fspecial(‘average’,9);
GRAY=uint8(round(filter2(h,GRAY))); %进行均值滤波
subplot(222);imshow(GRAY);title(‘均值滤波’);
GRAY = imcrop(GRAY,[10 20 542 355]); %裁剪
GRAY=double(GRAY); %转换为double类型
[Gx,Gy]=gradient(GRAY); % 计算梯度
G=sqrt(Gx.*Gx+Gy.Gy); % 水平垂直差分
J=GRAY;
K=find(G<2); %指定灰度级
J(K)=0;
subplot(223);imshow(J);title(‘锐化’);
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
BW2=imdilate(J,SE);%膨胀
BW3 = imfill(BW2,‘holes’); %填充
BW4=imerode(BW3,SE);%腐蚀
I=im2bw(BW4);
subplot(224);imshow(I);title(‘目标块’);
%==形态特征值计算=%
A=bwarea(I); % 计算目标的面积
I1=edge(I,‘canny’,0.7);
[L, num]=bwlabel(I1,8);%存放提取的目标矩阵和数目
STATS = regionprops(L,‘BoundingBox’);
% 存放经过筛选以后得到的所有矩形块
n = 1;
wh=zeros(1,num);
for i=1:num
box = STATS(i).BoundingBox; %图像的长宽
x = box(1); %矩形坐标x
y = box(2); %矩形坐标y
w = box(3); %矩形宽度w
h = box(4); %矩形高度h
wh(1,i)=w
h;
ux = ceil(x); %取整
uy = ceil(y);
if ux > 1
ux = ux - 1;
end
if uy > 1

 end  %result(n,:) = [ux uy w h];R=zeros(h,w);G=zeros(h,w);B=zeros(h,w);for j=1:wfor ii=1:hR(ii,j)=BW1(ii+uy-1,j+ux-1,1);B(ii,j)=BW1(ii+uy-1,j+ux-1,3);endend% r(1,n)=mean(mean(R))% g(1,n)=mean(mean(G))% b(1,n)=mean(mean(B))% n = n+1;if(r(1,i)>130&&g(1,i)<130&&b(1,i)<130)disp('检测出车辆是红色')elseif(r(1,i)<130&&g(1,i)>130&&b(1,i)<130)disp('检测出车辆是绿色')elseif(r(1,i)<130&&g(1,i)<130&&b(1,i)>130)disp('检测出车辆是蓝色')elseif(r(1,i)<80&&g(1,i)<80&&b(1,i)<80)disp('检测出车辆是黑色')elseif(r(1,i)>170&&g(1,i)>170&&b(1,i)>170)disp('检测出车辆是白色')elsedisp('检测出车辆是其他色')end

end
% 创建系统对象,用于显示结果
sz = get(0,‘ScreenSize’);
pos = [20 sz(4)-300 200 200];
hVideoOrig = vision.VideoPlayer(‘Name’, ‘Original’, ‘Position’, pos);
pos(1) = pos(1)+220; %在右侧建立下一个视窗
hVideoFg = vision.VideoPlayer(‘Name’, ‘Foreground’, ‘Position’, pos);
pos(1) = pos(1)+220;
hVideoRes = vision.VideoPlayer(‘Name’, ‘Results’, ‘Position’, pos);
line_row = 23; % 定义感兴趣区域(ROI)
% 以下的程序段为对输入的视频图像进行处理
while ~isDone(hvfr)
image = step(hvfr); % 读入视频的每一帧
y = step(hcsc, image); % 将彩色图像转换成灰度图像
% 采用自动白平衡算法去除灰度突变
y = y-mean(y(😃);
fg_image = step(hfdet, y); % 检验背景
% 采用数学形态学,在前景图像中检测变化的联通图像块区域的面积
[area, bbox] = step(hblob, fg_image);
image_out = image;

end

⛄三、运行结果

在这里插入图片描述
在这里插入图片描述

⛄四、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1]汤石晨,陈锻生.基于光流法和行人面积特征的人数统计方法研究[J].图学学报. 2013,34(01)

3 备注
简介此部分摘自互联网,仅供参考,若侵权,联系删除

🍅 仿真咨询
1 各类智能优化算法改进及应用

生产调度、经济调度、装配线调度、充电优化、车间调度、发车优化、水库调度、三维装箱、物流选址、货位优化、公交排班优化、充电桩布局优化、车间布局优化、集装箱船配载优化、水泵组合优化、解医疗资源分配优化、设施布局优化、可视域基站和无人机选址优化

2 机器学习和深度学习方面
卷积神经网络(CNN)、LSTM、支持向量机(SVM)、最小二乘支持向量机(LSSVM)、极限学习机(ELM)、核极限学习机(KELM)、BP、RBF、宽度学习、DBN、RF、RBF、DELM、XGBOOST、TCN实现风电预测、光伏预测、电池寿命预测、辐射源识别、交通流预测、负荷预测、股价预测、PM2.5浓度预测、电池健康状态预测、水体光学参数反演、NLOS信号识别、地铁停车精准预测、变压器故障诊断

3 图像处理方面
图像识别、图像分割、图像检测、图像隐藏、图像配准、图像拼接、图像融合、图像增强、图像压缩感知

4 路径规划方面
旅行商问题(TSP)、车辆路径问题(VRP、MVRP、CVRP、VRPTW等)、无人机三维路径规划、无人机协同、无人机编队、机器人路径规划、栅格地图路径规划、多式联运运输问题、车辆协同无人机路径规划、天线线性阵列分布优化、车间布局优化

5 无人机应用方面
无人机路径规划、无人机控制、无人机编队、无人机协同、无人机任务分配

6 无线传感器定位及布局方面
传感器部署优化、通信协议优化、路由优化、目标定位优化、Dv-Hop定位优化、Leach协议优化、WSN覆盖优化、组播优化、RSSI定位优化

7 信号处理方面
信号识别、信号加密、信号去噪、信号增强、雷达信号处理、信号水印嵌入提取、肌电信号、脑电信号、信号配时优化

8 电力系统方面
微电网优化、无功优化、配电网重构、储能配置

9 元胞自动机方面
交通流 人群疏散 病毒扩散 晶体生长

10 雷达方面
卡尔曼滤波跟踪、航迹关联、航迹融合

这篇关于【车辆计数】基于matlab光流法行驶车辆检测计数【含Matlab源码 627期】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/893507

相关文章

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

烟火目标检测数据集 7800张 烟火检测 带标注 voc yolo

一个包含7800张带标注图像的数据集,专门用于烟火目标检测,是一个非常有价值的资源,尤其对于那些致力于公共安全、事件管理和烟花表演监控等领域的人士而言。下面是对此数据集的一个详细介绍: 数据集名称:烟火目标检测数据集 数据集规模: 图片数量:7800张类别:主要包含烟火类目标,可能还包括其他相关类别,如烟火发射装置、背景等。格式:图像文件通常为JPEG或PNG格式;标注文件可能为X

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、

基于 YOLOv5 的积水检测系统:打造高效智能的智慧城市应用

在城市发展中,积水问题日益严重,特别是在大雨过后,积水往往会影响交通甚至威胁人们的安全。通过现代计算机视觉技术,我们能够智能化地检测和识别积水区域,减少潜在危险。本文将介绍如何使用 YOLOv5 和 PyQt5 搭建一个积水检测系统,结合深度学习和直观的图形界面,为用户提供高效的解决方案。 源码地址: PyQt5+YoloV5 实现积水检测系统 预览: 项目背景

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

音视频入门基础:WAV专题(10)——FFmpeg源码中计算WAV音频文件每个packet的pts、dts的实现

一、引言 从文章《音视频入门基础:WAV专题(6)——通过FFprobe显示WAV音频文件每个数据包的信息》中我们可以知道,通过FFprobe命令可以打印WAV音频文件每个packet(也称为数据包或多媒体包)的信息,这些信息包含该packet的pts、dts: 打印出来的“pts”实际是AVPacket结构体中的成员变量pts,是以AVStream->time_base为单位的显