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

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

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

3天內不再提示

基于QT+OpenCV的人臉識別-米爾iMX8M Plus開發(fā)板的測評

米爾電子 ? 2022-05-23 10:34 ? 次閱讀


本篇測評由電子工程世界的優(yōu)秀測評者“流行科技”提供。此次測試的開源項目,是基于QT+OpenCV的人臉識別打卡項目。本次體驗使用的是開源的代碼,此代碼本來是運行在WIN下的,為了測試稍微進行了修改,讓其運行在米爾iMX8M Plus開發(fā)板上。e50c1d82-d20d-11ec-8521-dac502259ad0.png測試項目實際是分了兩個工程,一個工程是作為管理員控制功能使用,添加人臉信息。同時也可以查詢到打卡記錄,對從機進行下發(fā)通知等等。人臉識別我們主要需要用到opencv的人臉檢測分類器。e51b0766-d20d-11ec-8521-dac502259ad0.pngOpenCV編譯完成后已經提供好了的。因為這里還需要涉及到訓練模型,有了模型后才能更好的識別,所以還是簡單介紹下怎么訓練的吧。 ??

  • CascadeClassifier cascada;
  • //將opencv官方訓練好的人臉識別分類器拷貝到自己的工程目錄中
  • cascada.load("F:\\video\\ccc\\haarcascade_frontalface_alt2.xml");
  • VideoCapture cap(1); //0表示電腦自帶的,如果用一個外接攝像頭,將0變成1
  • Mat frame, myFace;
  • int pic_num = 1;
  • while (1) {
  • //攝像頭讀圖像
  • cap >> frame;
  • vector faces;//vector容器存檢測到的faces
  • Mat frame_gray;
  • cvtColor(frame, frame_gray, COLOR_BGR2GRAY);//轉灰度化,減少運算
  • cascada.detectMultiScale(frame_gray, faces, 1.1, 4, CV_HAAR_DO_ROUGH_SEARCH, Size(70, 70), Size(1000, 1000));
  • printf("檢測到人臉個數:%d\n", faces.size());
  • //識別到的臉用矩形圈出
  • for (int i = 0; i < faces.size(); i++)
  • {
  • rectangle(frame, faces, Scalar(255, 0, 0), 2, 8, 0);
  • }
  • //當只有一個人臉時,開始拍照
  • if (faces.size() == 1)
  • {
  • Mat faceROI = frame_gray(faces[0]);//在灰度圖中將圈出的臉所在區(qū)域裁剪出
  • //cout << faces[0].x << endl;//測試下face[0].x
  • resize(faceROI, myFace, Size(92, 112));//將興趣域size為92*112
  • putText(frame, to_string(pic_num), faces[0].tl(), 3, 1.2, (0, 0, 225), 2, 0);//在 faces[0].tl()的左上角上面寫序號
  • string filename = format("F:\\video\\%d.jpg", pic_num); //圖片的存放位置,frmat的用法跟QString差不對
  • imwrite(filename, myFace);//存在當前目錄下
  • imshow(filename, myFace);//顯示下size后的臉
  • waitKey(500);//等待500us
  • destroyWindow(filename);//:銷毀指定的窗口
  • pic_num++;//序號加1
  • if (pic_num == 11)
  • {
  • return 0;//當序號為11時退出循環(huán),一共拍10張照片
  • }
  • }
  • int c = waitKey(10);
  • if ((char)c == 27) { break; } //10us內輸入esc則退出循環(huán)
  • imshow("frame", frame);//顯示視頻
  • waitKey(100);//等待100us
  • }
  • return 0;

通過上面代碼,完成圖像采集。

//讀取你的CSV文件路徑.

//string fn_csv = string(argv[1]);

string fn_csv = "F:\\video\\ccc\\at.txt";

// 2個容器來存放圖像數據和對應的標簽

vector images;

vector<int> labels;

// 讀取數據. 如果文件不合法就會出錯

// 輸入的文件名已經有了.

try

{

read_csv(fn_csv, images, labels); //從csv文件中批量讀取訓練數據

}

catch (cv::Exception& e)

{

cerr << "Error opening file "" << fn_csv << "". Reason: " << e.msg << endl;

// 文件有問題,我們啥也做不了了,退出了

exit(1);

}

// 如果沒有讀取到足夠圖片,也退出.

if (images.size() <= 1) {

string error_message = "This demo needs at least 2 images to work. Please add more images to your data set!";

CV_Error(CV_StsError, error_message);

}

for (int i = 0; i < images.size(); i++)

{

//cout<

if (images.size() != Size(92, 112))

{

cout << i << endl;

cout << images.size() << endl;

}

}

// 下面的幾行代碼僅僅是從你的數據集中移除最后一張圖片,作為測試圖片

//[gm:自然這里需要根據自己的需要修改,他這里簡化了很多問題]

Mat testSample = images[images.size() - 1];

int testLabel = labels[labels.size() - 1];

images.pop_back();//刪除最后一張照片,此照片作為測試圖片

labels.pop_back();//刪除最有一張照片的labels

// 下面幾行創(chuàng)建了一個特征臉模型用于人臉識別,

// 通過CSV文件讀取的圖像和標簽訓練它。

// T這里是一個完整的PCA變換

//如果你只想保留10個主成分,使用如下代碼

// cv::createEigenFaceRecognizer(10);

//

// 如果你還希望使用置信度閾值來初始化,使用以下語句:

// cv::createEigenFaceRecognizer(10, 123.0);

//

// 如果你使用所有特征并且使用一個閾值,使用以下語句:

// cv::createEigenFaceRecognizer(0, 123.0);

//創(chuàng)建一個PCA人臉分類器,暫時命名為model吧,創(chuàng)建完成后

//調用其中的成員函數train()來完成分類器的訓練

Ptr model = face::create();

model->train(images, labels);

model->save("MyFacePCAModel.xml");//保存路徑可自己設置,但注意用“\\”

Ptr model1 = face::create();

model1->train(images, labels);

model1->save("MyFaceFisherModel.xml");

Ptr model2 = face::create();

model2->train(images, labels);

model2->save("MyFaceLBPHModel.xml");

// 下面對測試圖像進行預測,predictedLabel是預測標簽結果

//注意predict()入口參數必須為單通道灰度圖像,如果圖像類型不符,需要先進行轉換

//predict()函數返回一個整形變量作為識別標簽

int predictedLabel = model->predict(testSample);//加載分類器

int predictedLabel1 = model1->predict(testSample);

int predictedLabel2 = model2->predict(testSample);

// 還有一種調用方式,可以獲取結果同時得到閾值:

// int predictedLabel = -1;

// double confidence = 0.0;

// model->predict(testSample, predictedLabel, confidence);

string result_message = format("Predicted class = %d / Actual class = %d.", predictedLabel, testLabel);

string result_message1 = format("Predicted class = %d / Actual class = %d.", predictedLabel1, testLabel);

string result_message2 = format("Predicted class = %d / Actual class = %d.", predictedLabel2, testLabel);

cout << result_message << endl;

cout << result_message1 << endl;

cout << result_message2 << endl;

getchar();

//waitKey(0);

return 0;

通過上面的代碼進行訓練,訓練使用了python。所以系統(tǒng)環(huán)境需要配置好。

e55243a2-d20d-11ec-8521-dac502259ad0.png

在此文件中,把我們采集到的圖像,放進去,新建一個文件夾。

e57f8a92-d20d-11ec-8521-dac502259ad0.png


之后就是把我們的at.txt也加入我們的文件。

e59a0a02-d20d-11ec-8521-dac502259ad0.png

訓練好后,我們就得到了我們所需要的訓練文件。


e5c0ec26-d20d-11ec-8521-dac502259ad0.png


在我們打卡界面,點擊打卡時就是這樣的。加載訓練好的東西。然后啟動定時器,去獲取攝像頭信號,然后對比,最終和數據庫一致就認為打卡成功。

上面訓練部分,其實提供的另一個工程就全部完成了。


e5dcae8e-d20d-11ec-8521-dac502259ad0.png

這是我們win端界面,圓框就是我們攝像頭采集圖像顯示的位置。


e5f6049c-d20d-11ec-8521-dac502259ad0.png

我們需要在Ubuntu下把庫全部替換,這樣就能編譯過了,然后拷貝到開發(fā)板上運行。如下:

e625682c-d20d-11ec-8521-dac502259ad0.png

進來就提示數據庫打開失敗了,我們這個都是基于數據庫,所以還是比較尷尬的,后期的話可以嘗試自己全部編譯下,然后更新吧。目前就測試,看下效果吧。

e657c902-d20d-11ec-8521-dac502259ad0.jpg

使用的硬件增加了一個攝像頭。

e66e744a-d20d-11ec-8521-dac502259ad0.jpg

這是打開攝像頭采集的樣子。

e686f57e-d20d-11ec-8521-dac502259ad0.gif

這個GIF展示了我們的人臉檢測情況。

e7157efc-d20d-11ec-8521-dac502259ad0.png

由于沒有數據庫,只能打印一些信息。當兩個數據相等時就進入下一步,判斷打卡了。由于沒有數據庫,就展示下電腦端的效果吧。

e726ad30-d20d-11ec-8521-dac502259ad0.pnge77a2ce4-d20d-11ec-8521-dac502259ad0.png

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

    關注

    25

    文章

    5121

    瀏覽量

    97993
收藏 人收藏

    評論

    相關推薦

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

    百度智能云平臺的人臉識別項目,旨在利用其強大的人臉識別服務實現自動人臉識別。選擇百度智能云的原因
    的頭像 發(fā)表于 12-24 10:54 ?525次閱讀
    ElfBoard開源項目|百度智能云平臺<b class='flag-5'>的人臉</b><b class='flag-5'>識別</b>項目

    人臉疲勞檢測應用-米爾基于RK3576核心/開發(fā)板

    本文將介紹基于米爾電子MYD-LR3576開發(fā)板米爾基于瑞芯微RK3576開發(fā)板的人臉疲勞檢測方案測試。
    的頭像 發(fā)表于 12-20 08:06 ?344次閱讀
    <b class='flag-5'>人臉</b>疲勞檢測應用-<b class='flag-5'>米爾</b>基于RK3576核心<b class='flag-5'>板</b>/<b class='flag-5'>開發(fā)板</b>

    如何用OpenCV進行手勢識別--基于米爾全志T527開發(fā)板

    本文將介紹基于米爾電子MYD-LT527開發(fā)板米爾基于全志T527開發(fā)板)的OpenCV手勢識別
    的頭像 發(fā)表于 12-13 08:04 ?817次閱讀
    如何用<b class='flag-5'>OpenCV</b>進行手勢<b class='flag-5'>識別</b>--基于<b class='flag-5'>米爾</b>全志T527<b class='flag-5'>開發(fā)板</b>

    FacenetPytorch人臉識別方案--基于米爾全志T527開發(fā)板

    本篇測評由優(yōu)秀測評者“小火苗”提供。本文將介紹基于米爾電子MYD-LT527開發(fā)板米爾基于全志 T527
    發(fā)表于 11-28 15:57

    FacenetPytorch人臉識別方案--基于米爾全志T527開發(fā)板

    本篇測評由電子工程世界的優(yōu)秀測評者“小火苗”提供。本文將介紹基于米爾電子MYD-LT527開發(fā)板米爾基于全志T527
    的頭像 發(fā)表于 11-28 15:12 ?382次閱讀
    FacenetPytorch<b class='flag-5'>人臉</b><b class='flag-5'>識別</b>方案--基于<b class='flag-5'>米爾</b>全志T527<b class='flag-5'>開發(fā)板</b>

    如何用OpenCV的相機捕捉視頻進行人臉檢測--基于米爾NXP i.MX93開發(fā)板

    本篇測評由優(yōu)秀測評者“eefocus_3914144”提供。 本文將介紹基于米爾電子MYD-LMX93開發(fā)板米爾基于NXP i.MX93
    發(fā)表于 11-15 17:58

    米爾-紫光PG2L100H國產FPGA開發(fā)板試用】米爾-紫光PG2L100H國產FPGA開發(fā)板開箱評測

    很榮幸收到電子發(fā)燒友論壇申請的 米爾-紫光PG2L100H國產FPGA開發(fā)板,現在特地來寫篇測評報告,米爾-紫光PG2L100H國產FPGA由核心
    發(fā)表于 11-07 12:21

    基于OPENCV的相機捕捉視頻進行人臉檢測--米爾NXP i.MX93開發(fā)板

    本文將介紹基于米爾電子MYD-LMX93開發(fā)板米爾基于NXPi.MX93開發(fā)板)的基于OpenCV的人
    的頭像 發(fā)表于 11-07 09:03 ?1146次閱讀
    基于<b class='flag-5'>OPENCV</b>的相機捕捉視頻進行<b class='flag-5'>人臉</b>檢測--<b class='flag-5'>米爾</b>NXP i.MX93<b class='flag-5'>開發(fā)板</b>

    基于OpenCV的人臉識別系統(tǒng)設計

    基于OpenCV的人臉識別系統(tǒng)是一個復雜但功能強大的系統(tǒng),廣泛應用于安全監(jiān)控、人機交互、智能家居等多個領域。下面將詳細介紹基于OpenCV的人臉
    的頭像 發(fā)表于 07-11 15:37 ?1.4w次閱讀

    米爾基于NXP iMX.93開發(fā)板M33處理器應用開發(fā)筆記

    資源MYD-LMX9X開發(fā)板米爾基于NXPiMX.93開發(fā)板)3.軟件資源Windows7及以上版本軟件:IAREmbeddedWorkbench4.板載固件調試
    的頭像 發(fā)表于 06-29 08:01 ?1545次閱讀
    <b class='flag-5'>米爾</b>基于NXP <b class='flag-5'>iMX</b>.93<b class='flag-5'>開發(fā)板</b>的<b class='flag-5'>M</b>33處理器應用<b class='flag-5'>開發(fā)</b>筆記

    米爾NXP i.MX 93開發(fā)板Qt開發(fā)指南

    1. 概述Qt 是一個跨平臺的圖形應用開發(fā)框架,被應用在不同尺寸設備和平臺上,同時提供不同版權版本供用戶選擇。米爾 NXP i.MX 93 開發(fā)板(MYD-LMX9X
    發(fā)表于 06-07 20:45

    米爾NXP i.MX 93開發(fā)板Qt開發(fā)指南

    1.概述Qt是一個跨平臺的圖形應用開發(fā)框架,被應用在不同尺寸設備和平臺上,同時提供不同版權版本供用戶選擇。米爾NXPi.MX93開發(fā)板(MYD-LMX9X
    的頭像 發(fā)表于 06-07 08:01 ?1812次閱讀
    <b class='flag-5'>米爾</b>NXP i.MX 93<b class='flag-5'>開發(fā)板</b>的<b class='flag-5'>Qt</b><b class='flag-5'>開發(fā)</b>指南

    通過物聯(lián)網管理多臺MQTT設備-基于米爾T527開發(fā)板

    本篇測評由電子工程世界的優(yōu)秀測評者“JerryZhen”提供。本文將介紹基于米爾電子MYD-LT527開發(fā)板的網關方案測試。一、系統(tǒng)概述基于米爾
    的頭像 發(fā)表于 05-10 08:01 ?736次閱讀
    通過物聯(lián)網管理多臺MQTT設備-基于<b class='flag-5'>米爾</b>T527<b class='flag-5'>開發(fā)板</b>

    【OpenHarmony鴻蒙實戰(zhàn)】在RK3399開發(fā)板實現智能門禁人臉識別

    基于RK3399開發(fā)板,使用OpenHarmony3.0-LTS開發(fā)的應用。通過定時獲取攝像頭數據,實現人臉識別比對等功能。
    的頭像 發(fā)表于 03-20 17:38 ?1529次閱讀
    【OpenHarmony鴻蒙實戰(zhàn)】在RK3399<b class='flag-5'>開發(fā)板</b>實現智能門禁<b class='flag-5'>人臉</b><b class='flag-5'>識別</b>

    米爾-全志T113-i開發(fā)板試用】發(fā)布opencv-mobile米爾t113i專享預編譯包

    MYC-YT113i核心開發(fā)板 真正的國產核心,100%國產物料認證 國產T113-i處理器配備2*Cortex-A7@1.2GHz ,RISC-V 外置DDR3接口、支持視頻編解碼器
    發(fā)表于 02-25 20:23
    主站蜘蛛池模板: 久久久久国产精品嫩草影院 | 国产亚洲精品久久久久小 | 男人一生要读的书 | 69日本人XXXX护士HD | 国产精品久久久久久免费播放 | beeg日本老师按摩 | 99精品成人无码A片观看金桔 | 免费高清在线影片一区 | 亚洲国产精品一区二区第一页 | 国产99对白在线播放 | 久久99re热在线播放7 | 91福利潘春春在线观看 | 欧美亚洲另类丝袜自拍动漫 | 精品国产5g影院天天爽 | 春药按摩人妻中文字幕 | 久久久96人妻无码精品蜜桃 | 亚洲成色爱我久久 | 户外插BBBBB 蝴蝶中文综合娱乐网2 | 乱xxxjapanese黑人| 亚洲爆乳少妇精品无码专区 | 久久青草免费线观最新 | 99热精品在线av播放 | 97在线视频免费观看97 | 日本高清不卡一区久久精品 | 97伦理电影在线不卡 | 蜜芽一二三区 | 国产亚洲va在线电影 | 性色AV一区二区三区咪爱四虎 | 美女脱精光让男生桶下面 | 伊人久久网国产伊人 | SM调教贱屁股眼哭叫求饶H | 老板揉搓秘书丰满大乳 | 成人国产精品视频频 | 肉伦禁忌小说np | 日本无码欧美激情在线视频 | 99国产精品白浆在线观看免费 | 视频专区亚洲欧美日韩 | 992交通广播| 精品精品国产自在现拍 | 欧美精品一区二区在线电影 | 黄色三级图片 |