iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >python进阶——人工智能实时目标跟踪
  • 687
分享到

python进阶——人工智能实时目标跟踪

人工智能python计算机视觉目标跟踪 2023-09-05 06:09:23 687人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

  大家好,我是csdn的博主:lqj_本人 这是我的个人博客主页:lqj_本人的博客_CSDN博客-微信小程序,前端,Vue领域博主lqj_本人擅长微信小程序,前端,vue,等方面的知识https://blog.csdn.net/l

  大家好,我是csdn的博主:lqj_本人

这是我的个人博客主页:lqj_本人的博客_CSDN博客-微信小程序,前端,Vue领域博主lqj_本人擅长微信小程序,前端,vue,等方面的知识https://blog.csdn.net/lbcyllqj?spm=1000.2115.3001.5343

哔哩哔哩欢迎关注:小淼前端

小淼前端的个人空间_哔哩哔哩_bilibili

本篇文章主要讲述python人工智能目标跟踪,本篇文章已经成功收录到我们Python专栏中:Https://blog.csdn.net/lbcyllqj/cateGory_12089557.htmlhttps://blog.csdn.net/lbcyllqj/category_12089557.html

目录

前言

项目介绍

区域性锁定目标实时动态跟踪(适用 警方追捕,无人机锁定拍摄等)

首先先介绍几种AI视觉算法

详细代码讲解

完整代码及注释:

结果演示

区域性全部实时动态目标跟踪(适用夜视跟踪,范围性观察等)

思路构建

详细代码讲解

完整代码及注释:

结果显示


前言

本程序主要实现了python的OpenCV人工智能视觉模块的目标跟踪功能。

若不知道怎么安装opencv或者使用的请看我的这篇文章(曾上过csdn综合热榜的top1):

python进阶——人工智能视觉识别_lqj_本人的博客-CSDN博客

项目介绍

区域性定目标实时动态跟踪(适用 警方追捕,无人机锁定拍摄等)

 首先先介绍几种ai视觉算法

特性:

1.BOOSTING:算法原理类似于Harr cascdes(AdaBoost),是一种很老的算法。这个算法速度慢并且不准。

2.MIL:比BOOSTING准一点

3.KCF:速度比BOOSTING和MIL更快,与BOOSTING和MIL一样不能很好的处理遮挡问题。

4.CSRT:比KCF更准一些,但是速度比KCF慢

5.MedianFlow:对于快速移动的目标和外形比那花迅速的目标效果不好

6.TLD:会产生朵的false-posittives

7.MOSSE:算法速度非常快,但是准确率比不上KCF和CSRT,在一些追求算法的速度场合很适用

8.GOTURN:OpenCV中自带的唯一一个基于深度学习的算法,运行短发需要提前下载好模型文件

分别对应的伴生的函数:

kcf:cv2.legacy.TrackerKCF_createcsrt:cv2.legacy.TrackerCSRT_createboosting:cv2.legacy.TrackerBoosting_createmil:cv2.legacy.TrackerMIL_createtld:cv2.legacy.TrackerTLD_createmedianflow:cv2.legacy.TrackerMedianFlow_createmosse:cv2.legacy.TrackerMOSSE_create

详细代码讲解

导入cv模块

import cv2

使用csrt算法,引用伴生函数,并赋值给tracker

tracker = cv2.legacy.TrackerCSRT_create()

读取视频流

cap = cv2.VideoCapture('11.mp4')

先读取到第一帧

ret,frame = cap.read()

使用selectROI(前景),画框将目标框起,并赋值给bbox

bbox = cv2.selectROI('A',frame,fromCenter=False,showCrosshair=True)

初始化tracker,将上面的两个值传入

tracker.init(frame,bbox)

读取每一帧

ret,frame = cap.read()

根据每一帧来更新tracker

ok,box = tracker.update(frame)

若读取成功,就定位画框,并跟随

    if ok :        (x,y,w,h) = [int(v) for v in box]        cv2.rectangle(frame,pt1=(int(x),int(y)),pt2=(int(x)+int(w),int(y)+int(h)),color=(0,255,0),thickness=2)

显示视频流

cv2.imshow('A', frame)

等待50毫秒或按空格键退出

    if cv2.waiTKEy(50) == ord(' '):        break

 释放视频流和释放窗口

cap.release()cv2.destroyAllwindows()

完整代码及注释:

import cv2tracker = cv2.legacy.TrackerCSRT_create()#使用csrt算法,引用伴生函数,并赋值给trackercap = cv2.VideoCapture('11.mp4')#读取视频流ret,frame = cap.read()#先读取第一帧bbox = cv2.selectROI('A',frame,fromCenter=False,showCrosshair=True)#使用selectROI(前景),画框将目标框起,并赋值给bboxtracker.init(frame,bbox)#初始化tracker,将上面的两个值传入while True:    ret,frame = cap.read()#读取每一帧    ok,box = tracker.update(frame)#根据每一帧来跟新tracker    # 若读取成功,我们就定位画框,并跟随    if ok :        (x,y,w,h) = [int(v) for v in box]        cv2.rectangle(frame,pt1=(int(x),int(y)),pt2=(int(x)+int(w),int(y)+int(h)),color=(0,255,0),thickness=2)    cv2.imshow('A', frame)#显示视频流    if cv2.waitKey(50) == ord(' '):#等待50毫秒或键盘按空格键退出        break# 释放视频流,释放窗口cap.release()cv2.destroyAllWindows()

结果演示

区域性全部实时动态目标跟踪(适用夜视跟踪,范围性观察等)

思路构建

1.先将实时摄像流或录制视频流,灰度转化并高斯模糊

2.用二值化算法将流中的物体轮廓扩充

3.分别先读到第一帧和第二帧,让其对比

4.寻找对比后,流的轮廓位置,并开启简易模式

5.过滤物体的矩阵轮廓将其定位绘出

详细代码讲解

导入cv模块

import cv2

将视频流转换并让其高斯模糊

    gray = cv2.cvtColor(frame,cv2.COLOR_BGR2GRAY)    blur = cv2.GaussianBlur(gray,(5,5),0)

二值化扩充

    _,thresh = cv2.threshold(blur,20,255,cv2.THRESH_BINARY)    dilated = cv2.dilate(thresh,None,iterations=3)    return dilated

读取视频流或实时摄像流

cap = cv2.VideoCapture('11.mp4')

读取第一帧

ret,frame1 = cap.read()

读取第二帧

ret,frame2 = cap.read()

判断cap是否为打开状态

while cap.isOpened():

若为打开,则第一帧与第二帧比较

diff = cv2.absdiff(frame1,frame2)mask = filter_img(diff)

寻找比较后的物体轮廓,并开启简易模式

contours,_ = cv2.findContours(mask,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)

使用方框将视频流中的物体框出,得到矩阵的宽高

(x,y,w,h) = cv2.boundingRect(contour)

若矩阵的面积小于10(根据视频流中物体的大小来定义),直接无视

if cv2.contourArea(contour) < 10:

将过滤的物体的矩阵轮廓绘出(一定要用int整形)

cv2.rectangle(frame1,pt1=(int(x),int(y)),pt2=(int(x)+int(w),int(y)+int(h)),color=(0,255,0),thickness=1)

将第一帧显示

cv2.imshow('A',frame1)

将上面赋值的mask显示

cv2.imshow('B',mask)

实现前后帧对比,并定位物体运动轨迹

将第二帧赋值给第一帧

frame1 = frame2

再将cap读到的赋值给第二帧()

ret,frame2 = cap.read()

等待50毫秒或者按空格结束

    if cv2.waitKey(50) == ord(' '):        break

释放视频流及释放窗口

cap.release()cv2.destroyAllWindows()

 完整代码及注释:

import cv2def filter_img(frame):    #将视频流转换灰度并让其高斯模糊    gray = cv2.cvtColor(frame,cv2.COLOR_BGR2GRAY)    blur = cv2.GaussianBlur(gray,(5,5),0)    #二值化将其扩充    _,thresh = cv2.threshold(blur,20,255,cv2.THRESH_BINARY)    dilated = cv2.dilate(thresh,None,iterations=3)    return dilated# 读取视频流cap = cv2.VideoCapture('11.mp4')ret,frame1 = cap.read()#读到第一帧ret,frame2 = cap.read()#读到第二帧while cap.isOpened():#判断cap是否打开    diff = cv2.absdiff(frame1,frame2)#若打开,则第一帧和第二帧作比较    mask = filter_img(diff)    contours,_ = cv2.findContours(mask,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)#寻找视频流的轮廓,简单模式    #用方框将视频流中的物体用矩形框出    for contour in contours:        (x,y,w,h) = cv2.boundingRect(contour)#得到矩阵的宽高        if cv2.contourArea(contour) < 10:#若矩阵的面积小于200,就无视(太小了)            continue        cv2.rectangle(frame1,pt1=(int(x),int(y)),pt2=(int(x)+int(w),int(y)+int(h)),color=(0,255,0),thickness=1)#将过滤的物体的矩阵轮廓绘出    # cv2.drawContours(frame1,contours,-1,(0,255,0),2)#将视频流中的物体轮廓画出    cv2.imshow('A',frame1)#将第一帧显示    cv2.imshow('B',mask)#将mask也显示    frame1 = frame2#将第二帧赋值给第一帧    ret,frame2 = cap.read()#再将cap读到的赋值给第二帧    if cv2.waitKey(50) == ord(' '):#等待五十毫秒或者按空格结束        break#销毁cap流cap.release()#释放窗口cv2.destroyAllWindows()

结果显示

来源地址:https://blog.csdn.net/lbcyllqj/article/details/128857299

--结束END--

本文标题: python进阶——人工智能实时目标跟踪

本文链接: https://www.lsjlt.com/news/394857.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • python进阶——人工智能实时目标跟踪
      大家好,我是csdn的博主:lqj_本人 这是我的个人博客主页:lqj_本人的博客_CSDN博客-微信小程序,前端,vue领域博主lqj_本人擅长微信小程序,前端,vue,等方面的知识https://blog.csdn.net/l...
    99+
    2023-09-05
    人工智能 python 计算机视觉 目标跟踪
  • python进阶学习实时目标跟踪示例详解
    目录前言项目介绍首先先介绍几种AI视觉算法详细代码讲解完整代码及注释: 完整代码及注释:结果显示前言 本程序主要实现了python的opencv人工智能视觉模块的目标跟踪...
    99+
    2023-03-21
    python进阶实时目标跟踪 python目标跟踪
  • python实时目标跟踪怎么实现
    这篇“python实时目标跟踪怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“python实时目标跟踪怎么实现”文章吧...
    99+
    2023-07-05
  • python进阶——人工智能视觉识别
      大家好,我是csdn的博主:lqj_本人 这是我的个人博客主页:lqj_本人的博客_CSDN博客-微信小程序,前端,vue领域博主lqj_本人擅长微信小程序,前端,vue,等方面的知识https://blog.csdn.net/l...
    99+
    2023-09-04
    python 人工智能 开发语言
  • python+opencv实现目标跟踪
    python-opencv3.0新增了一些比较有用的追踪器算法,这里根据官网示例写了一个追踪器类 程序只能运行在安装有opencv3.0以上版本和对应的contrib模块的python解释器   #encoding=utf-8 imp...
    99+
    2023-01-31
    目标 python opencv
  • python+opencv实现目标跟踪过程
    目录python opencv实现目标跟踪这里根据官网示例写了一个追踪器类python opencv实现目标跟踪 python-opencv3.0新增了一些比较有用的追踪器算法 这里...
    99+
    2024-04-02
  • python使用OpenCV实现多目标跟踪
    目录1 背景介绍2 基于MultiTracker的多目标跟踪2.1 创建单个对象跟踪器2.2 读取视频的第一帧2.3 在第一帧中确定我们跟踪的对象2.4 初始化MultiTracke...
    99+
    2024-04-02
  • 基于OpenCV目标跟踪实现人员计数器
    目录1.了解对象检测与对象跟踪2.结合对象检测和对象跟踪3.项目结构4.结合对象跟踪算法5.创建可追踪对象6.使用OpenCV+Python实现我们的人员计数器7.完整代码peopl...
    99+
    2024-04-02
  • Python OpenCV如何使用dlib进行多目标跟踪
    这篇文章主要讲解了“Python OpenCV如何使用dlib进行多目标跟踪”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python OpenCV如何使用dlib进行多...
    99+
    2023-06-29
  • 人工智能学习Pytorch进阶操作教程
    目录一、合并与分割1.cat拼接2.stack堆叠3.拆分①Split按长度拆分②Chunk按数量拆分二、基本运算1.加减乘除2.矩阵相乘3.次方计算4. clamp三、属性统计1....
    99+
    2024-04-02
  • python怎么使用OpenCV实现多目标跟踪
    这篇文章主要介绍“python怎么使用OpenCV实现多目标跟踪”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“python怎么使用OpenCV实现多目标跟踪”文章能帮助大家解决问题。1 背景介绍计算...
    99+
    2023-06-30
  • Python PyTorch:开启人工智能新时代
    Python PyTorch,人工智能新时代的开拓者,凭借其强大的人工智能功能和简便易用的特性,受到越来越多开发人员和研究人员的青睐。在本文中,我们将深入探讨Python PyTorch,并通过一系列演示代码,展示其在人工智能领域中的应用...
    99+
    2024-02-02
    Python PyTorch 人工智能 深度学习 机器学习
  • 人工智能实战项目(python)+多领域实战练手项目
    人工智能实战项目 大家好,我是微学AI,本项目将围绕人工智能实战项目进行展开,紧密贴近生活,实战项目设计多个领域包括:金融、教育、医疗、地理、生物、人文、自然语言处理等;帮助各位读者结合机器学习与深度学习构建智能而且实用的人工智能简单系统,...
    99+
    2023-09-08
    人工智能 深度学习 计算机视觉 知识图谱
  • Python实现人脸识别并进行视频跟踪打码
    目录前言准备工作代码实战效果展示前言 事情是这样的,昨天去表弟家,用了下他的电脑,不小心点到了他硬盘里隐藏的秘密,本来我只需要用几分钟电脑的,害得我硬是在电脑旁坐了几个小时~ 还好他...
    99+
    2023-03-06
    Python人脸识别 Python视频打码 Python人脸识别 视频打码
  • 人工智能-Python实现岭回归
    1 概述 1.1 线性回归 对于一般地线性回归问题,参数的求解采用的是最小二乘法,其目标函数如下: 1.2 岭回归  岭回归(ridge regression) 是一种...
    99+
    2024-04-02
  • 详解Python人工智能混合高斯模型运动目标检测
    本篇内容主要讲解“详解Python人工智能混合高斯模型运动目标检测”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“详解Python人工智能混合高斯模型运动目标检测”吧!高斯算法提取工作import...
    99+
    2023-06-25
  • 人工智能—Python实现线性回归
    1、概述 (1)人工智能学习           (2)机器学习  (3)有监督学习  (4)线...
    99+
    2024-04-02
  • Python实现视频目标检测与轨迹跟踪流程详解
    目录一、原理二、代码实现1.增加多模板匹配机制2.增加轨迹平滑三、测试对比一、原理 核心思想比较简单。即通过不同旋转角度的模板同时匹配,在多个结果中,找到相似度最大的结果,即认为匹配...
    99+
    2023-01-28
    Python视频目标检测 Python视频轨迹跟踪
  • Python如何实现人脸识别并进行视频跟踪打码
    这篇文章主要介绍了Python如何实现人脸识别并进行视频跟踪打码的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python如何实现人脸识别并进行视频跟踪打码文章都会有所收获,下面我们一起来看看吧。准备工作首先需...
    99+
    2023-07-05
  • Python使用OPENCV的目标跟踪算法实现自动视频标注效果
    先上效果  1.首先,要使用opencv的目标跟踪算法,必须要有opencv环境  使用:opencv==4.4.0 和 opencv-contri...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作