0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

【EASY EAI Nano开源套件试用体验】4AI功能测试之人脸检测

开发板试用精选 来源:开发板试用 作者:电子发烧友论坛 2022-10-11 16:40 次阅读

本文来源电子发烧友社区,作者:码农爱学习, 帖子地址:https://bbs.elecfans.com/jishu_2307951_1_1.html


EASY EAI Nano AI人脸检测测试(附上体验视频,详细见原作者帖子)

本篇介绍EASY EAI Nano的AI人脸检测功能,先看下测试效果:

1.jpg

本篇参考官方文档:https://www.easy-eai.com/document_details/3/109

1 代码下载

下载官方测试代码:https://github.com/EASY-EAI/EASY-EAI-Toolkit-C-Solution.git,本篇来修改face_detect中的代码并测试。

下载AI算法模型face_detect.model,百度网盘:https://pan.baidu.com/s/1mrhVHxHWJ8cY9Fl9k5KtYg#list/path=%2F提取码:0k7j

总的资料百度网盘了也有算法模型:https://pan.baidu.com/s/1AjOIu77mzFM4cDA0MMVr2A#list/path=%2F,提取码:5ttf

我先使用总的资料里下载的模型测试。

2 人脸检测API接口介绍

组件 头文件以及库路径 描述
系统操作组件 easyeai-api/common_api/system_opt 提供线程操作函数
摄像头组件 easyeai-api/peripheral_api/camera 提供摄像头操作函数
显示屏组件 easyeai-api/peripheral_api/display 提供显示屏操作函数
人脸检测组件 easyeai-api/algorithm_api/face_detect 提供人脸检测操作函数

主要来看下人脸检测组件。

face_detect.h主要内容如下,包括一个det(detect)类的3个人脸检测API函数:

class det {
public:
    det(){
landmarks.resize(5);
    }
    ~det(){
    }
​
    bool operator<(const det &t) const {
return score < t.score;
}
​
    bool operator>(const det &t) const {
return score > t.score;
}
​
    cv::Rect_ box;
    std::vector landmarks;
    float score;
​
    void print() {
printf("finalbox(x1y1x2y2) %f %f %f %f, score %fn", box.x, box.y, box.br().x, box.br().y, score);
printf("landmarks ");
int point_number = landmarks.size();
for (int i = 0; i < point_number; i++) {
printf("%f %f, ", landmarks[i].x, landmarks[i].y);
}
printf("n");
}
    
};
​
int face_detect_init(rknn_context *ctx, const char *path);
​
int face_detect_run(rknn_context ctx, cv::Mat &input_image, std::vector &result);
​
int face_detect_release(rknn_context ctx);

一些参数

  • ctx:输入参数,rknn_context句柄
  • path:输入参数,算法模型路径
  • input_image:输入参数, Opencv Mat格式图像
  • result:输出参数, 人脸检测的结果输出

3 代码分析与修改

官方例程使用的是双目摄像头中的RGB摄像头,本篇测试修改为使用外接USB摄像头来采集图像,并将采集的图像横屏显示。另外,在识别到人脸后,通过OpenCV函数,在屏幕左上角显示出识别到的人脸个数。

3.1 图像采集与显示线程(主线程)

修改后的主程序逻辑如下:

2.png

主要代码结构如下:

Mat algorithm_image;
pthread_mutex_t img_lock;
​
int main(int argc, char **argv)
{
//省略...
pthread_t mTid;
Result_t Result;
Mat image;
// 1.打开USB摄像头
//省略...
// 2.创建识别线程,以及图像互斥锁
pthread_mutex_init(&img_lock, NULL);
Result.result.clear();
Result.face_number = 0;
CreateNormalThread(detect_thread_entry, &Result, &mTid);
// 3.显示初始化
    //省略...
// 4.(取流 + 显示)循环
while(1){
// 4.1、取流
pthread_mutex_lock(&img_lock);
ret = usbcamera_getframe(USB2_0, USB_DIRECT, pbuf);
if (ret) {
printf("error: %s, %dn", __func__, __LINE__);
pthread_mutex_unlock(&img_lock);
continue;
}
algorithm_image = Mat(CAMERA_HEIGHT, CAMERA_WIDTH, CV_8UC3, pbuf);
image = algorithm_image.clone();
pthread_mutex_unlock(&img_lock);
// 4.2、显示
        cv::putText(image, std::string("detect faces: ") + std::to_string((int)Result.result.size()), 
                    cv::Point2f(30, 50), cv::FONT_HERSHEY_SIMPLEX,1.45, CV_RGB(255,0,0),3.0);
for (int i = 0; i < (int)Result.result.size(); i++)
{
// 标出人脸框
int x = (int)(Result.result[i].box.x);
int y = (int)(Result.result[i].box.y);
int w = (int)(Result.result[i].box.width);
int h = (int)(Result.result[i].box.height);
rectangle(image, Rect(x, y, w, h), Scalar(0, 255, 0), 2, 8, 0);
// 标出人脸定位标记
for (int j = 0; j < (int)Result.result[i].landmarks.size(); ++j) {
cv::circle(image, cv::Point((int)Result.result[i].landmarks[j].x, (int)Result.result[i].landmarks[j].y), 2, cv::Scalar(0, 255, 0), 3, 8);
}
}
        disp_commit(image.data, IMAGE_SIZE);

        usleep(20*1000);
}
​
//省略...
}

3.2 人脸检测处理

人脸检测处理序逻辑如下:

3.png

代码如下:

// 识别线程
void *detect_thread_entry(void *para)
{
int ret;
Result_t *pResult = (Result_t *)para;

// 人脸检测初始化
rknn_context ctx;
face_detect_init(&ctx, "face_detect.model");

Mat image;
while(1)
{
        if(algorithm_image.empty()) {
usleep(5);
            continue;
        }

pthread_mutex_lock(&img_lock);
image = algorithm_image.clone();
pthread_mutex_unlock(&img_lock);
// 算法分析
ret = face_detect_run(ctx, image, pResult->result);
pResult->face_number = pResult->result.size();
if(ret <= 0){
pResult->result.clear();
usleep(1000);
continue;
}

printf("n>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>n");
printf("face number : %dn", pResult->face_number);

        usleep(16*1000);
}
/* 人脸检测释放 */
face_detect_release(ctx);
return NULL;
}

4 测试

测试效果如下,可以同时检测到多张人脸,在屏幕左上角标注有检测到的人脸个数:

4.png

5 总结

本篇介绍了EASY EAI Nano的AI人脸检测功能,修改官方代码,改用外接USB摄像头来采集图像,并在识别到人脸后,通过OpenCV函数,在屏幕左上角显示出识别到的人脸个数。


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 开发板
    +关注

    关注

    25

    文章

    4979

    浏览量

    97272
  • 灵眸
    +关注

    关注

    0

    文章

    19

    浏览量

    3190
收藏 人收藏

    评论

    相关推荐

    如何用OpenCV的相机捕捉视频进行人脸检测--基于米尔NXP i.MX93开发板

    本篇测评由优秀测评者“eefocus_3914144”提供。 本文将介绍基于米尔电子MYD-LMX93开发板(米尔基于NXP i.MX93开发板)的基于OpenCV的人脸检测方案测试。 OpenCV
    发表于 11-15 17:58

    基于迅为RK3568/RK3588开发板的AI图像识别方案

    01_官方模型测试 02_人脸识别 03_口罩检测 04_工地防护 05_扑克牌识别 06_手掌关键点检测 07_人脸特征点
    发表于 08-28 09:50

    人脸检测模型有哪些

    人脸检测是计算机视觉领域的一个重要研究方向,它涉及到从图像或视频中检测出人脸的位置和大小。随着深度学习技术的发展,人脸检测模型的性能得到了显
    的头像 发表于 07-03 17:05 953次阅读

    人脸检测人脸识别的区别是什么

    人脸检测人脸识别是计算机视觉领域的两个重要技术,它们在许多应用场景中都有广泛的应用,如安全监控、身份验证、社交媒体等。尽管它们在某些方面有相似之处,但它们之间存在一些关键的区别。本文将详细介绍
    的头像 发表于 07-03 14:49 991次阅读

    聆思CSK6视觉语音大模型AI开发板入门资源合集(硬件资料、大模型语音/多模态交互/英语评测SDK合集)

    自定义大模型应用并接入到开发套件上实现语音交互,由浅入深地展示如何开发自己的大模型助手。 离线AI能力示例SDK清单 序号AI 能力 1语音唤醒 + 坐姿检测 2语音合成 3坐姿
    发表于 06-18 17:33

    谷歌安卓系统引入AI诈骗电话检测功能

    谷歌解释称,新功能依靠本地运行的Gemini Nano模型。当AI系统监测到异常信息(如银行工作人员查询密码等隐私信息)时,便会触发警报。
    的头像 发表于 05-15 11:16 355次阅读

    【LicheeRV-Nano开发套件试用体验】LicheeRV-Nano上的IAI技术应用

    开发板,之前试用过 DUO对其清奇骨骼,小巧的身板,强劲的性能所吸引,在知道其更加强悍的兄弟板出来后,第一时间申请到试用。 此次开发板包含物料比较充分,除了有Nano开发板,还有带触摸的全贴合屏幕
    发表于 03-07 17:32

    【LicheeRV-Nano开发套件试用体验】+智能平板开发

    开发 6.摄像头开发 7.AI人脸识别、运动侦测、姿态检测调试开发 预期成果 1.熟练算能软件工具使用,代码编写调试 2.外设功能驱动达成相应效果 3.网络、音频调通
    发表于 03-06 23:05

    【LicheeRV-Nano开发套件试用连载体验】+ 实现三麦克纳姆轮小车自主导航

    【LicheeRV-Nano开发套件试用连载体验】+ 实现三麦克纳姆轮小车自主导航 非常感谢被选中成为Sipeed矽速科技、电子发烧友论坛组织的此次试用体验幸运儿,有机会参与
    发表于 03-03 14:20

    EASY-EAI携手Hailo推出高性能、高算力的边缘AI硬件组合

    EASY-EAI与Hailo建立合作关系,共同推出高算力的边缘AI产品组合。
    的头像 发表于 02-21 09:56 786次阅读

    对基于 FPGA 的 AI 视觉应用进行基准测试

    ,这里没有运行 NLP-SmartVision 或 AI。 操作系统 没有人工智能 独立式 31-64 PetaLinux GStreamer 140-190 USB摄像头 操作系统 人脸检测 物体
    发表于 02-02 10:26

    【新品体验】LicheeRV-Nano开发套件免费试用

    名单:2024年 2 月 27 日 3. 发货日期:2024年 2 月 28 日 4. 试用期限:2024年 2 月 28 日 - 2024年 3 月 28 日 点击立即申请&gt;&gt;
    发表于 01-26 16:34

    EASY EAI Nano】RV1126实时读取摄像头并进行yolo检测显示

    实现了三个并行模块,分别是 摄像头读取,使用opencv转换到适合大小 yolo检测 托管到Qt进行现实 检测的DEMO从每帧10次改到每帧2次,可以看到还是具备一定实时性。 代码:仓库
    发表于 01-14 18:53

    【飞腾派4G版免费试用】飞腾派SeetafaceEngine人脸对齐(PART2)

    继续玩飞腾派。。。 接着上一篇【飞腾派4G版免费试用】飞腾派SeetafaceEngine人脸检测 继续补充。 FaceAlignment人脸
    发表于 12-19 09:57

    【飞腾派4G版免费试用】飞腾派SeetafaceEngine人脸检测

    使用的OpenCV版本是早期OpenCV–2.4.11,需手工修改为支持OpenCV-4.x版本函数。Seetaface包含 人脸检测FaceDetection 、 人脸对齐FaceA
    发表于 12-18 10:53