Python运动检测编程实战演练(Python运动检测编程实战演练)
Python运动检测编程实战演练(Python运动检测编程实战演练)
2024-10-01 03:51:14  作者:白癡娿  网址:https://m.xinb2b.cn/sport/adr189803.html

译者 | 朱先忠

审校 | 孙淑娟


概述

由于Python编程语言面临多个开源库可用;因此,选择Python语言进行运动检测开发是很容易的。目前,运动检测已经有许多的商业应用。例如,它可以用于在线考试的监考,也可以用于商店、银行等领域的安全目的。

Python编程语言是一种开源的且支持库极其丰富的语言,如今基于此语言已经为用户开发了大量的应用程序,并拥有大量用户。正因为如此,Python语言在市场上快速增长。Python语言的优点不胜枚举,不仅是因为它的语法简单、易于发现错误,而且其非常迅速的调试过程使其对用户更加友好。

为什么建议您学习Python呢?我们可以使用下图来简单说明:


Python于1991年设计,由Python软件基金会开发。如今已经发布了许多版本。其中,Python2和Python3最为著名。目前,Python3已经被广泛使用,用户数量也在快速增长。在本文这个项目中,我们将使用Python3作为开发语言。

什么是运动检测?

根据物理学原理,当一个物体静止不动且没有速度时,它就被认为处于静止状态;而恰恰相反的是,当一物体没有完全静止且在某个方向(无论是左右、前后或上下)上有一定的运动或速度时,它都被认为处于运动状态。在本文中,我们将尝试检测出物体的运行情况。


目前,运动检测在现实生活中已经存在大量实现或应用,这充分证明其巨大的应用价值。其中,使用网络摄像头(我们将在本文中实现)作为安全警卫进行在线考试监考等是最典型的应用。

在本文中,我们将尝试实现一个脚本。通过该脚本,我们将使用台式机或笔记本电脑上安装的网络摄像头实现对物体运动的检测。我们的想法是,我们将拍摄两帧视频,并试图找出它们之间的差异。如果两帧之间存在某种差异,那么很明显,相机前面的物体存在某种移动,这就产生了差异。

主要的参考库

在着手实现代码之前,让我们先看看我们将在代码中使用的一些模块或库,这些模块或库用于操作网络摄像头进行运动检测。正如我们所讨论的,这些开源库对于Python声誉的传播起着重要作用。让我们看看本文示例项目中需要的开源库:

openCVPandas

上述两个库OpenCV和Pandas都是纯粹基于Python的免费开源库,我们将通过Python语言的Python3版本来使用它们。

1.OpenCV

OpenCV是一个非常著名的开源库,可以与许多编程语言(如C 、Python等)一起使用,专门应用于处理图像和视频程序开发。通过与Python的开源库Pandas或者NumPy库集成应用,我们可以充分挖掘出OpenCV的功能。

2.Pandas

Pandas是一个开放源码的Python库,为数据分析提供了丰富的内置工具;因此,在数据科学和数据分析领域得到了广泛的应用。在Pandas中提供了数据结构形式DataFrame数据帧,这种结构对于将表格数据操作和存储到二维数据结构中提供了极方便的支持。

上述两个模块都不是Python内置的,我们必须在使用前先安装它们。除此之外,我们还将在项目中使用另外两个模块。

Python日期时间(DateTime)模块Python时间(Time)模块

这两个模块都内置在Python中,以后无需安装。这些模块分别用来处理与日期和时间相关的功能。

代码实现

到目前为止,我们已经看到了我们将在代码中使用的库。接下来,让我们从视频只是许多静态图像或帧的组合这一假定开始,然后使用所有这些帧的组合来创建一个视频。

导入所需的库

在本节中,我们将首先导入所有库,如Pandas和OpenCV。然后,我们从DateTime模块导入time和DateTime函数。

#导入Pandas库import Pandas as panda # 导入OpenCV库import cv2 #导入时间模块import time #从datetime 模块导入datetime 函数 from datetime import datetime

初始化数据变量

在本节中,我们要初始化一些变量,并将在代码中进一步使用这些变量。首先,我们将初始状态定义为“None”,然后通过另一个变量motionTrackList来存储跟踪的运动。

此外,我们还定义了一个列表“motionTime”,用于存储发现运动的时间,并使用Panda的模块初始化数据帧列表。

# 对于初始帧,以变量initialState的形式将初始状态指定为None initialState = None # 帧中检测到任何运动时存储所有轨迹的列表 motionTrackList= [ None, None ] # 一个新的“时间”列表,用于存储检测到移动时的时间 motionTime = [] # 使用带有初始列和最终列的Panda库初始化数据帧变量“DataFrame” dataFrame = panda.DataFrame(columns = ["Initial", "Final"])

关键帧捕获过程

在本节中,我们将实现本文示例项目中最关键的运动检测步骤。下面,让我们分步骤进行解说:

首先,我们将开始使用cv2模块捕获视频,并将其存储在视频变量中。然后,我们将使用无限while循环从视频中捕获每一帧。接下来,将使用read()方法读取每个帧,并将它们存储到各自的变量中。我们定义了一个变量var_motion,并将其初始化为零。我们使用cv2函数cvtColor和GaussianBlur创建另外两个变量grayImage和grayFrame,以找到运动中的变化。如果我们的initialState为None,则我们将当前grayFrame指定为initialState;否则,使用“continue”关键字跳过后面代码的执行。在后面代码中,我们计算在当前迭代中创建的初始帧和灰度帧grayscale之间的差异。然后,我们将使用cv2阈值和dilate函数突出显示初始帧和当前帧之间的变化。我们将从当前图像或帧中的运动对象中找到轮廓,并通过使用rectangle函数在其周围创建绿色边界来指示运动对象。在此之后,我们将把当前检测到的元素添加到列表变量motionTrackList。到目前为止,我们已经通过使用imshow方法显示出如灰度和原始帧等所有的关键帧。此外,我们还使用cv2模块的witkey()方法来结束进程。程序中,我们选择使用按下键盘上的'm'键来结束我们的进程。

# 使用cv2模块启动网络摄像头以捕获视频 video = cv2.VideoCapture(0) # 使用无限循环从视频中捕获帧while True: # 使用read功能从视频中读取每个图像或帧 check, cur_frame = video.read() #将'motion'变量定义为等于零的初始帧 var_motion = 0 # 从彩色图像创建灰色帧 gray_image = cv2.cvtColor(cur_frame, cv2.COLOR_BGR2GRAY) # 从灰度图像中使用GaussianBlur函数找到变化部分 gray_frame = cv2.GaussianBlur(gray_image, (21, 21), 0) # 在第一次迭代时进行条件检查 # 如果为None,则把grayFrame赋值给变量initalState if initialState is None: initialState = gray_frame continue # 计算静态(或初始)帧与我们创建的灰色帧之间的差异 differ_frame = cv2.absdiff(initialState, gray_frame) # 静态或初始背景与当前灰色帧之间的变化将突出显示 thresh_frame = cv2.threshold(differ_frame, 30, 255, cv2.THRESH_BINARY)[1] thresh_frame = cv2.dilate(thresh_frame, None, iterations = 2) #对于帧中的移动对象,查找轮廓 cont,_ = cv2.findContours(thresh_frame.copy(), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) for cur in cont: if cv2.contourArea(cur) < 10000: continue var_motion = 1 (cur_x, cur_y,cur_w, cur_h) = cv2.boundingRect(cur) # 在移动对象周围创建一个绿色矩形 cv2.rectangle(cur_frame, (cur_x, cur_y), (cur_x cur_w, cur_y cur_h), (0, 255, 0), 3) # 从帧中添加运动状态 motionTrackList.append(var_motion) motionTrackList = motionTrackList[-2:] # 添加运动的开始时间 if motionTrackList[-1] == 1 and motionTrackList[-2] == 0: motionTime.append(datetime.now()) # 添加运动的结束时间 if motionTrackList[-1] == 0 and motionTrackList[-2] == 1: motionTime.append(datetime.now()) # 在显示捕获图像的灰度级中 cv2.imshow("The image captured in the Gray Frame is shown below: ", gray_frame) # 显示初始静态帧和当前帧之间的差异 cv2.imshow("Difference between the inital static frame and the current frame: ", differ_frame) # 在框架屏幕上显示视频中的黑白图像 cv2.imshow("Threshold Frame created from the PC or Laptop Webcam is: ", thresh_frame) #通过彩色框显示物体的轮廓 cv2.imshow("From the PC or Laptop webcam, this is one example of the Colour Frame:", cur_frame) # 创建处于等待状态的键盘按键 wait_key = cv2.waitKey(1) # 按下'm'键时,结束整个进程执行 if wait_key == ord('m'): # 当屏幕上有东西移动时,将运动变量值添加到motiontime列表中 if var_motion == 1: motionTime.append(datetime.now()) break

代码收尾工作

在结束循环体执行后,我们将从dataFrame和motionTime列表中添加数据到CSV文件中,最后关闭视频。这一部分代码的实现如下所示:

# 最后,我们在数据帧中添加运动时间 for a in range(0, len(motionTime), 2): dataFrame = dataFrame.append({"Initial" : time[a], "Final" : motionTime[a 1]}, ignore_index = True) # 创建CSV文件记录下所有运动信息 dataFrame.to_csv("EachMovement.csv") # 释放视频内存 video.release() #现在,在openCV的帮助下关闭或销毁所有打开的窗口 cv2.destroyAllWindows()

至此,我们已经成功地创建完所有代码。现在,让我们再次归纳一下整个过程。

首先,我们使用设备的网络摄像头捕捉视频,然后将输入视频的初始帧作为参考,并不时检查下一帧。如果发现与第一帧不同的帧,则说明存在运动。该信息将被标记在绿色矩形中。

完整的代码

现在,让我们把上面所有代码片断连接到一起,如下所示:

#导入Pandas库import Pandas as panda # 导入OpenCV库import cv2 #导入时间模块import time #从datetime 模块导入datetime 函数 from datetime import datetime # 对于初始帧,以变量initialState的形式将初始状态指定为None initialState = None # 帧中检测到任何运动时存储所有轨迹的列表 motionTrackList= [ None, None ] # 一个新的“时间”列表,用于存储检测到移动时的时间 motionTime = [] # 使用带有初始列和最终列的Panda库初始化数据帧变量“DataFrame” dataFrame = panda.DataFrame(columns = ["Initial", "Final"])# 使用cv2模块启动网络摄像头以捕获视频 video = cv2.VideoCapture(0) # 使用无限循环从视频中捕获帧while True: # 使用read功能从视频中读取每个图像或帧 check, cur_frame = video.read() #将'motion'变量定义为等于零的初始帧 var_motion = 0 # 从彩色图像创建灰色帧 gray_image = cv2.cvtColor(cur_frame, cv2.COLOR_BGR2GRAY) # 从灰度图像中使用GaussianBlur函数找到变化部分 gray_frame = cv2.GaussianBlur(gray_image, (21, 21), 0) # 在第一次迭代时进行条件检查 # 如果为None,则把grayFrame赋值给变量initalState if initialState is None: initialState = gray_frame continue # 计算静态(或初始)帧与我们创建的灰色帧之间的差异 differ_frame = cv2.absdiff(initialState, gray_frame) # 静态或初始背景与当前灰色帧之间的变化将突出显示 thresh_frame = cv2.threshold(differ_frame, 30, 255, cv2.THRESH_BINARY)[1] thresh_frame = cv2.dilate(thresh_frame, None, iterations = 2) #对于帧中的移动对象,查找轮廓 cont,_ = cv2.findContours(thresh_frame.copy(), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) for cur in cont: if cv2.contourArea(cur) < 10000: continue var_motion = 1 (cur_x, cur_y,cur_w, cur_h) = cv2.boundingRect(cur) # 在移动对象周围创建一个绿色矩形 cv2.rectangle(cur_frame, (cur_x, cur_y), (cur_x cur_w, cur_y cur_h), (0, 255, 0), 3) # 从帧中添加运动状态 motionTrackList.append(var_motion) motionTrackList = motionTrackList[-2:] # 添加运动的开始时间 if motionTrackList[-1] == 1 and motionTrackList[-2] == 0: motionTime.append(datetime.now()) # 添加运动的结束时间 if motionTrackList[-1] == 0 and motionTrackList[-2] == 1: motionTime.append(datetime.now()) # 在显示捕获图像的灰度级中 cv2.imshow("The image captured in the Gray Frame is shown below: ", gray_frame) # 显示初始静态帧和当前帧之间的差异 cv2.imshow("Difference between the inital static frame and the current frame: ", differ_frame) # 在框架屏幕上显示视频中的黑白图像 cv2.imshow("Threshold Frame created from the PC or Laptop Webcam is: ", thresh_frame) #通过彩色框显示物体的轮廓 cv2.imshow("From the PC or Laptop webcam, this is one example of the Colour Frame:", cur_frame) # 创建处于等待状态的键盘按键 wait_key = cv2.waitKey(1) # 借助'm'键结束我们系统的整个进行 if wait_key == ord('m'): # 当屏幕上有物体运行时把运动变量值添加到列表motiontime中 if var_motion == 1: motionTime.append(datetime.now()) break # 最后,我们在数据帧中添加运动时间 for a in range(0, len(motionTime), 2): dataFrame = dataFrame.append({"Initial" : time[a], "Final" : motionTime[a 1]}, ignore_index = True) # 记录下所有运行,并创建到一个CSV文件中 dataFrame.to_csv("EachMovement.csv") # 释放视频内存 video.release() #现在,在openCV的帮助下关闭或销毁所有打开的窗口 cv2.destroyAllWindows()

运行结果

运行上述代码后得到的结果与下面看到的结果类似。


从这个动画中,我们可以看到该男子在视频中的动作已经被跟踪。因此,可以相应地看到输出结果。

然而,在这段代码中,跟踪是在移动对象周围的矩形框的帮助下完成,类似于下面动画中所示的。这里要注意的一件有趣的事情是,这段视频是一个实际的安全摄像头的镜头,已经对其进行了检测处理。


结论Python编程语言是一种开源的且有丰富的开源库支持的语言,目前已经为用户提供了许多现成的应用程序。当一个物体静止不动且没有速度时,则认为它处于静止状态;反之,当一个对象未完全静止时,则视为它处于运动状态。OpenCV是一个开源库,可用于多种编程语言,通过将其与Python的Panda/NumPy库集成,我们可以充分发挥OpenCV的功能。

最后来归纳一下。本文中所介绍的运动检测的主要思想是,每个视频只是许多静态图像(称为帧)的组合,我们是通过判断帧之间的差异来实现运行检测的。

译者介绍

朱先忠,51CTO社区编辑,51CTO专家博客、讲师,潍坊一所高校计算机教师,自由编程界老兵一枚。早期专注各种微软技术(编著成ASP.NET AJX、Cocos 2d-X相关三本技术图书),近十多年投身于开源世界(熟悉流行全栈Web开发技术),了解基于OneNet/AliOS Arduino/ESP32/树莓派等物联网开发技术与Scala Hadoop Spark Flink等大数据开发技术。

原文标题: ​ How to Perform Motion Detection Using Python

https://www.kdnuggets.com/2022/08/perform-motion-detection-Python.html

作者:Vaishnavi Amira Yada​

  • 珠宝行业分析(成为新消费独角兽)
  • 2024-10-01成为新消费独角兽在奥运赛场上所向披靡的中国健儿,会怎样为他们的爱情“加冕”?9.83秒封神的苏炳添,在浪漫的大海边,向自己的“女神”单膝下跪,用一枚DR求婚钻戒,许下爱的誓言:“说过的话一定要算,爱过的人永不会变”在。
  • 宝鸡哪个县最好(宝鸡哪个区县最大)
  • 2024-10-01宝鸡哪个区县最大我们每天在这个地方生活、穿梭,感受着她的呼吸,见证着她的发展变化……我们以为对这个地方这座城市了如指掌,但其实,你真的了解宝鸡吗?哪个区县面积最大?哪个区县面积最小?……你在宝鸡生活多久了?你住在哪里。
  • 京剧名家杨宝森唱段(京剧大师杨宝森诞辰112周年)
  • 2024-10-01京剧大师杨宝森诞辰112周年112年前的今天,京剧大师杨宝森出生在北京的一个梨园世家幼年时,杨宝森赴上海演出,被誉为“正宗谭派须生”,深受上海观众欢迎他曾历经“满腹戏曲歌不成,箪食瓢饮苦练声”的困顿与苦闷,但他依然坚持吊嗓、习琴。
  • 新东方在线发展前景咋样(新东方在线宣布)
  • 2024-10-01新东方在线宣布来源丨21世纪经济报道(ID:jjbd21)作者丨钱奕昀、王峰编辑丨朱益民、周上祺、刘巷图源丨IC、图虫校外学科类培训机构的境遇再添一颗重磅炸弹!10月25日晚,新东方旗下在线教育网站——新东方在线(。
  • 楼宇自控系统发展前景(探索楼宇自控行业的创新与变革)
  • 2024-10-01探索楼宇自控行业的创新与变革“双碳”目标呼唤智能建筑为积极应对气候变化,贯彻绿色可持续发展理念,2020年9月,我国政府正式提出双碳目标,即2030年前实现碳达峰、2060年前实现碳中和“双碳”目标是我国基于推动构建人类命运共同。
  • 贝壳找房一定要经纪人吗(贝壳找房ACN经纪人网络)
  • 2024-10-01贝壳找房ACN经纪人网络第一个吃到蛋糕的人,滋味最值得分享5月6日,武汉德佑A系统在当地上线第三天,郑艳就成交了一单,房源来自链家网,在她看来,“这是以前想都不敢想的事情”作为武汉德佑海上五月花店的经纪人,郑艳吃到了武汉徳佑。
  • 奇怪君的号是什么(这位主播被誉为)
  • 2024-10-01这位主播被誉为作为Steam上常年位居Steam销量榜前列的生存沙盒游戏,《方舟:生存进化》的玩家基数十分庞大,因为全球同服的性质,全世界各国玩家都在游戏当中征战而就有那么一位国人主播被誉为"方舟皇帝。
  • 景甜用的卸妆品(景甜素颜美翻天)
  • 2024-10-01景甜素颜美翻天快来数一数谁又被大甜甜的盛世美颜圈粉啦!在节目上卸妆的明星不少见,但是直接素颜上阵的女星还真的是不多哦,勇敢的景甜就是其中一位在最新一档综艺《我想见到你》中,景甜就用一张素颜小脸挑战了各类角色,关键是。
  • 什么盐吃得最好(全国哪的食用盐最好吃)
  • 2024-10-01全国哪的食用盐最好吃您家里常备的是哪种盐?以前过穷日子的时候,因为吃不起盐,很多人就容易生怪病现在生活条件好了,超市里面的各种盐,又让人挑得眼花缭乱,分不清好坏关于盐的功效,我们在生活中被很多人科普过,人体失盐过多,便会。
  • 西南哪所大学最好(西南这所211大学明明实力不错)
  • 2024-10-01西南这所211大学明明实力不错211大学,是我国高等教育的中坚力量它们赫赫有名,在生源质量、师资力量、政策支持力度上,远超过其他高校211大学各211大学水平也是参差不齐的北京大学与石河子大学当然不能相提并论,事实上,很多211都。
  • 大豆的营养成分和肉一样吗(大豆被称为植物肉)
  • 2024-10-01大豆被称为植物肉大豆,可分为黄、青、黑、褐等不同的颜色,日常食用最多的是黄豆;大豆制品是由大豆为原料做成的半成品食物,像豆浆、豆腐、豆腐干、千张、素鸡等大豆和大豆制品含有丰富的蛋白质、脂肪、矿物质、淀粉等多种营养素,。
  • (为什么男人有喉结)
  • 2024-10-01为什么男人有喉结喉结往往被视为男性“性感”的标志尤其说话或者吃东西的时候喉结一上一下特别明显但是你有没有想过为什么喉结只有男生有?而大多数的女生都没有呢?今天就给大家科普一下原来性感的喉结可不只是男人的专属女人也有只。