Go語言實現人臉檢測(Go的OpenCV綁定庫)

文章目錄

  • OpenCV
    • Github
    • 官網
    • 安裝
    • 環境變量
  • Go的OpenCV綁定庫
    • Github
    • 文檔
    • 安裝
    • 搜索視頻設備ID
    • 顯示視頻
    • 檢測人臉

OpenCV

Github

  • https://github.com/opencv/opencv/

官網

  • https://opencv.org/

安裝

brew install opencv
brew upgrade opencv
  • 安裝目錄
cd /usr/local/opt/opencv@4

環境變量

vim ~/.zshrc
export PKG_CONFIG_PATH="/usr/local/opt/opencv@4/lib/pkgconfig:$PKG_CONFIG_PATH"
source ~/.zshrc
  • 驗證是否安裝成功
pkg-config --cflags --libs opencv4

在這里插入圖片描述

Go的OpenCV綁定庫

Github

  • https://github.com/hybridgroup/gocv

文檔

  • https://gocv.io/getting-started/macos/

安裝

go get -u -d gocv.io/x/gocv

搜索視頻設備ID

brew install ffmpeg
# 列出視頻的設備ID
ffmpeg -f avfoundation -list_devices true -i ""

在這里插入圖片描述

注意: [0] FaceTime HD Camera,deviceID := 0 是電腦攝像頭。

顯示視頻

此示例使用設備“0”打開視頻捕獲設備,讀取幀,并在GUI窗口中顯示視頻。

# 初始化
go mod init demo
# 安裝庫
go get -u -d gocv.io/x/gocv
package mainimport ("fmt""github.com/kbinani/screenshot""gocv.io/x/gocv""image"
)func main() {deviceID := 0webcam, _ := gocv.OpenVideoCapture(deviceID)window := gocv.NewWindow("Hello")defer window.Close()// 調整窗口大小winWidth, winHeight := 400, 400window.ResizeWindow(winWidth, winHeight)// 獲取屏幕分辨率width, height, _ := getScreenResolution()winX := (width - winWidth) / 2winY := (height - winHeight) / 2window.MoveWindow(winX, winY-100)img := gocv.NewMat()defer img.Close()for {webcam.Read(&img)// 調整圖像大小size := image.Point{X: winWidth, Y: winHeight}gocv.Resize(img, &img, size, 0, 0, gocv.InterpolationDefault)window.IMShow(img)window.WaitKey(1)}
}func getScreenResolution() (int, int, error) {// 獲取活動顯示器的數量numDisplays := screenshot.NumActiveDisplays()if numDisplays <= 0 {panic("no active display found")}// 獲取第一個顯示器的分辨率bounds := screenshot.GetDisplayBounds(0)width := bounds.Dx()height := bounds.Dy()fmt.Printf("Primary display resolution: %d x %d\n", width, height)return width, height, nil
}

在這里插入圖片描述

檢測人臉

這是一個使用設備“0”打開視頻捕獲設備的更完整示例。它還使用CascadeClassifier類來加載包含分類器數據的外部數據文件。該程序從視頻中獲取每一幀,然后使用分類器來檢測人臉。如果找到任何人臉,它會在每個人臉周圍繪制一個藍色矩形,然后在輸出窗口中顯示視頻。

haarcascade_frontalface_default.xml 是一個預訓練的 Haar 特征分類器,用于人臉檢測。它是由 OpenCV 提供的一個經典工具,基于 Viola-Jones 對象檢測框架。該文件包含了一系列經過訓練的特征,可以快速有效地檢測圖像中的人臉。

Haar 特征分類器是一種基于機器學習的方法,用于圖像中對象的檢測。以下是其主要特點:

  1. 簡單矩形特征:Haar 特征由簡單的矩形區域組成,這些區域被分成亮和暗部分。通過比較這些區域的亮度差異,可以確定特征的存在。

  2. 積分圖像:為了快速計算矩形特征,使用積分圖像(Integral Image)來加速特征計算。這使得檢測過程非常高效。

  3. 級聯分類器:級聯分類器將多個弱分類器(簡單的矩形特征)串聯起來,以形成一個強大的分類器。通過逐級過濾非目標區域,逐步縮小檢測范圍,提高檢測速度。

  • 下載 haarcascade_frontalface_default.xml 文件
package mainimport ("fmt""github.com/kbinani/screenshot""gocv.io/x/gocv""image""image/color"
)func main() {// set to use a video capture device 0deviceID := 0// open webcamwebcam, err := gocv.OpenVideoCapture(deviceID)if err != nil {fmt.Println(err)return}defer webcam.Close()// open display windowwindow := gocv.NewWindow("Face Detect")defer window.Close()// 調整窗口大小winWidth, winHeight := 400, 400window.ResizeWindow(winWidth, winHeight)// 獲取屏幕分辨率width, height, _ := getScreenResolution()winX := (width - winWidth) / 2winY := (height - winHeight) / 2window.MoveWindow(winX, winY-100)// prepare image matriximg := gocv.NewMat()defer img.Close()// color for the rect when faces detectedblue := color.RGBA{0, 0, 255, 0}// load classifier to recognize facesclassifier := gocv.NewCascadeClassifier()defer classifier.Close()if !classifier.Load("./haarcascade_frontalface_default.xml") {fmt.Println("Error reading cascade file: ./haarcascade_frontalface_default.xml")return}fmt.Printf("start reading camera device: %v\n", deviceID)for {if ok := webcam.Read(&img); !ok {fmt.Printf("cannot read device %v\n", deviceID)return}if img.Empty() {continue}// 調整圖像大小size := image.Point{X: winWidth, Y: winHeight}gocv.Resize(img, &img, size, 0, 0, gocv.InterpolationDefault)// detect facesrects := classifier.DetectMultiScale(img)fmt.Printf("found %d faces\n", len(rects))// draw a rectangle around each face on the original imagefor _, r := range rects {gocv.Rectangle(&img, r, blue, 3)}// show the image in the window, and wait 1 millisecondwindow.IMShow(img)window.WaitKey(1)}
}func getScreenResolution() (int, int, error) {// 獲取活動顯示器的數量numDisplays := screenshot.NumActiveDisplays()if numDisplays <= 0 {panic("no active display found")}// 獲取第一個顯示器的分辨率bounds := screenshot.GetDisplayBounds(0)width := bounds.Dx()height := bounds.Dy()fmt.Printf("Primary display resolution: %d x %d\n", width, height)return width, height, nil
}

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/14759.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/14759.shtml
英文地址,請注明出處:http://en.pswp.cn/web/14759.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

子比主題ACG美化插件[全開源]

WordPress插件是一種可以擴展和增強WordPress網站功能的應用程序。子比主題ACG美化插件聽起來像是一個專門為ACG&#xff08;動畫、漫畫、游戲&#xff09;愛好者設計的美化插件&#xff0c;它可能包含多種功能來改善網站的外觀和用戶體驗。 內置功能開關100意味著這個插件提供…

基于CNN卷積神經網絡的金融數據預測matlab仿真,對比BP,RBF,LSTM

目錄 1.程序功能描述 2.測試軟件版本以及運行結果展示 3.核心程序 4.本算法原理 4.1 反向傳播網絡&#xff08;BP&#xff0c;多層感知器MLP&#xff09; 4.2 徑向基函數網絡&#xff08;RBF&#xff09; 4.3 卷積神經網絡&#xff08;CNN&#xff09; 4.4 長短期記憶網…

六(1)、RTKLIB源碼解析 — rnx2rtkp.c

目錄 一、前言 二、main中的參數說明 三、main中的代碼解讀 3.1 總體邏輯框架

計算機網絡套接字知識(非常詳細)從零基礎入門到精通

本節重點 認識IP地址, 端口號, 網絡字節序等網絡編程中的基本概念; 學習socket api的基本用法; 一、預備知識 1.理解源IP地址和目的IP地址 ?在IP數據包頭部中&#xff0c;有兩個IP地址&#xff0c;分別叫做源IP地址和目的IP地址。 思考: 我們光有IP地址就可以完成通信了…

Kotlin Flow應用舉例,launchIn 和collect用法及區別

launchIn 和 collect 都可以用于處理 MutableStateFlow<Message> 消息流&#xff0c;但它們有不同的用途和使用場景。 collect 用于在協程中收集消息流的最新值。它會一直監聽消息流&#xff0c;并在每次消息流的值發生變化時執行指定的代碼塊。 launchIn 用于在協程作…

【30天精通Prometheus:一站式監控實戰指南】第7天:postgres_exporter從入門到實戰:安裝、配置詳解與生產環境搭建指南,超詳細

親愛的讀者們&#x1f44b; ??歡迎加入【30天精通Prometheus】專欄&#xff01;&#x1f4da; 在這里&#xff0c;我們將探索Prometheus的強大功能&#xff0c;并將其應用于實際監控中。這個專欄都將為你提供寶貴的實戰經驗。&#x1f680; ??Prometheus是云原生和DevOps的…

Java基礎之異常(簡單易懂)

異常 1.JAVA異常體系 &#xff08;1&#xff09;Throwable類(表示可拋)是所有異常和錯誤的超類&#xff0c;兩個直接子類為Error和Exception,分別表示錯誤和異常;其中異常類Exception又分為運行時異常和非運行時異常&#xff0c;這兩個異常有很大區別&#xff0c;運行時異常也…

代碼隨想錄算法訓練營第三十一天| 貪心算法理論基礎、LeetCode455.分發餅干、LeetCode376. 擺動序列 、LeetCode53. 最大子序和

貪心算法理論基礎&#xff1a; 貪心算法沒有類似遞歸、回溯的套路。主要的思想可以理解為&#xff1a;用局部最優找全局最優。 #LeetCode 455. Assign Cookies #LeetCode 455. 視頻講解&#xff1a;貪心算法&#xff0c;你想先喂哪個小孩&#xff1f;| LeetCode&#xff1a;4…

魯教版六年級數學下冊-筆記

文章目錄 第五章 基本平面圖形1 線段、射線、直線2 比較線段的長短3 角4 角的比較5 多邊形和圓的初步認識第六章 整式的乘除1 同底數冪的乘法2 冪的乘方與積的乘方3 同底數冪的除法4 零指數冪與負整數指數冪5 整式的乘法6 平方差公式7 完全平方公式8 整式的除法 第七章 相交線與…

全域運營是割韭菜嗎?常見套路有哪些?

隨著全域運營賽道的全面開啟&#xff0c;全域運營服務商和全域運營系統的數量迅速增加&#xff0c;持續激發賽道活力的同時&#xff0c;也讓一些試圖用全域運營割韭菜的人有了可趁之機。 值得慶幸的是&#xff0c;由于當前全域運營賽道剛興起不久&#xff0c;因此&#xff0c;割…

Python | Leetcode Python題解之第110題平衡二叉樹

題目&#xff1a; 題解&#xff1a; class Solution:def isBalanced(self, root: TreeNode) -> bool:def height(root: TreeNode) -> int:if not root:return 0leftHeight height(root.left)rightHeight height(root.right)if leftHeight -1 or rightHeight -1 or a…

C++青少年簡明教程:If選擇語句

C青少年簡明教程&#xff1a;If選擇語句 C中選擇語句的語法是&#xff1a; if (條件) { 條件成立時需要執行的語句... } [else { 條件不成立時需要執行的語句... }] 說明&#xff1a; if后面使用一個括號&#xff0c;括號里是條件——關系表達式。 所謂的關系表達式就是判…

5.24學習記錄

[FSCTF 2023]ez_php2 比較簡單的pop鏈 <?php highlight_file(__file__); Class Rd{public $ending;public $cl;public $poc;public function __destruct(){echo "All matters have concluded";die($this->ending);}public function __call($name, $arg){for…

E1載波:一種2.048Mbps速率的PCM載波

E1載波的基本幀由32個子信道組成 幀長為256個bit,分為32個相等時隙&#xff0c;一個時隙為8個bit。256/328 時隙的編號為CH0~CH31 全幀包含256位,且每一幀用 125us時間傳送 E1載波支持的數據傳輸效率為2.048Mbps&#xff0c;用PCM編碼&#xff08;即 256bit/125us2.048Mbps…

Android 一個activity對應多個window

Android 一個activity對應多個window Android Activity 對應多個Window&#xff0c;Activity是應用程序的重要組成部分&#xff0c;在程序中的一個屏幕界面&#xff0c;用戶可以進行交互操作。在Android應用程序中&#xff0c;Activity對應著一個Window&#xff0c;一個Activi…

微信小程序源碼-基于Java后端的小區租拼車管理信息系統畢業設計(附源碼+演示錄像+LW)

大家好&#xff01;我是程序員一帆&#xff0c;感謝您閱讀本文&#xff0c;歡迎一鍵三連哦。 &#x1f49e;當前專欄&#xff1a;微信小程序畢業設計 精彩專欄推薦&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python畢業設…

洗完咖啡杯的最早時間

題目描述&#xff1a;給定一個數組arr&#xff0c;arr[i]代表第i號咖啡機泡一杯咖啡的時間&#xff0c;給定一個正數N&#xff0c;表示N個人在等著咖啡機&#xff0c;每臺咖啡機只能一個一個的泡咖啡&#xff0c;其次&#xff0c;只有一臺咖啡機可以洗杯子&#xff0c;一次只能…

1.OLED

1.基礎知識

kotlin重復類編譯報錯解決

Duplicate class org.jetbrains.annotations.TestOnly found in modules annotations-12.0 (com.intellij:annotations:12.0) and annotations-13.0 (org.jetbrains:annotations:13.0) Go to the documentation to learn how to <a href"d.android.com/r/tools 參考鏈…

網絡拓撲—DHCP服務配置

文章目錄 DHCP服務搭建相關配置細節前提安裝DHCP服務 DHCP服務搭建 相關配置細節前提 系統&#xff1a;Windows Server 2003 IP網段&#xff1a;10.0.0.0/24 三臺機子&#xff1a; 普通PC機 DHCP服務器 路由器&#xff08;兩塊網卡&#xff0c;連接內外網&#xff09; //注…