金子邦彦研究室人工知能OpenCV 4 の Python プログラムOpenCV で顔検出(OpenCV,Python を使用)

OpenCV で顔検出(OpenCV,Python を使用)

OpenCV のカスケード分類器を使用

[image]

キーワード: OpenCV, cv2.CascadeClassifier, Python, 顔検出, カスケード分類器, Haar

【サイト内の OpenCV 関連ページ】

【OpenCV の公式情報】

前準備

Python の準備(Windows,Ubuntu 上)

サイト内の関連ページ

関連する外部ページ

Python の公式ページ: https://www.python.org/

Python 開発環境のインストール

OpenCV Python のインストール

Python で OpenCV を動かすためのもの.

OpenCV Python のインストールは:別ページ »で説明1~2 コマンドの実行でインストールできる.

画像ファイル messi5.jpg のダウンロード

https://github.com/opencv/opencv/tree/master/samples/data で公開されている messi5.jpg を使用する(謝辞:画像の作者に感謝します)

OpenCV を用いた顔検出プログラム例

Python プログラムの実行

Python 開発環境(Jupyter Qt Console, Jupyter ノートブック (Jupyter Notebook), Jupyter Lab, Nteract, Spyder, PyCharm, PyScripterなど)も便利である.

Python のまとめ: 別ページ »にまとめ

  1. Windows, Ubuntu, RaspberryPi の場合

    Jupyter Qt Consoleを起動

    jupyter qtconsole
    
  2. Python プログラムの実行

    Ubuntu, RaspberryPi のときは,「IMROOT=os.environ['LOCALAPPDATA'] + '/'」の行を,「IMROOT="/usr/local/image/"」のように書き換える. Google Colaboratory のときは,「IMROOT=os.environ['LOCALAPPDATA'] + '/'」の行を,「IMROOT="./"」のように書き換える.
    import os
    import numpy as np
    import cv2
    %matplotlib inline
    import matplotlib.pyplot as plt
    import warnings
    warnings.filterwarnings('ignore')   # Suppress Matplotlib warnings
    
    IMROOT=os.environ['LOCALAPPDATA'] + '/'
    
    face_cascade = cv2.CascadeClassifier('c:\opencv\data\haarcascades_cuda\haarcascade_frontalface_alt.xml')
    
    bgr = cv2.imread(IMROOT + "messi5.jpg")
    gray = cv2.cvtColor(bgr, cv2.COLOR_BGR2GRAY)
    
    face_rects = face_cascade.detectMultiScale(gray, 1.1, 3)
    if len(face_rects) > 0:
        for (x,y,w,h) in face_rects:
            cv2.rectangle(bgr, (x,y), (x+w,y+h), (0,255,255), 4)
    else:
        print("no faces")
            
    plt.style.use('default')
    plt.imshow(cv2.cvtColor(bgr, cv2.COLOR_BGR2RGB))
    plt.show()
    

    [image]