搜索
bottom↓
回复: 0
打印 上一主题 下一主题

《DNESP32S3使用指南-IDF版_V1.6》第五十八章 人脸检测实验

[复制链接]

出0入234汤圆

跳转到指定楼层
1
发表于 2024-8-8 11:41:45 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

1)实验平台:正点原子ESP32S3开发板
2)购买链接:https://detail.tmall.com/item.htm?id=768499342659
3)全套实验源码+手册+视频下载地址:http://www.openedv.com/thread-347618-1-1.html
4)正点原子官方B站:https://space.bilibili.com/394620890
5)正点原子手把手教你学ESP32S3快速入门视频教程:https://www.bilibili.com/video/BV1sH4y1W7Tc
6)正点原子FPGA交流群:132780729



第五十八章 人脸检测实验


       人脸检测是一种基于人工智能(AI)的计算机技术,用于在数字图像中查找和识别人脸。人脸检测技术可应用于各个领域,包括安全、生物识别、执法、娱乐和个人安全等,以提供对人员的实时监控和跟踪。人脸检测技术通过使用算法自动搜索图像/视频帧中的人脸,判断是否存在人脸,并返回人脸的位置、大小和姿态。本章,我们使用乐鑫AI库来实现人脸检测功能。
       本章分为如下几个部分:
       58.1 硬件设计
       58.2 软件设计
       58.3 下载验证

       58.1 硬件设计

       1. 例程功能
       本章实验功能简介:使用乐鑫官方的ESP32-WHO AI库对OV2640和OV5640摄像头输出的数据进行人脸检测。

       2. 硬件资源

       1)LED灯
              LED-IO1

       2)XL9555
              IIC_INT-IO0(需在P5连接IO0)
              IIC_SDA-IO41
              IIC_SCL-IO42

       3)SPILCD
              CS-IO21
              SCK-IO12
              SDA-IO11
              DC-IO40(在P5端口,使用跳线帽将IO_SET和LCD_DC相连)
              PWR- IO1_3(XL9555)
              RST- IO1_2(XL9555)

       4)CAMERA
              OV_SCL-IO38
              OV_SDA- IO39
              VSYNC- IO47
              HREF- IO48
              PCLK- IO45
              D0- IO4
              D1- IO5
              D2- IO6
              D3- IO7
              D4- IO15
              D5- IO16
              D6- IO17
              D7- IO18
              RESET-IO0_5(XL9555)
              PWDN-IO0_4(XL9555)

       3. 原理图
       本章实验使用的KPU为ESP32-S3的内部资源,因此并没有相应的连接原理图。

       58.2 软件设计

       58.2.1 程序流程图
       程序流程图能帮助我们更好的理解一个工程的功能和实现的过程,对学习和设计工程有很好的主导作用。下面看看本实验的程序流程图:

图58.2.1.1 程序流程图

       58.2.2 程序解析
       在本章节中,我们将重点关注两个文件:esp_face_detection.cpp和esp_face_detection.hpp。其中,esp_face_detection.hpp主要声明了esp_face_detection函数,其内容相对简单,因此我们暂时不作详细解释。本章节的核心关注点是esp_face_detection.cpp文件中的函数。
       接下来,我们将详细解析esp_face_detection_ai_strat函数的工作原理。
  1. TaskHandle_t camera_task_handle;
  2. TaskHandle_t ai_task_handle;
  3. QueueHandle_t xQueueFrameO = NULL;
  4. QueueHandle_t xQueueAIFrameO = NULL;


  5. /**
  6. * @brief       摄像头图像数据获取任务
  7. * @param       arg:未使用
  8. * @retval      无
  9. */
  10. static void camera_process_handler(void *arg)
  11. {
  12.     arg = arg;
  13.     camera_fb_t *camera_frame = NULL;

  14.     while (1)
  15.     {
  16.         /* 获取摄像头图像 */
  17.         camera_frame = esp_camera_fb_get();

  18.         if (camera_frame)
  19.         {
  20.             /* 以队列的形式发送 */
  21.             xQueueSend(xQueueFrameO, &camera_frame, portMAX_DELAY);
  22.         }
  23.     }
  24. }

  25. /**
  26. * @brief       摄像头图像数据传入AI处理任务
  27. * @param       arg:未使用
  28. * @retval      无
  29. */
  30. static void ai_process_handler(void *arg)
  31. {
  32.     arg = arg;
  33.     camera_fb_t *face_ai_frameI = NULL;
  34.     HumanFaceDetectMSR01 detector(0.3F, 0.3F, 10, 0.3F);
  35.     HumanFaceDetectMNP01 detector2(0.4F, 0.3F, 10);

  36.     while(1)
  37.     {
  38.         /* 以队列的形式获取摄像头图像数据 */
  39.         if (xQueueReceive(xQueueFrameO, &face_ai_frameI, portMAX_DELAY))
  40.         {
  41.             /* 判断图像是否出现人脸 */
  42.             std::list<dl::detect::result_t> &detect_candidates
  43. = detector.infer((uint16_t *)face_ai_frameI->buf,
  44. {(int)face_ai_frameI->height,
  45. (int)face_ai_frameI->width, 3});
  46.             std::list<dl::detect::result_t> &detect_results
  47. = detector2.infer((uint16_t *)face_ai_frameI->buf,
  48. {(int)face_ai_frameI->height,
  49. (int)face_ai_frameI->width, 3},
  50. detect_candidates);

  51.             if (detect_results.size() > 0)
  52.             {
  53.                 printf("Face detected\r\n");
  54.                 /* 此处是在图像中绘画检测效果 */
  55.                 draw_detection_result((uint16_t *)face_ai_frameI->buf,
  56.                                       face_ai_frameI->height,
  57.                                       face_ai_frameI->width, detect_results);
  58.             }
  59.             else
  60.             {
  61.                 printf("Face not detected\r\n");
  62.             }
  63.             
  64.             /* 以队列的形式发送AI处理的图像 */
  65.             xQueueSend(xQueueAIFrameO, &face_ai_frameI, portMAX_DELAY);
  66.         }
  67.     }
  68. }

  69. /**
  70. * @brief       AI图像数据开启
  71. * @param       无
  72. * @retval      1:创建失败;0:创建成功
  73. */
  74. uint8_t esp_face_detection_ai_strat(void)
  75. {
  76.     /* 创建队列及任务 */
  77.     xQueueFrameO = xQueueCreate(5, sizeof(camera_fb_t *));
  78.     xQueueAIFrameO = xQueueCreate(5, sizeof(camera_fb_t *));
  79. xTaskCreatePinnedToCore(camera_process_handler, "camera_process_handler",
  80. 4 * 1024, NULL, 5, &camera_task_handle, 1);
  81. xTaskCreatePinnedToCore(ai_process_handler, "ai_process_handler",
  82. 6 * 1024, NULL, 5, &ai_task_handle, 1);

  83.     if (xQueueFrameO != NULL
  84.         || xQueueAIFrameO != NULL
  85.         || camera_task_handle != NULL
  86.         || ai_task_handle != NULL)
  87.     {
  88.         return 0;
  89.     }

  90.     return 1;
  91. }
复制代码
       首先,我们创建了两个消息队列和两个任务。这两个消息队列的主要功能是传输图像数据,它们的区别在于一个用于传输原始图像数据,另一个用于传输经过AI处理后的图像数据或者未检测到的图像数据(原始图像数据)。而这两个任务则分别负责图像数据的获取和AI处理。在AI处理任务中,无论检测是否成功,我们都会使用消息队列将AI处理后的图像数据或未检测到的图像数据(原始图像数据)发送到LCD上进行显示。

       58.3 下载验证
       程序下载成功后,如果在检测过程中发现人脸,该系统会将此帧的图像数据发送给人脸检测API进行处理。处理成功后,此帧的图像将被显示在LCD上,如下图所示。

图58.3.1 人脸检测效果图

阿莫论坛20周年了!感谢大家的支持与爱护!!

曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-8-25 12:19

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表