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

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

[复制链接]

出0入234汤圆

跳转到指定楼层
1

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库来实现猫脸检测功能。
       本章分为如下几个部分:
       60.1 硬件设计
       60.2 软件设计
       60.3 下载验证

       60.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的内部资源,因此并没有相应的连接原理图。

       60.2 软件设计

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

图60.2.1.1 程序流程图

       60.2.2 程序解析
       在本章节中,我们将重点关注两个文件:esp_cat_detection.cpp和esp_cat_detection.hpp。其中,esp_cat_detection.hpp主要声明了esp_cat_detection函数,其内容相对简单,因此我们暂时不作详细解释。本章节的核心关注点是esp_cat_detection.cpp文件中的函数。
       接下来,我们将详细解析esp_cat_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 esp_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 esp_ai_process_handler(void *arg)
  31. {
  32.     arg = arg;
  33.     camera_fb_t *face_ai_frameI = NULL;
  34.     CatFaceDetectMN03 detector(0.4F, 0.3F, 10, 0.3F);

  35.     while(1)
  36.     {
  37.         /* 以队列的形式获取摄像头图像数据 */
  38.         if (xQueueReceive(xQueueFrameO, &face_ai_frameI, portMAX_DELAY))
  39.         {
  40.             std::list<dl::detect::result_t> &detect_results =
  41.               detector.infer((uint16_t *)face_ai_frameI->buf,
  42.               {(int)face_ai_frameI->height, (int)face_ai_frameI->width, 3});
  43.             
  44.             if (detect_results.size() > 0)
  45.             {
  46.                 ESP_LOGE("Camera", "Cat Face detected");
  47.                 /* 此处是在图像中绘画检测效果 */
  48.                 draw_detection_result((uint16_t *)face_ai_frameI->buf,
  49. face_ai_frameI->height,
  50. face_ai_frameI->width,
  51. detect_results);
  52.             }
  53.             else
  54.             {
  55.                 ESP_LOGE("Camera", "Cat Face not detected");
  56.             }
  57.             /* 以队列的形式发送AI处理的图像 */
  58.             xQueueSend(xQueueAIFrameO, &face_ai_frameI, portMAX_DELAY);
  59.         }
  60.     }
  61. }

  62. /**
  63. * @brief       AI图像数据开启
  64. * @param       无
  65. * @retval      1:创建失败;0:创建成功
  66. */
  67. uint8_t esp_cat_face_detection_ai_strat(void)
  68. {
  69.     /* 创建队列及任务 */
  70.     xQueueFrameO = xQueueCreate(5, sizeof(camera_fb_t *));
  71.     xQueueAIFrameO = xQueueCreate(5, sizeof(camera_fb_t *));
  72. xTaskCreatePinnedToCore(esp_camera_process_handler,
  73.                        "esp_camera_process_handler", 4 * 1024, NULL,
  74. 5, &camera_task_handle, 1);
  75. xTaskCreatePinnedToCore(esp_ai_process_handler, "esp_ai_process_handler",
  76. 6 * 1024, NULL, 5, &ai_task_handle, 1);
  77.     if (xQueueFrameO != NULL
  78.         || xQueueAIFrameO != NULL
  79.         || camera_task_handle != NULL
  80.         || ai_task_handle != NULL)
  81.     {
  82.         return 0;
  83.     }
  84.     return 1;
  85. }
复制代码
       首先,我们创建了两个消息队列和两个任务。这两个消息队列的主要功能是传输图像数据,它们的区别在于一个用于传输原始图像数据,另一个用于传输经过AI处理后的图像数据或者未检测到的图像数据(原始图像数据)。而这两个任务则分别负责图像数据的获取和AI处理。在AI处理任务中,无论检测是否成功,我们都会使用消息队列将AI处理后的图像数据或未检测到的图像数据(原始图像数据)发送到LCD上进行显示。

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

图60.4.1 猫脸检测效果图

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

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

本版积分规则

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

GMT+8, 2024-8-15 01:07

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

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