前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >基于米尔全志T527开发板的OpenCV行人检测方案

基于米尔全志T527开发板的OpenCV行人检测方案

原创
作者头像
用户10591265
发布于 2025-04-11 10:23:23
发布于 2025-04-11 10:23:23
8000
代码可运行
举报
文章被收录于专栏:米尔电子米尔电子
运行总次数:0
代码可运行

本文将介绍基于米尔电子MYD-LT527开发板(米尔基于全志T527开发板)的OpenCV行人检测方案测试。

摘自优秀创作者-小火苗


一、软件环境安装

1.在全志T527开发板安装OpenCV

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo apt-get install libopencv-dev python3-opencv

2.在全志T527开发板安装pip

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo apt-get install python3-pip

二、行人检测概论

使用HOG和SVM基于全志T527开发板构建行人检测器的关键步骤包括:

  • 准备训练数据集:训练数据集应包含大量正样本(行人图像)和负样本(非行人图像)。
  • 计算HOG特征:对于每个图像,计算HOG特征。HOG特征是一个一维向量,其中每个元素表示图像中特定位置和方向的梯度强度。
  • 训练SVM分类器:使用HOG特征作为输入,训练SVM分类器。SVM分类器将学习区分行人和非行人。
  • 评估模型:使用测试数据集评估训练后的模型。计算模型的准确率、召回率和F1分数等指标。

三、代码实现

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import cv2
import time
def detect(image,scale):
    imagex=image.copy()   #函数内部做个副本,让每个函数运行在不同的图像上
    hog = cv2.HOGDescriptor()   #初始化方向梯度直方图描述子
    #设置SVM为一个预先训练好的行人检测器
    hog.setSVMDetector(cv2.HOGDescriptor_getDefaultPeopleDetector())
    #调用函数detectMultiScale,检测行人对应的边框
    time_start = time.time()     #记录开始时间
    #获取(行人对应的矩形框、对应的权重)
    (rects, weights) = hog.detectMultiScale(imagex,scale=scale)
    time_end = time.time()    #记录结束时间 
    # 绘制每一个矩形框
    for (x, y, w, h) in rects:
        cv2.rectangle(imagex, (x, y), (x + w, y + h), (0, 0, 255), 2)
    print("sacle size:",scale,",time:",time_end-time_start)
    name=str(scale)
    cv2.imshow(name, imagex)     #显示原始效果
image = cv2.imread("back.jpg")
detect(image,1.01)
detect(image,1.05)
detect(image,1.3)
cv2.waitKey(0)
cv2.destroyAllWindows()

四、实际操作

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、软件环境安装
    • 1.在全志T527开发板安装OpenCV
    • 2.在全志T527开发板​安装pip
  • 二、行人检测概论
  • 三、代码实现
  • 四、实际操作
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档