[python] OpenCV를 사용하여 얼굴 인식하기
이번 글에서는 Python 언어와 OpenCV 라이브러리를 사용하여 얼굴을 인식하는 과정을 알아보겠습니다. OpenCV는 영상 처리 및 컴퓨터 비전 작업에 사용되는 강력한 라이브러리로, 다양한 기능을 포함하고 있습니다.
필요한 라이브러리 설치하기
얼굴 인식을 위해 우선 Python과 OpenCV를 설치해야 합니다. 아래의 명령어로 필요한 라이브러리를 설치할 수 있습니다.
pip install opencv-python
이미지에서 얼굴 인식하기
이미지에서 얼굴을 인식하는 방법은 다음과 같습니다.
import cv2
# 이미지 파일 읽기
image = cv2.imread("image.jpg")
# 얼굴 인식을 위한 분류기 로드
face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + "haarcascade_frontalface_default.xml")
# 그레이스케일로 변환
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
# 얼굴 인식 수행
faces = face_cascade.detectMultiScale(gray, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30))
# 얼굴 주변에 사각형 그리기
for (x, y, w, h) in faces:
cv2.rectangle(image, (x, y), (x+w, y+h), (0, 255, 0), 3)
# 이미지 파일로 출력
cv2.imwrite("output.jpg", image)
이 코드는 image.jpg
파일에서 얼굴을 인식하고, 각 얼굴 주변에 사각형을 그려서 output.jpg
로 저장합니다. haarcascade_frontalface_default.xml
파일은 얼굴을 인식하기 위한 학습된 데이터입니다.
실시간 비디오에서 얼굴 인식하기
실시간 비디오에서 얼굴을 인식하는 방법은 다음과 같습니다.
import cv2
# 얼굴 인식을 위한 분류기 로드
face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + "haarcascade_frontalface_default.xml")
# 비디오 캡처 생성
video_capture = cv2.VideoCapture(0)
while True:
# 비디오 프레임 읽기
ret, frame = video_capture.read()
# 그레이스케일로 변환
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
# 얼굴 인식 수행
faces = face_cascade.detectMultiScale(gray, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30))
# 얼굴 주변에 사각형 그리기
for (x, y, w, h) in faces:
cv2.rectangle(frame, (x, y), (x+w, y+h), (0, 255, 0), 3)
# 화면에 출력
cv2.imshow('Video', frame)
# 'q' 키를 누르면 종료
if cv2.waitKey(1) & 0xFF == ord('q'):
break
# 비디오 캡처 종료
video_capture.release()
cv2.destroyAllWindows()
이 코드는 웹캠의 실시간 비디오를 가져와 얼굴을 인식하고, 각 얼굴 주변에 사각형을 그려줍니다. ‘q’ 키를 누르면 종료됩니다.
이렇게 Python과 OpenCV를 사용하여 얼굴을 인식할 수 있습니다. 더 많은 기능을 사용하려면 OpenCV 공식 문서를 참고하세요.
참고 문서: https://docs.opencv.org/