统计某个时间段通过该路口车辆的个数
我们定义在视频里面,移动的物体称为前景,静止不动的为背景使用opencv里面的createBackgroundSubtractorMOG2()可以对所有的移动物体追踪。称之为背景减除
背景减除(Background Subtraction)是许多基于计算机视觉的任务中的主要预处理步骤。如果我们有完整的静止的背景帧,那么我们可以通过帧差法来计算像素差从而获取到前景对象。但是在大多数情况下,我们可能没有这样的图像,所以我们需要从我们拥有的任何图像中提取背景。当运动物体有阴影时,由于阴影也在移动,情况会变的变得更加复杂。为此引入了背景减除算法,通过这一方法我们能够从视频中分离出运动的物体前景,从而达到目标检测的目的。 OpenCV已经实现了几种非常容易使用的算法。
import cv2
#打开默认摄像头
video = cv2.VideoCapture(0)
#背景和前景的使用,生成背景对象
mog = cv2.createBackgroundSubtractorMOG2()
while True:
#读取一帧照片
ret,frame = video.read()
if ret==True:
#讲这一帧照片应用背景减除
img = mog.apply(frame)
#展示照片
cv2.imshow('img',img)
#每一毫秒一张照片
k = cv2.waitKey(1)
#按q建退出
if k == ord('q'):
break
video.release()
cv2.destroyAllWindows()
我们对图片中的各种阴影,如移动的树叶,行走的行人进行降噪,腐蚀操作、膨胀操作来减小干扰
图像的降噪处理
import cv2
#打开默认摄像头
video = cv2.VideoCapture('video.mp4')
#背景和前景的使用,生成背景对象
mog = cv2.createBackgroundSubtractorMOG2()
#生成形态学内核
kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (5,5))
while True:
#读取一帧照片
ret,frame = video.read()
if ret==True:
#对照片进行灰度化处理:
img = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
#对照片使用高斯降噪:
img = cv2.GaussianBlur(img,(5,5,),1)
#将这一帧照片应用背景减除
img = mog.apply(frame)
#进行腐蚀操作:
img = cv2.erode(img,kernel,iterations=2)
#进行膨胀操作:
img = cv2.dilate(img,kernel)
#由于膨胀操作会放大车子上的车牌等车内部分
#对目标图片内部进行闭运算
img = cv2.morphologyEx(img,cv2.MORPH_CLOSE,kernel)
#展示照片
cv2.imshow('img',img)
#每一毫秒一张照片
k = cv2.waitKey(1)
if k == ord('q'):
break
video.release()
cv2.destroyAllWindows()
前导知识:图像的轮廓
得到所有车子的移动轨迹,我们进行轮廓处理,画出每个车子的最小外接矩阵
import cv2
#打开默认摄像头
video = cv2.VideoCapture('video.mp4')
#背景和前景的使用,生成背景对象
mog = cv2.createBackgroundSubtractorMOG2()
#生成形态学内核
kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (5,5))
while True:
#读取一帧照片
ret,frame = video.read()
if ret==True:
#对照片进行灰度化处理:
img = cv2.cvtColor(frame,cv2.COLOR_BGR2GRAY)
#对照片使用高斯降噪:
img = cv2.GaussianBlur(img,(5,5,),1)
#将这一帧照片应用背景减除
img = mog.apply(frame)
#进行腐蚀操作:
img = cv2.erode(img,kernel,iterations=2)
#进行膨胀操作:
img = cv2.dilate(img,kernel)
#由于膨胀操作会放大车子上的车牌等车内部分
#对目标图片内部进行闭运算
img = cv2.morphologyEx(img,cv2.MORPH_CLOSE,kernel)
# 查找轮廓,返回轮廓和阶级
contours, hierarchy = cv2.findContours(img, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
#对所有车子进行处理,也就是处理所有的轮廓坐标
for contour in contours:
# 最大外接矩阵的生成
x, y, w, h = cv2.boundingRect(contour)
# 绘制最大外接矩阵
cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2)
#展示照片
cv2.imshow('img',frame)
#每一毫秒一张照片
k = cv2.waitKey(1)
if k == ord('q'):
break
video.release()
cv2.destroyAllWindows()
对于所有轮廓,当长度和宽度大于一定大小才是车子。然每个车子抽象为一个中心,设置参考坐标线,通过这条线(车子的坐标跟参考线的坐标距离足够小)计数加1
import cv2
# 统计车的数量
carno = 0
# 存放有效车辆的数组
cars = []
#打开默认摄像头
video = cv2.VideoCapture('video.mp4')
#背景和前景的使用,生成背景对象
mog = cv2.createBackgroundSubtractorMOG2()
#生成形态学内核
kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (5,5))
while True:
#读取一帧照片
ret,frame = video.read()
if ret==True:
#对照片进行灰度化处理:
img = cv2.cvtColor(frame,cv2.COLOR_BGR2GRAY)
#对照片使用高斯降噪:
img = cv2.GaussianBlur(img,(5,5,),1)
#将这一帧照片应用背景减除
img = mog.apply(frame)
#进行腐蚀操作:
img = cv2.erode(img,kernel,iterations=2)
#进行膨胀操作:
img = cv2.dilate(img,kernel)
#由于膨胀操作会放大车子上的车牌等车内部分
#对目标图片内部进行闭运算
img = cv2.morphologyEx(img,cv2.MORPH_CLOSE,kernel)
# 查找轮廓,返回轮廓和阶级
contours, hierarchy = cv2.findContours(img, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
# 绘制一条检测线
cv2.line(frame, (10, 600), (1200, 600), (0, 255, 0), 2)
#对所有车子进行处理,也就是处理所有的轮廓坐标
for contour in contours:
# 最大外接矩阵的生成
x, y, w, h = cv2.boundingRect(contour)
# 对车辆的外接矩阵的宽高进行判断,以验证是否为有效的车辆
if not(w >= 50 and h >= 50):
continue
# 绘制最大外接矩阵
cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2)
#找到中心点的坐标
center_x,center_y = int(w/2)+x,int(h/2)+y
#为了避免一个画面车子过多无法统计完,加入数组,一个一个的判断
cars.append((center_x,center_y))
#对每一个车子的坐标情况进行判断:
for x,y in cars:#小于10像素极为识别有一辆车
if ((y > 600 - 10) and (y < 600 + 10)):
carno += 1
cars.remove((x, y))
#显示车辆个数
cv2.putText(frame, "Vehicle Count:" + str(carno), (600, 50), cv2.FONT_HERSHEY_SIMPLEX, 2, (0, 255, 0), 3)
#展示照片
cv2.imshow('img',frame)
#每一毫秒一张照片
k = cv2.waitKey(1)
if k == ord('q'):
break
video.release()
cv2.destroyAllWindows()
由于在统计过程中对于运动轨迹的车子识别存在一定的误差,对车子的轮廓处理不够完善,当车子的流量过大时会检测失败。同时对于车辆的计数如果车子跟坐标轴距离过大,也无法识别这个车子是否通过。
使用深度学习中的卷积神经网络,对每个运动的物体进行追踪,当算法模型可以识别为车子时,即可进行计数,从而提高识别率