色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

ElfBoard開源項目|百度智能云平臺的人臉識別項目

ElfBoard ? 2024-12-24 10:54 ? 次閱讀

百度智能云平臺的人臉識別項目,旨在利用其強大的人臉識別服務實現自動人臉識別。選擇百度智能云的原因是其高效的API接口和穩定的服務質量,能夠幫助開發者快速實現人臉識別應用。

本項目使用攝像頭捕捉圖像后,通過百度智能云平臺的人臉識別服務,能夠輕松識別圖像中的人臉,并將識別結果實時顯示在Qt界面上。

wKgZO2dqH8eALz0sAAGsIZC5P6M422.png

功能特性

1、圖片處理和人臉識別:使用百度智能云的人臉識別服務,通過API輕松識別圖像中的人臉。

2、攝像頭實時采集圖像并保存:使用Qt設計了直觀的用戶界面,控制USB攝像頭的打開、關閉以及實時顯示攝像頭捕獲的視頻流,并將采集到的視頻流保存為圖像。

環境說明

1、開發環境操作系統:Ubuntu18.04 64位版

2、交叉編譯工具鏈:arm-poky-linux-gnueabi-gcc 5.3.0

3、開發板使用Bootloader版本:u-boot-2016.03

4、開發板內核版本:linux-4.1.15

5、開發板移植QT版本:qt5.6.2

圖片處理和人臉識別

百度智能云網址:cloud.baidu.com

本次人臉識別的方案是通過百度智能云平臺進行實現的。首先進入百度智能云網頁- >選擇人臉與人體- > 人臉識別。

wKgZO2dqH_OAWu-gAAKjGVJGn_Y086.png

進入人臉識別頁面之后可通過閱讀技術文檔來學習人臉識別的使用方法。

1、創建人臉庫

(1)單擊“應用列表”,單擊“查看人臉庫”。

(2)單擊“新建組”。

(3)選擇用戶組場景類型,填寫組ID,單擊“確認”。

(4)單擊剛新建的組ID。

(5)單擊“新建用戶”,填寫用戶ID,添加圖片,單擊“確認”。

wKgZO2dqIC2AIpQ0AACv_qifvqM043.png

2、在線識別人臉圖片

在本地實現之前可通過平臺提供的在線驗證方法進行驗證,如下圖,需要在旁邊輸入一張人臉圖片的base64 編碼的字符串或者選擇上傳一張人臉圖片,并填寫組ID即可進行在線識別。

wKgZO2dqIEuAFq9_AGQSHdaqySY915.png

3、識別本地人臉圖片

本地實現人臉識別的方法需要將識別代碼拷貝到本地,并需要實現一個將圖片轉換為base64編碼的函數。需要輸入自己的access_token(通過閱讀文檔可知怎么獲取)。

#include #include #include #include #include #include #include #include #include #include #include #include inline size_t onWriteData(void * buffer, size_t size, size_t nmemb, void * userp) { std::string * str = dynamic_cast((std::string *)userp); str->append((char *)buffer, size * nmemb); return nmemb;

} std::string getFileBase64Content(const char * path, bool urlencoded=false) { const std::string base64_chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" "abcdefghijklmnopqrstuvwxyz" "0123456789+/"; std::string ret;

int i = 0; int j = 0; unsigned char char_array_3[3]; unsigned char char_array_4[4]; unsigned int bufferSize = 1024;

unsigned char buffer[bufferSize]; std::ifstream file_read; file_read.open(path, std::ios::binary); while (!file_read.eof()){ file_read.read((char *) buffer, bufferSize * sizeof(char)); int num = file_read.gcount(); int m = 0; while (num--){ char_array_3[i++] = buffer[m++];

if(i == 3){ char_array_4[0] = (char_array_3[0] & 0xfc) >> 2; char_array_4[1] = ((char_array_3[0] & 0x03) << 4) + ((char_array_3[1] & 0xf0) >> 4); char_array_4[2] = ((char_array_3[1] & 0x0f) << 2) + ((char_array_3[2] & 0xc0) >> 6);

char_array_4[3] = char_array_3[2] & 0x3f; for(i = 0; (i <4) ; i++) ret += base64_chars[char_array_4[i]]; i = 0; } } } file_read.close(); if(i){ for(j = i; j < 3; j++) char_array_3[j] = '\0'; char_array_4[0] = (char_array_3[0] & 0xfc) >> 2; char_array_4[1] = ((char_array_3[0] & 0x03) << 4) + ((char_array_3[1] & 0xf0) >> 4); char_array_4[2] = ((char_array_3[1] & 0x0f) << 2) + ((char_array_3[2] & 0xc0) >> 6); char_array_4[3] = char_array_3[2] & 0x3f; for(j = 0; (j < i + 1); j++) ret += base64_chars[char_array_4[j]]; while((i++ < 3)) ret += '='; }

if (urlencoded) ret = curl_escape(ret.c_str(), ret.length()); return ret; } std::string performCurlRequest(const char *pic_path, const std::string &token) { std::string result; char *web_curl = nullptr; CURL *curl = curl_easy_init(); CURLcode res = CURLE_OK;

if (!asprintf(&web_curl, "https://aip.baidubce.com/rest/2.0/face/v3/search?access_token=%s", token.c_str())) { perror("asprintf error"); }

if (curl) { curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "POST");

// std::string url = "https://aip.baidubce.com/rest/2.0/face/v3/search?access_token=" + token; curl_easy_setopt(curl, CURLOPT_URL, web_curl); curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1L); curl_easy_setopt(curl, CURLOPT_DEFAULT_PROTOCOL, "HTTPS"); curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L); curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L);

struct curl_slist *headers = NULL; headers = curl_slist_append(headers, "Content-Type: application/json");

curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers); std::string base64_image = getFileBase64Content(pic_path, true); std::string post_data = "image=" + base64_image + "&group_id_list=one&image_type=BASE64";

curl_easy_setopt(curl, CURLOPT_POSTFIELDS, post_data.c_str()); curl_easy_setopt(curl, CURLOPT_WRITEDATA, &result); curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, onWriteData);

if(curl_easy_perform(curl) != CURLE_OK) fprintf(stderr, "Curl request failed: %s\n", curl_easy_strerror(res)); }

curl_easy_cleanup(curl); free(web_curl); return result; } int main(int argc, char *argv[])

{ std::string result; std::string name; std::string token = "24.2bc619cf9c09c32ce5af202ccc98c0c9.2592000.1724918062.282335-100710397"; result = performCurlRequest("/home/root/num/1.jpg", token); std::string json = result; std::regex pattern(""user_id":"(.*?)""); std::smatch match; if (std::regex_search(json, match, pattern)) { name = match[1].str(); std::cout << "read name is: " << name << std::endl; } return 0; }

1)依賴庫編譯

編譯人臉識別的應用需要依賴Curl庫、OpenSSL庫、OpenCv庫、JsonCPP庫。詳細的依賴庫安裝步驟請參考以下鏈接:

bbs.elfboard.com/forum.php?mod=viewthread&tid=496&extra=page%3D1

bbs.elfboard.com/forum.php?mod=viewthread&tid=495&extra=page%3D1

bbs.elfboard.com/forum.php?mod=viewthread&tid=497&extra=page%3D1

bbs.elfboard.com/forum.php?mod=viewthread&tid=498&extra=page%3D1

2)應用編譯

elf@ubuntu:~/work$ . /opt/fsl-imx-x11/4.1.15-2.0.0/environment-setup-cortexa7hf-neon-poky-linux-gnueabi elf@ubuntu:~/work$ $CC demoFace.cpp -o demoFace -I /home/elf/work/opencv-3.4.1/install/include/ -I /home/elf/work/curl-7.71.1/install/include/ -I /home/elf/work/jsoncpp-1.9.5/install/include/ -L /home/elf/work/opencv-3.4.1/install/lib/ -L /home/elf/work/curl-7.71.1/install/lib/ -L /home/elf/work/jsoncpp-1.9.5/install/lib/ -lopencv_highgui -lopencv_core -lopencv_imgproc -lopencv_objdetect -lopencv_videoio -lopencv_imgcodecs -std=c++11 -lcurl -lcrypto -ljsoncpp -lstdc++

編譯完成將文件通過scp拷貝到ELF 1開發板運行即可,這樣就可以將本地的圖片通過HTTPS發送到百度智能云進行識別,并將識別結果返回。

攝像頭實時采集圖像并保存

1、程序設計

在前面一個章節實現了對本地人臉圖片的識別,下面來介紹如何通過攝像頭進行人臉識別,采用USB攝像頭進行識別,程序設計如下圖所示。

wKgZPGdSYC-ADVntAACniexGP6E983.png

主函數的實現main.cpp

int main(int argc, char *argv[]) { QApplication a(argc, argv); Camera w; w.setWindowFlags(w.windowFlags()& ~Qt::WindowMaximizeButtonHint& ~Qt::WindowMinimizeButtonHint ); w.showMaximized(); w.show(); return a.exec(); }

設置UI

ui->setupUi(this); timer = new QTimer; QDesktopWidget* desktopWidget = QApplication::desktop(); QRect screenRect = desktopWidget->screenGeometry(); qDebug("screen.width = %d , screen.height = %d",screenRect.width(),screenRect.height()); this->imageWidget = new ImageWidget(this); this->imageWidget->setBackgroundRole(QPalette::Dark); this->imageWidget->setSizePolicy(QSizePolicy::Ignored, QSizePolicy::Ignored); this->imageWidget->setObjectName(QString::fromUtf8("imageWidget")); if(screenRect.width()==800) { ui->pbt_start->setGeometry(60,300,70,50); ui->pbt_stop->setGeometry(190,300,70,50); this->imageWidget->setGeometry(QRect(5, 30, 350, 250)); } else if(screenRect.width()>800) { ui->pbt_start->setGeometry(80,400,70,70); ui->pbt_stop->setGeometry(260,400,70,70); this->imageWidget->setGeometry(QRect(6, 37, 500, 330)); }

打開攝像頭設備

void deviceOpen(void) { fd = open(deviceName, O_RDWR | O_NONBLOCK, 0); if (-1 == fd) { QMessageBox::about(NULL, "About", "camera open error"); exit(EXIT_FAILURE); } }

初始化攝像頭設備

void deviceInit(void) { struct v4l2_capability cap; struct v4l2_cropcap cropcap; struct v4l2_crop crop; struct v4l2_format fmt; struct v4l2_streamparm sparm; unsigned int min; if (-1 == xioctl(fd, VIDIOC_QUERYCAP, &cap)) { if (EINVAL == errno) { QMessageBox::about(NULL,"Information"," no V4L2 device"); exit(EXIT_FAILURE); } else { errno_exit("VIDIOC_QUERYCAP"); } } if (!(cap.capabilities & V4L2_CAP_VIDEO_CAPTURE)) { QMessageBox::about(NULL,"Information"," no video capture device");

exit(EXIT_FAILURE); } struct v4l2_input input; input.index = 0; if ( ioctl(fd, VIDIOC_ENUMINPUT, &input) != 0) { QMessageBox::about(NULL,"Information","set input error"); exit(0); } if ((ioctl(fd, VIDIOC_S_INPUT, &input)) < 0) { QMessageBox::about(NULL,"Information","set s_input error"); exit(0); } CLEAR(cropcap); cropcap.type = V4L2_BUF_TYPE_VIDEO_CAPTURE; if (0 == xioctl(fd, VIDIOC_CROPCAP, &cropcap)) { crop.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;

crop.c.top = 0; crop.c.left = 0; crop.c.height = 720; crop.c.width = 1280; if (-1 == xioctl(fd, VIDIOC_S_CROP, &crop)) { switch (errno) { case EINVAL: break; default: break; } } } CLEAR (fmt); // v4l2_format fmt.type = V4L2_BUF_TYPE_VIDEO_CAPTURE; fmt.fmt.pix.width = width; fmt.fmt.pix.height = height; fmt.fmt.pix.pixelformat = V4L2_PIX_FMT_YUYV;

fmt.fmt.pix.field = V4L2_FIELD_ANY; if (-1 == xioctl(fd, VIDIOC_S_FMT, &fmt)) errno_exit("VIDIOC_S_FMT");

/* Note VIDIOC_S_FMT may change width and height.*/ if (width != fmt.fmt.pix.width) { width = fmt.fmt.pix.width; //fprintf(stderr,"Image width set to %i by device %s.\n",width,deviceName); } if (height != fmt.fmt.pix.height) { height = fmt.fmt.pix.height; //fprintf(stderr,"Image height set to %i by device %s.\n",height,deviceName); } /*Buggy driver paranoia. */ min = fmt.fmt.pix.width * 2; if (fmt.fmt.pix.bytesperline < min) fmt.fmt.pix.bytesperline = min; min = fmt.fmt.pix.bytesperline * fmt.fmt.pix.height; if (fmt.fmt.pix.sizeimage < min) fmt.fmt.pix.sizeimage = min; CLEAR (sparm); sparm.type = V4L2_BUF_TYPE_VIDEO_CAPTURE; sparm.parm.capture.capturemode = 0; sparm.parm.capture.timeperframe.numerator = 1; sparm.parm.capture.timeperframe.denominator = 30; if(xioctl(fd,VIDIOC_S_PARM,&sparm) < 0){ errno_exit("cam s parm"); // exit(1); } mmapInit(); }

開啟視頻流捕獲

void captureStart(void) { unsigned int i; enum v4l2_buf_type type; for (i = 0; i < n_buffers; ++i) { struct v4l2_buffer buf; CLEAR (buf); buf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE; buf.memory = V4L2_MEMORY_MMAP; buf.index = i; if (-1 == xioctl(fd, VIDIOC_QBUF, &buf)) errno_exit("VIDIOC_QBUF"); } type = V4L2_BUF_TYPE_VIDEO_CAPTURE; if (-1 == xioctl(fd, VIDIOC_STREAMON, &type)) errno_exit("VIDIOC_STREAMON"); }

超時處理

void Camera::up_date() { unsigned char image_buf[921600+54]; frameRead(image_buf); this->imageWidget->setPixmap(image_buf); }

2、應用編譯及測試

1)編譯

elf@ubuntu:~/work/camera-demo$ . /opt/fsl-imx-x11/4.1.15-2.0.0/environment-setup-cortexa7hf-neon-poky-linux-gnueabi elf@ubuntu:~/work/camera-demo$ qmake elf@ubuntu:~/work/camera-demo$ make

2)拷貝camera-demo到ELF 1開發板的/home/root路徑下,運行測試。

root@ELF1:~# cp /run/media/sda1/camera-demo ./ root@ELF1:~# chmod 777 camera-demo root@ELF1:~# export DISPLAY=:0.0 root@ELF1:~# ./camera-demo

點擊start按鈕之后,使用ls num路徑下查看會有攝像頭拍攝的圖片。液晶屏上會實時預覽攝像頭拍到的圖像,如下圖所示:

wKgZPGdSYRCAUYsRAAGWgTwKOp4829.png

在這里就可以和前面人臉識別結合起來了,比如攝像頭里面的畫面是一張人臉信息,通過截取攝像頭中的實時畫面到本地,然后上傳到百度智能云進行識別,至此就完成了通過攝像頭進行人臉識別的過程。

項目測試

在此基礎上再次完善應用,識別人臉的應用將識別到的人臉信息保存到文本中,基于攝像頭的應用讀取文檔中的人臉信息顯示在Qt界面中。

1、確保開發板已連接USB攝像頭和屏幕

2、設置Wi-Fi連接

root@ELF1:~# elf1_cmd_wifi.sh -i 8723 -s 賬號 -p 密碼

3、執行應用

root@ELF1:~# ./camera-demo & root@ELF1:~# ./demoFace

單擊“start”按鈕,識別結果如下圖所示。

wKgZO2dqH8eALz0sAAGsIZC5P6M422.png
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 嵌入式
    +關注

    關注

    5086

    文章

    19141

    瀏覽量

    305976
  • 嵌入式系統
    +關注

    關注

    41

    文章

    3595

    瀏覽量

    129550
  • 人臉識別
    +關注

    關注

    76

    文章

    4012

    瀏覽量

    81993
  • 嵌入式開發板

    關注

    5

    文章

    82

    瀏覽量

    18764
  • 開源項目
    +關注

    關注

    0

    文章

    38

    瀏覽量

    7208
收藏 人收藏

    評論

    相關推薦

    ElfBoard開源項目|智能消防車項目

    智慧城市的建設推動了城市各個領域的智能化發展,消防領域也不例外。智慧消防作為智慧城市的重要組成部分,其建設和發展與智慧城市的建設緊密相連。 在此背景下,ElfBoard團隊完成了一個創新性的開源
    的頭像 發表于 01-04 16:43 ?188次閱讀
    <b class='flag-5'>ElfBoard</b><b class='flag-5'>開源</b><b class='flag-5'>項目</b>|<b class='flag-5'>智能</b>消防車<b class='flag-5'>項目</b>

    【實戰】人工智能0基礎入門:基于Python+OpenCV的車牌識別項目(課程+平臺實踐)

    01引言隨著智能交通系統的發展,車牌識別技術在車輛管理、交通監控、停車收費等多個領域發揮著重要作用。接下來小編將帶你深入了解車牌識別項目的全流程,從理論基礎到實際應用,讓你掌握如何構建一個高效、準確
    的頭像 發表于 12-16 10:43 ?341次閱讀
    【實戰】人工<b class='flag-5'>智能</b>0基礎入門:基于Python+OpenCV的車牌<b class='flag-5'>識別項目</b>(課程+<b class='flag-5'>平臺</b>實踐)

    ElfBoard開源項目|車牌識別項目技術文檔

    車牌識別項目基于百度智能平臺,旨在利用其強大的OCR服務實現車牌號碼的自動識別。選擇
    的頭像 發表于 12-06 10:30 ?277次閱讀
    <b class='flag-5'>ElfBoard</b><b class='flag-5'>開源</b><b class='flag-5'>項目</b>|車牌<b class='flag-5'>識別項目</b>技術文檔

    百度將發布AI智能眼鏡

    近日,有知情人士透露,百度旗下的人工智能品牌小計劃在即將舉行的百度世界大會上推出一款全新的AI智能眼鏡。這款眼鏡將內置先進
    的頭像 發表于 11-11 14:50 ?457次閱讀

    百度智能榮獲A級工業互聯網“雙跨”平臺企業

    的是,百度智能在本次評價中表現突出,榮獲A級工業互聯網“雙跨”平臺企業稱號。這不僅是對百度智能
    的頭像 發表于 11-11 13:53 ?266次閱讀

    百度智能發布千帆大模型平臺3.0

    2024年百度智大會上,百度智能震撼發布千帆大模型平臺3.0,標志著其在AI領域又一里程碑式
    的頭像 發表于 09-26 14:51 ?449次閱讀

    百度舸AI計算平臺4.0震撼發布

    在2024年百度智大會的璀璨舞臺上,百度智能重磅推出了舸AI異構計算
    的頭像 發表于 09-26 14:46 ?490次閱讀

    深圳華恩運維科技簽約百度智能合作伙伴開啟人臉識別新篇章

    百度智能-目合作伙伴交流會暨授牌儀式在深圳順利舉行12月29日下午,“百度智能
    的頭像 發表于 07-28 17:05 ?596次閱讀
    深圳華恩運維科技簽約<b class='flag-5'>百度</b><b class='flag-5'>智能</b><b class='flag-5'>云</b>合作伙伴開啟<b class='flag-5'>人臉</b><b class='flag-5'>識別</b>新篇章

    esp32在Arduino IDE中可以實現調用百度智能接口嗎?

    esp32在Arduino IDE中可以實現調用百度智能接口嗎?涉及到http協議,想知道能不能不用esp-idf
    發表于 06-28 06:52

    百度智能升級3款大模型應用:面向三類場景打造企業“超級員工”

    6月25日,“AI Cloud Day:百度智能大模型應用產品發布會”在北京舉行。會上,百度智能
    的頭像 發表于 06-25 19:22 ?1103次閱讀

    百度智能推出“千帆行業增強版”

    在近日于北京舉辦的2024智能經濟論壇上,百度集團執行副總裁、百度智能事業群總裁沈抖分享了百度
    的頭像 發表于 05-30 09:30 ?596次閱讀

    百度智能正式發布了《百度智能水業大模型白皮書》

    3月28日,由E20環境平臺主辦的2024(第二十二屆)水業戰略論壇在北京召開。會上,百度智能正式發布了《百度
    的頭像 發表于 03-29 09:20 ?1387次閱讀
    <b class='flag-5'>百度</b><b class='flag-5'>智能</b><b class='flag-5'>云</b>正式發布了《<b class='flag-5'>百度</b><b class='flag-5'>智能</b><b class='flag-5'>云</b>水業大模型白皮書》

    漳州市長魏東到訪百度,與百度智能共商漳州新質生產力發展

    發展,就百度智能(漳州)人工智能基礎數據產業基地、生態合作項目百度
    的頭像 發表于 03-25 11:27 ?890次閱讀

    一圖講透百度智能千帆大模型平臺全面升級!

    【一圖講透】百度智能千帆大模型平臺全面升級!
    的頭像 發表于 03-22 10:44 ?522次閱讀
    一圖講透<b class='flag-5'>百度</b><b class='flag-5'>智能</b><b class='flag-5'>云</b>千帆大模型<b class='flag-5'>平臺</b>全面升級!

    項目分享|基于ELF 1開發板的遠程監測及人臉識別項目

    今天非常榮幸地向各位小伙伴分享一個由共創社成員完成的遠程監測及人臉識別項目,該項目依托ELF1開發板為核心硬件平臺,構建了一套完整的視頻監控系統,并在此基礎上集成了
    的頭像 發表于 03-13 16:41 ?541次閱讀
    <b class='flag-5'>項目</b>分享|基于ELF 1開發板的遠程監測及<b class='flag-5'>人臉</b><b class='flag-5'>識別項目</b>
    主站蜘蛛池模板: 国产午夜AV无码无片久久96| 国产不卡一卡2卡三卡4卡网站| 91视频夜色| 久久re视频精品538在线| 午夜精品久久久久久影视riav| 八妻子秋霞理在线播放| 暖暖日本手机免费完整版在线观看| 中文字幕在线视频免费观看| 精品亚洲国产熟女福利自在线| 亚洲精品免播放器在线观看| 国产综合在线视频| 亚洲免费久久| 精品国产乱码久久久久久口爆| 亚洲精品天堂自在久久77| 国产婷婷一区二区在线观看| 亚洲国产cao| 久久99综合国产精品亚洲首页| 一级特黄视频| 美女脱衣服搞鸡| 饱满奶大30p| 熟妇久久无码人妻AV蜜桃| 国产成人无码WWW免费视频在线| 特污兔午夜影视院| 国产这里有精品| 在教室轮流被澡高H林萌| 老头扒开粉缝亲我下面| 99久久国产综合精品成人影院| 拍床戏被肉高H纯肉H在水| 俄罗斯孩交精品| 亚洲AV成人无码999WWW| 久久精品久久久久| metart中国撒尿人体欣赏| 搡女人免费免费视频观看| 国产午夜精品理论片影院 | 黑粗硬大欧美在线视频| 一区二区三区无码高清视频| 蜜芽手机在线观看| 国产成人免费在线| 一边啪啪的一边呻吟声口述| 蜜芽国产在线精品欧美| 国产99精品在线观看|