当前位置: 首页 > article >正文

使用 OpenCV 进行视频中的行人检测

在计算机视觉领域,行人检测是一个重要的研究方向,它在视频监控、自动驾驶、人机交互等领域都有着广泛的应用。本文将介绍如何使用 OpenCV 库来实现视频中的行人检测。

环境准备

首先,我们需要安装 OpenCV 库。可以通过以下命令来安装:

pip install opencv-python

代码实现

以下是实现视频中行人检测的代码:

import cv2
import os
import numpy as np
import time

def detect_people():
    current_dir = os.path.dirname(os.path.abspath(__file__))
    video_path = os.path.join(current_dir, 'walk2.mp4')
    
    if not os.path.exists(video_path):
        print(f"Error: 视频文件不存在,请确认文件路径: {video_path}")
        return
    
    # 创建HOG检测器
    hog = cv2.HOGDescriptor()
    hog.setSVMDetector(cv2.HOGDescriptor_getDefaultPeopleDetector())
    
    cap = cv2.VideoCapture(video_path)
    if not cap.isOpened():
        print("Error: 无法打开视频文件")
        return

    # 设置视频捕获的分辨率
    cap.set(cv2.CAP_PROP_FRAME_WIDTH, 640)
    cap.set(cv2.CAP_PROP_FRAME_HEIGHT, 480)
    
    # 用于控制检测频率
    frame_count = 0
    detection_interval = 3  # 每隔3帧进行一次检测
    last_boxes = []

    while True:
        start_time = time.time()
        ret, frame = cap.read()
        if not ret:
            break
            
        # 降低分辨率
        frame = cv2.resize(frame, (640, 480))
        
        # 每隔几帧进行一次检测
        if frame_count % detection_interval == 0:
            # 检测人
            boxes, weights = hog.detectMultiScale(frame, 
                                                winStride=(8, 8),
                                                padding=(4, 4),
                                                scale=1.1)
            last_boxes = boxes
        else:
            boxes = last_boxes
            
        # 在图像上绘制边界框
        for (x, y, w, h) in boxes:
            cv2.rectangle(frame, (x, y), (x+w, y+h), (0, 255, 0), 2)
            
        # 显示人数
        people_count = len(boxes)
        cv2.putText(frame, f'People Count: {people_count}', 
                    (10, 30), cv2.FONT_HERSHEY_SIMPLEX, 1, 
                    (0, 255, 0), 2)
        
        # 计算和显示FPS
        fps = 1.0 / (time.time() - start_time)
        cv2.putText(frame, f'FPS: {int(fps)}', 
                    (10, 60), cv2.FONT_HERSHEY_SIMPLEX, 1, 
                    (0, 255, 0), 2)
        
        # 显示结果
        cv2.imshow('People Detection', frame)
        
        frame_count += 1
        
        # 减小等待时间,提高帧率
        if cv2.waitKey(1) & 0xFF == ord('q'):
            break
    
    cap.release()
    cv2.destroyAllWindows()

if __name__ == '__main__':
    detect_people()

 

 


http://www.kler.cn/a/414635.html

相关文章:

  • 关于Vscode配置Unity环境时的一些报错问题(持续更新)
  • 快速理解微服务中Fegin的概念
  • Zero to JupyterHub with Kubernetes中篇 - Kubernetes 常规使用记录
  • Windows 11 搭建 Docker 桌面版详细教程
  • macOS 桌面悬浮窗口
  • 山峰数(hill)
  • 【Web前端】如何构建简单HTML表单?
  • Vue 路由配置与环境差异问题解析:开发与生产环境中的行为差异
  • 大数据新视界 -- Hive 函数应用:复杂数据转换的实战案例(下)(12/ 30)
  • 解决 Vim 上下左右变成 ABCD 的问题
  • 技术总结(四十)
  • springboot331“有光”摄影分享网站系统pf(论文+源码)_kaic
  • CTF-RE 从0到 N: 高版本 APK 调试 + APK逻辑修改再打包 + os层调试[2024 强网杯青少年专项赛 Flip_over] writeup
  • 50-基于单片机和传感器的冷链运输设计
  • 实战丨证券 HTAP 混合业务场景的难点问题应对
  • python代码示例(读取excel文件,自动播放音频)
  • Flink (Windows Function 窗口函数)
  • [Maven]3.5.3配置
  • HTTP超文本协议
  • Python轴承故障诊断 (21)基于VMD-CNN-BiTCN的创新诊断模型
  • C++练级计划-> 《IO流》iostream fstream sstream详解
  • 操作系统 | 学习笔记 | 王道 | 2.1 进程与线程
  • 若依前端报错 components.at is not a function
  • JVM(JAVA虚拟机)内存溢出导致内存不足,Java运行时环境无法继续
  • 外卖点餐系统小程序
  • LeetCode --- 424周赛