溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

虹軟最新版 python 接口 完整版

發(fā)布時(shí)間:2020-08-08 14:27:44 來源:ITPUB博客 閱讀:416 作者:丸子丸子丸子 欄目:互聯(lián)網(wǎng)科技

虹軟最新版 python 接口 完整版

當(dāng)前開源的人臉檢測模型,識(shí)別很多,很多小伙伴也踩過不少坑。相信不少使用過dlib和facenet人臉識(shí)別的小伙伴都有這樣的疑惑,為什么論文里高達(dá)99.8以上的準(zhǔn)確率,自己實(shí)際使用下來的準(zhǔn)確率卻并不好,甚至用來落實(shí)到百人以內(nèi)的人臉識(shí)別,都經(jīng)常出現(xiàn)誤識(shí)別現(xiàn)象,造成這樣的現(xiàn)象最主要的原因來自于訓(xùn)練人臉識(shí)別模型的樣本和國內(nèi)人臉有差距。因此,這些看似準(zhǔn)確率很高的模型,直接拿來做項(xiàng)目使用是不行的,測試兩種模型在使用幾百人的考勤圖片上的表現(xiàn),準(zhǔn)確率上dlib和facenet 都很不理想。

綜合比較,發(fā)現(xiàn)使用虹軟的人臉識(shí)別接口是目前開源,在國內(nèi)人臉識(shí)別準(zhǔn)確度上最好的選擇。

遺憾的是當(dāng)前虹軟暫時(shí)沒有提供python 接口代碼,目前網(wǎng)上也有部分使用python調(diào)用虹軟接口的案例,但是類似文章千篇一律,基本都是同一個(gè)代碼,反復(fù)轉(zhuǎn)載,也并沒有能一個(gè)完整調(diào)用虹軟全部功能的python接口,函數(shù)名稱也隨意定義并不好記,使用pycharm 開發(fā)也沒有類函數(shù)成員代碼編寫提示,代碼部分不合理的地方也重復(fù)出現(xiàn)… 實(shí)在是不能忍受當(dāng)前已發(fā)布 的python api 接口參差不齊的現(xiàn)象,為此,特意用了幾天時(shí)間將虹軟當(dāng)前版本的全部功能寫出一個(gè)完整好用的python api接口。

出發(fā)點(diǎn)

本質(zhì)上python接口是使用 ctypes 調(diào)用 虹軟的動(dòng)態(tài)鏈接庫,需要去虹軟官網(wǎng) 去選擇 C/C++ 版本SDK 來下載依賴文件。為了在代碼使用上 和 虹軟 提供的 C/C++ 版本演示代碼基本一致,此 python 接口 的函數(shù)名和虹軟的函數(shù)名是一樣的,并且 demo.py 的結(jié)構(gòu) 基本就是 C/C++ 版本演示代碼的 python 翻譯版。
代碼地址: ArcFace-python 如果代碼對你有幫助,給個(gè)star 吧!

優(yōu)化點(diǎn)

1.重寫了所有結(jié)構(gòu)體對象類的打印屬性 和 成員變量,方便 python 可以直接print 對象查看虹軟返回的結(jié)果信息,以及 pycharm 編寫代碼時(shí)可以提供 提示信息。
2.在此之前其他博客中的 python 接口 在給虹軟引擎?zhèn)魅雸D像時(shí)都使用了這種方式:

frame_byte=bytes(frame.data)

frame_byte_p=cast(framebyte,c_ubyte_p)

但是以上可以改為:

frame.ctypes.data_as(POINTER(c_ubyte))

這樣可以減少 numpy 圖像轉(zhuǎn)換為字節(jié)流這一步的消耗

注意

1.當(dāng)前接口需要下載虹軟最新的(2.2)C/C++版本 SDK。

2.虹軟的C/C++接口支持很多圖像格式傳入,但是 python 使用opencv 做圖像處理時(shí)基本都是 ASVL_PAF_RGB24_B8G8R8 這種格式(就是cv2.imread() 得到的numpy圖像),并且默認(rèn)使用該接口時(shí) 都是使用 這種圖片格式。因此此接口 依賴 opencv,如果沒有可以直接pip安裝。

3.虹軟的配個(gè)函數(shù)都會(huì)返回一盒狀態(tài)碼,要做好狀態(tài)碼的判斷工作,確保使用正確,如果狀態(tài)碼 返回值不是 MOK(值為0),說明函數(shù)執(zhí)行出錯(cuò),可以對照 doc文檔中的錯(cuò)誤碼解釋對照。

4.第一次運(yùn)行代碼需要聯(lián)網(wǎng),因?yàn)闀?huì)做激活操作,首次運(yùn)行激活成功后會(huì)得到一個(gè)ArcFace64.dat文件,當(dāng)有此文件以后,可以不用執(zhí)行激活代碼。

5.涉及到傳入圖片的函數(shù)操作,要確保送入的圖片寬度為 4 的整數(shù)倍,如果不是則要提前做好裁剪,或者做resize操作。

6.當(dāng)前默認(rèn)為圖片檢測模式,人臉屬性值中的faceID始終為空,當(dāng)需要運(yùn)行視頻人臉檢測的話可以將 初始化引擎 函數(shù)中 ASF_DETECT_MODE_IMAGE改為 ASF_DETECT_MODE_VIDEO即代表追蹤模式,這樣可以減少人臉檢測的消耗,并且此時(shí)返回的人臉信息中的faceID 將會(huì)有值,這在視頻人臉識(shí)別中很有用,可以減少人臉重復(fù)提取識(shí)別。

7.特征值和人臉屬性檢測可能會(huì)失敗。虹軟在做特征提取和屬性提取這些功能時(shí)會(huì)對人臉區(qū)域有一個(gè)判斷操作,如果人臉模糊,或者提供的人臉坐標(biāo)位置不對有偏差,會(huì)返回81925(人臉特征檢測結(jié)果置信度低)錯(cuò)誤碼。所以一定要對返回狀態(tài)碼引起重視。

8.虹軟有兩個(gè)描述人臉檢測位置和角度信息的對象 ASF_SingleFaceInfo(單人臉信息) ASF_MultiFaceInfo(多人臉信息),人臉識(shí)別流程是先檢測到人臉,再對人臉提取特征值信息,再用特征值信息比較相似度。虹軟人臉檢測時(shí)返回 ASF_MultiFaceInfo對象(哪怕只檢測到了一個(gè)人),用于提取人臉特征信息的函數(shù)需要 輸入 ASF_SingleFaceInfo的對象,因此在提取特征信息時(shí),需要根據(jù) ASF_MultiFaceInfo中的信息 構(gòu)建 ASF_SingleFaceInfo對象來提取特征值,除了 提取特征值函數(shù)外,虹軟的其他人臉屬性 提取,比如:年齡/性別識(shí)別,活體檢測,人臉3D角度 等功能都是要送入 ASF_MultiFaceInfo對象,但是其中活體檢測又要求單張大圖片中只能檢測一個(gè)活體,超出返回未知,而3D角度檢測單張大圖時(shí)最多返回4個(gè) 人臉的3D角度值,這些地方可能不太好控制,需要注意。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI