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

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

3天内不再提示

项目分享|基于ELF 1开发板的远程监测及人脸识别项目

ElfBoard 2024-03-13 16:41 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

今天非常荣幸地向各位小伙伴分享一个由共创社成员完成的远程监测及人脸识别项目,该项目依托ELF 1开发板为核心硬件平台,构建了一套完整的视频监控系统,并在此基础上集成了人脸识别功能。接下来,就为各位小伙伴详尽展示这一项目的相关细节。

项目实现步骤

1.视频监控

这一步骤中需要实现两个程序:

(1)在连接摄像头的ELF 1开发板上实现一个服务器程序:它一边读取摄像头数据,一边等待客户端连接并发送数据。可以用两个线程实现,一个负责采集图像信息;一个负责等待链接,并发送数据。

(2)在手机电脑上,编写客户端程序,它会从ELF 1开发板上获得数据并显示出来。同样,也可以用两个线程来实现。一个负责接受数据,一个负责显示数据。这2个程序之间,并不需要实现复杂的协议。

MJPG‐streamer是一个开源软件。MJPG-streamer从Linux UVC兼容的网络摄像头、文件系统或其他输入插件获取JPG,并通过HTTP、RTSP、UDP等将其作为M-JPEG流式传输到WebBrowser、VLC和其他软件。

MJPG-streamer 需要很少的CPU和内存资源就可以工作,大部分编码工作都是摄像头完成的,所以对于内存和性能都有限的嵌入式系统十分适用。

将MJPG-streamer移植并运行在ARM板上,在同一局域网内的设备输入正确的ip地址即可直接观看到视频画面。对ARM板的性能要求不高,主频200MHz的ARM芯片也能实现。

下载MJPG-streamer:

git clone https://github.com/shrkey/mjpg-streamer

启动MJPG-streamer后,输入ip地址以及端口号即可看到摄像头内容如下图:

wKgaomXxZX2AHZ8CAAdzp1_venQ147.png

同时后续人脸识别功能中需要能够从视屏流中提取出照片,需要修改MJPG-streamer源码,使其支持拍照功能。具体修改如下:

修改完成之后只要向有名管道/tmp/webcom写入相应的字符串就能实现拍照功能。

# cd mjpg-streamer-rc63/plugins/output_file # vim output_file.c //在96行 函数 void*worker_thread(void *arg) 体中加入以下代码: charbuf[10]; // intflags = 0; // intfd_com = 0; //打开管道 stop_num = 0; //拍照计数 if ( access(“/tmp/webcom”,F_OK) < 0 ) //创建有名管道用于接收拍照命令 { if ( mkfifo(“/tmp/webcom”,0666 ) < 0) { Printf(“ photo fifo create failed\n”); } } fd_com = open (“/tmp/webcom”,O_RDONLY,0666); if (fd < 0) { perror (“open the file webcom error”); } //在while( ok >= 0 && !pglobal->stop){ 后加入 if (flags == 0) { while(1) { reade(fd_com,buf,sizeof(buf)); if(strncmp(buf,”danger”,6) == 0) //拍11张照片 { flags = 1; bzero(buf,sizeof(buf)); break; } if(strncmp(buf,”one”,3) == 0) //拍1张照片 { flags = 2; bzero(buf,sizeof(buf)); break; } } } //在if (delay > 0){ usleep(1000*delay); }后加入 stop_num++ if(flags == 1) //判断拍照的数量 { if ( stop_num > 9) { stop_num= 0; flsgs= 0; } } elseif (flags == 2) { stop_num= 0; flags= 0; }

2.人脸检测

'haarcascade_frontalface_default.xml'是Opencv中已经训练好的人脸分类器文件。它是基于Haar特征的级联分类器,可以用于检测正面的人脸。该文件是通过大量的正负样本训练而成,可以用于人脸检测的应用中。具体调用代码如下:

#! user/bin/python #- * -coding:UTF-8 - * - import cv2 import numpy as np def myfilter(img): # 图像转化为灰度格式 gray=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY) # 导入人脸级联分类器引擎,'xml'文件包含训练好的人脸特征 face_cascade=cv2.CascadeClassifier(' \ /home/xuyang/test1/haarcascade_frontalface_default.xml') #为防止报错使用该文件在opencv下的绝对路径 # 用人脸级联分类器引擎进行人脸识别,返回的faces为人脸坐标列表 faces = face_cascade.detectMultiScale(gray) return faces def myfaces_count(img,faces): count = 0 #人脸计数初值 # 对每张脸,操作如下 for (x,y,w,h) in faces: '''画矩形圈出人脸 输入参数依次为:图片,右上角的点坐标,矩形大小,线条颜色,宽度 ''' cv2.rectangle(img,(x,y),(x+w,y+h),(255,255,255),2) count += 1 # 累计人数 # 把统计人数显示出来 cv2.putText(img,'{}'.format(count),(x,y-7),3,1.2,(0,0,255),2) return img #打开mjpg-streamer视频流(通过URL) #cap = cv2.VideoCapture('http://192.168.106.128:8080/?action=stream') #打开视频 cap = cv2.VideoCapture('video.mp4') y = 0 #获取视频相关数据以便于保存视频 width = int(cap.get(3)) height = int(cap.get(4)) fps = cap.get(5) fourcc = cv2.VideoWriter_fourcc(*'MJPG') output_file = 'output_video.mp4' video_writer = cv2.VideoWriter(output_file,fourcc,fps,(width,height),isColor = True) while True: # 读取每一帧图像 ret, frame = cap.read() if not ret: break if y == 0: faces = myfilter(frame) #人脸识别特征每10次循环做一次 不然运行速度太慢了 y = y + 1 if y == 10: y =0 frame = myfaces_count(frame,faces) # 在窗口上显示当前帧的图像 cv2.imshow("Frame", frame) video_writer.write(frame) #保存视频 # 按下 'q' 退出循环 if cv2.waitKey(1) & 0xFF == ord('q'): break # 关闭所有窗口及释放对象 cap.release() video_writer.release() cv2.destroyAllWindows()

3.人脸识别

鉴于开发板运行人脸检测模型已经有一定的运算压力,同时为了丰富项目内容,人脸识别部分我们通过传送照片在云端完成。

本文通过libcurl库调用云端API实现人脸识别。需要libcurl库支持https协议。要让LibCurl库支持https协议实现人脸识别,就需要安装移植Openssl这个库。此篇人脸识别介绍主要目的是判断两张人脸图片的相似程度或者接近程度。安装移植LibCurl库和Openssl库不多赘述。

首先是注册一个OCR云识别平台账号如图:

wKgZomXxZfaAeh-AAAEHOC4OGxA671.png

询对应平台的API和接口地址:

wKgaomXxZhSARgfgAARfyoy2h9Q860.png

下面是调用人脸识别API的代码

#include #include #include #include #include #include #include #include #include typedef unsigned int bool; #define true 1 #define false 0 char buf[1024]={'\0'}; size_t readData(void *ptr, size_t size, size_t nmemb, void *stream) { strncpy(buf,ptr,1024); } char* getPic(char *pic) { char cmd[128]={'\0'}; memset(cmd,'\0',128); sprintf(cmd,"base64 %s > tmpFile",pic); system(cmd); int fd = open("./tmpFile",O_RDWR); int filelen = lseek(fd,0,SEEK_END); lseek(fd,0,SEEK_SET); char *base64Buf = (char*)malloc(filelen + 8); memset(base64Buf,'\0',filelen + 8); read(fd,base64Buf,filelen+8); close(fd); system("rm -f tmpFile"); return base64Buf; } bool postUrl()//POST请求 { char buf1[1024] = {0},buf2[1024] = {0}; unsigned long long counter = 0; static char *folder = "/tmp"; time_t t; struct tm *now; t = time(NULL); now = localtime(&t); system("echo one > /tmp/webcom"); //向有名管道webcom写入字符串实现拍照 strftime(buf1, sizeof(buf1), "%%s/%Y_%m_%d_%H_%M_%S_picture_%%09llu.jpg", now); snprintf(buf2, sizeof(buf2), buf1,"/tmp", counter); sleep(1); CURL *curl; CURLcode res; char *postString = NULL; char *base64Buf1 = getPic(buf2); char *base64Buf2 = getPic("./me5.jpg"); char *key = "xxxxxxxxxxxxxxxxxxxxxxx"; char *secret = "xxxxxxxxxxxxxxxxxxxxxxx"; int typeld = 21; char *format = "xml"; int len = strlen(key)+strlen(secret)+strlen(format)+ \ strlen(base64Buf1)+strlen(base64Buf2)+128; printf("%d",len); postString = (char *)malloc(len); sprintf(postString,"img1=%s&img2=%s&key=%s&secret=%s&typeId=%d&format=%s",\ base64Buf1,base64Buf2,key,secret,typeld,format); curl = curl_easy_init(); if (curl) { curl_easy_setopt(curl, CURLOPT_COOKIEFILE, "/tmp/cookie.txt"); // 指定cookie文件 curl_easy_setopt(curl, CURLOPT_POSTFIELDS, postString); // 指定post内容 curl_easy_setopt(curl, CURLOPT_URL, "https://netocr.com/api/faceliu.do"); //指定url curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, readData); res = curl_easy_perform(curl);//执行 //printf("res = %d\n",res); if(strstr(buf,"是")!=NULL) { printf("is same people\n"); } else { printf("not the same people\n"); } curl_easy_cleanup(curl); } return true; } int main(void) { postUrl(); }

本项目的工作流程设计逻辑是,首先系统启动视频监控机制,智能判断画面中是否存在人脸;一旦检测到人脸,则触发拍照动作,然后通过调用云端API进行人脸识别对比并返回结果,上述视频的对比结果如下:

wKgZomXxZk-Ae-nBAAVrvxL1zDQ043.png

左图为提前准备好的相关人脸的照片,右图为拍照得到的照片,下面为对比结果判定为是同一个人。同时开发板返回结果也正确:

wKgZomXxZniAO-gjAAHxpbDUyN0544.png

至此,关于基于ELF 1开发板实现的远程监测及人脸识别项目的介绍告一段落。衷心期待这项案例能够对正在钻研嵌入式开发的小伙伴带来启示与借鉴,助力各位的学习之旅。

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

    关注

    5186

    文章

    20146

    浏览量

    328779
  • Linux
    +关注

    关注

    88

    文章

    11628

    浏览量

    217959
  • 远程监测
    +关注

    关注

    0

    文章

    168

    浏览量

    18898
  • 开发板
    +关注

    关注

    25

    文章

    6122

    浏览量

    113288
  • 人脸识别
    +关注

    关注

    77

    文章

    4117

    浏览量

    87755
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    【Milk-V Duo S 开发板免费体验】人脸检测

    【Milk-V Duo S 开发板免费体验】人脸检测 本文介绍了 Milk-V Duo S 开发板结合 OV5647 摄像头模块,实现人脸检测的项目
    发表于 07-27 16:53

    【EASY EAI Orin Nano开发板试用体验】EASY-EAI-Toolkit人脸识别

    、编译与测试 1.组件人脸识别代码如下 2.开发板挂载服务器,编译 挂载上服务器后,切换到EASY-EAI-Toolkit-3576/Demos/algorithm-face_dete
    发表于 07-20 14:40

    ElfBoard技术贴|【RK3588】ELF 2开发板开机自启动详解

    在嵌入式系统开发中,合理管理开机自启动项目能够优化系统启动流程,确保关键服务和应用按时加载运行。本文将详细介绍在ELF2开发板Linux5.10.209系统下基于SystemVinit
    的头像 发表于 06-27 16:20 1780次阅读
    ElfBoard技术贴|【RK3588】<b class='flag-5'>ELF</b> 2<b class='flag-5'>开发板</b>开机自启动详解

    基于RK3576开发板人脸识别算法

    RK3576开发板展示人脸识别算法例程和API说明
    的头像 发表于 05-07 16:48 2484次阅读
    基于RK3576<b class='flag-5'>开发板</b>的<b class='flag-5'>人脸</b><b class='flag-5'>识别</b>算法

    来自资深工程师对ELF 2开发板的产品测评

    来自资深工程师对ELF 2开发板的使用测评
    的头像 发表于 04-28 15:03 1527次阅读
    来自资深工程师对<b class='flag-5'>ELF</b> 2<b class='flag-5'>开发板</b>的产品测评

    基于RV1126开发板实现人脸识别方案

    在RV1126开发板上实现人脸识别:在图像中找出人脸,并与数据库进行比对,得出该人脸对应的身份信息。 方案设计逻辑流程图,方案
    的头像 发表于 04-21 10:24 107次阅读
    基于RV1126<b class='flag-5'>开发板</b>实现<b class='flag-5'>人脸</b><b class='flag-5'>识别</b>方案

    基于RV1126开发板实现人脸识别方案

    在RV1126开发板实现人脸识别:在图像中找出人脸,并与数据库进行比对,得出该人脸对应的身份信息。 方案设计逻辑流程图,方案代
    的头像 发表于 04-18 16:55 83次阅读
    基于RV1126<b class='flag-5'>开发板</b>实现<b class='flag-5'>人脸</b><b class='flag-5'>识别</b>方案

    如何在米尔-STM32MP257开发板上实现环境监测系统

    本文将介绍基于米尔电子MYD-LD25X开发板(米尔基于STM35MP257开发板)的环境监测系统方案测试。摘自优秀创作者-lugl4313820一、前言环境监测是当前很多场景需要的
    的头像 发表于 04-17 08:06 2367次阅读
    如何在米尔-STM32MP257<b class='flag-5'>开发板</b>上实现环境<b class='flag-5'>监测</b>系统

    人脸识别指南:如何在树莓派上安装和设置 Dlib

    学习如何在树莓派上安装Dlib并配置人脸识别功能,为您的AI项目奠定基础。在树莓派上安装Dlib的详细步骤要为树莓派安装Dlib并确保人脸识别项目
    的头像 发表于 03-24 17:31 1248次阅读
    <b class='flag-5'>人脸</b><b class='flag-5'>识别</b>指南:如何在树莓派上安装和设置 Dlib

    ElfBoard技术贴|如何在ELF 1开发板上交叉移植Qt

    在嵌入式系统开发领域,针对特定硬件平台进行Qt框架的移植与适配是一项关键技术任务。作为业界主流的跨平台应用开发框架,Qt凭借其完善的图形界面支持能力,在嵌入式开发图形界面应用程序中占据重要地位。本文将基于
    的头像 发表于 02-24 16:18 1038次阅读
    ElfBoard技术贴|如何在<b class='flag-5'>ELF</b> <b class='flag-5'>1</b><b class='flag-5'>开发板</b>上交叉移植Qt

    【米尔RK3576开发板评测】+项目名称RetinaFace人脸检测

    的文件。 bash ./build-linux.sh -t rk3576 -a aarch64 -d RetinaFace 四、RK3576运行 4.1、将编译后的文件上传至开发板中 4.2、打开文件
    发表于 02-15 13:28

    ELF 2学习试用】ELF2开发板开箱体验及基本使用环境搭建

    2开发板 输出为12v 3A的电源适配器(和ipad的充电器外观好像) 图1 外包装盒 图2 开箱物品内容 图3 ELF2开发板正面 图4
    发表于 01-19 22:41

    ElfBoard技术贴|ELF 1开发板适配摄像头详解

    ELF1ELF1S开发板适配的OV5640摄像头,集成了CMOS图像传感器,作为一款500万像素级别的摄像头,不仅能够支持最高达2592x1944分辨率的QSXGA图像输出,帧率可达15fps
    的头像 发表于 12-27 10:16 1892次阅读
    ElfBoard技术贴|<b class='flag-5'>ELF</b> <b class='flag-5'>1</b><b class='flag-5'>开发板</b>适配摄像头详解

    ElfBoard开源项目|百度智能云平台的人脸识别项目

    百度智能云平台的人脸识别项目,旨在利用其强大的人脸识别服务实现自动人脸识别。选择百度智能云的原因
    的头像 发表于 12-24 10:54 1859次阅读
    ElfBoard开源<b class='flag-5'>项目</b>|百度智能云平台的<b class='flag-5'>人脸</b><b class='flag-5'>识别项目</b>

    【实战】人工智能0基础入门:基于Python+OpenCV的车牌识别项目(课程+平台实践)

    01引言随着智能交通系统的发展,车牌识别技术在车辆管理、交通监控、停车收费等多个领域发挥着重要作用。接下来小编将带你深入了解车牌识别项目的全流程,从理论基础到实际应用,让你掌握如何构建一个高效、准确
    的头像 发表于 12-16 10:43 1175次阅读
    【实战】人工智能0基础入门:基于Python+OpenCV的车牌<b class='flag-5'>识别项目</b>(课程+平台实践)