顔検出用の Opencv Python プログラム

顔検出用の Opencv Python プログラム

与えられたプログラムの目的は、関心のあるオブジェクト (顔) をリアルタイムで検出し、同じオブジェクトを追跡し続けることです。これは、Python で顔を検出する方法の簡単な例です。必要なオブジェクトに対して分類器をトレーニングすることで、検出対象として選択した他のオブジェクトのトレーニング サンプルを使用することもできます。以下の要件をダウンロードする手順は次のとおりです。

手順:

  1. Python 2.7.x バージョンの numpy と Opencv 2.7.x バージョンをダウンロードします。Windows が 32 ビットまたは 64 ビットと互換性があるかどうかを確認し、それに応じてインストールします。
  2. Python で numpy が実行されていることを確認してから、opencv をインストールしてみてください。
  3. haarcascade_eye.xml ファイルと haarcascade_frontalface_default.xml ファイルを同じフォルダーに配置します (リンクは以下のコードにあります)。

実装

Python
   # OpenCV program to detect face in real time   # import libraries of python OpenCV    # where its functionality resides   import   cv2   # load the required trained XML classifiers   # https://github.com/opencv/opencv/tree/master   # data/haarcascades/haarcascade_frontalface_default.xml   # Trained XML classifiers describes some features of some   # object we want to detect a cascade function is trained   # from a lot of positive(faces) and negative(non-faces)   # images.   face_cascade   =   cv2  .  CascadeClassifier  (  'haarcascade_frontalface_default.xml'  )   # https://github.com/opencv/opencv/tree/master   # /data/haarcascades/haarcascade_eye.xml   # Trained XML file for detecting eyes   eye_cascade   =   cv2  .  CascadeClassifier  (  'haarcascade_eye.xml'  )   # capture frames from a camera   cap   =   cv2  .  VideoCapture  (  0  )   # loop runs if capturing has been initialized.   while   1  :   # reads frames from a camera   ret     img   =   cap  .  read  ()   # convert to gray scale of each frames   gray   =   cv2  .  cvtColor  (  img     cv2  .  COLOR_BGR2GRAY  )   # Detects faces of different sizes in the input image   faces   =   face_cascade  .  detectMultiScale  (  gray     1.3     5  )   for   (  x    y    w    h  )   in   faces  :   # To draw a rectangle in a face    cv2  .  rectangle  (  img  (  x    y  )(  x  +  w    y  +  h  )(  255    255    0  )  2  )   roi_gray   =   gray  [  y  :  y  +  h     x  :  x  +  w  ]   roi_color   =   img  [  y  :  y  +  h     x  :  x  +  w  ]   # Detects eyes of different sizes in the input image   eyes   =   eye_cascade  .  detectMultiScale  (  roi_gray  )   #To draw a rectangle in eyes   for   (  ex    ey    ew    eh  )   in   eyes  :   cv2  .  rectangle  (  roi_color  (  ex    ey  )(  ex  +  ew    ey  +  eh  )(  0    127    255  )  2  )   # Display an image in a window   cv2  .  imshow  (  'img'    img  )   # Wait for Esc key to stop   k   =   cv2  .  waitKey  (  30  )   &   0xff   if   k   ==   27  :   break   # Close the window   cap  .  release  ()   # De-allocate any associated memory usage   cv2  .  destroyAllWindows  ()   

出力:

出力

次の記事:

顔検出用の Opencv C++ プログラム クイズの作成