딥러닝 기반의 GOTURN 방식으로 물체 추적하기 [OpenCV/Python]
머신러닝, 딥러닝

딥러닝 기반의 GOTURN 방식으로 물체 추적하기 [OpenCV/Python]

반응형

딥러닝 기반의 물체 추적방식은 다양하지만 OpenCV 내에서 가장 간단하게 해볼수있는 방법은 바로 GOTURN을 이용하는 것이다.

 

출처 : https://www.learnopencv.com/goturn-deep-learning-based-object-tracking/

 

이번에 소개해볼 GOTURN의 소스코드와 기타 자료들은 모두 https://www.learnopencv.com/goturn-deep-learning-based-object-tracking/를 참고했음을 밝힌다.

 

우선 파이썬 개발환경에 아래 코드를 입력한다.

# Copyright 2018 Satya Mallick (LearnOpenCV.com)

# Import modules
import cv2, sys, os

if not (os.path.isfile('goturn.caffemodel') and os.path.isfile('goturn.prototxt')):
    errorMsg = '''
    Could not find GOTURN model in current directory.
    Please ensure goturn.caffemodel and goturn.prototxt are in the current directory
    '''

    print(errorMsg)
    sys.exit()

# Create tracker
tracker = cv2.TrackerGOTURN_create()

# Read video
video = cv2.VideoCapture(0)

# Exit if video not opened
if not video.isOpened():
    print("Could not open video")
    sys.exit()

# Read first frame
ok, frame = video.read()
if not ok:
    print("Cannot read video file")
    sys.exit()

# Define a bounding box
bbox = (276, 23, 86, 320)

# Uncomment the line below to select a different bounding box
# bbox = cv2.selectROI(frame, False)

# Initialize tracker with first frame and bounding box
ok = tracker.init(frame, bbox)

while True:
    # Read a new frame
    ok, frame = video.read()
    if not ok:
        break

    # Start timer
    timer = cv2.getTickCount()

    # Update tracker
    ok, bbox = tracker.update(frame)

    # Calculate Frames per second (FPS)
    fps = cv2.getTickFrequency() / (cv2.getTickCount() - timer);

    # Draw bounding box
    if ok:
        # Tracking success
        p1 = (int(bbox[0]), int(bbox[1]))
        p2 = (int(bbox[0] + bbox[2]), int(bbox[1] + bbox[3]))
        cv2.rectangle(frame, p1, p2, (255, 0, 0), 2, 1)
    else:
        # Tracking failure
        cv2.putText(frame, "Tracking failure detected", (100, 80), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (0, 0, 255), 2)

    # Display tracker type on frame
    cv2.putText(frame, "GOTURN Tracker", (100, 20), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (50, 170, 50), 2);

    # Display FPS on frame
    cv2.putText(frame, "FPS : " + str(int(fps)), (100, 50), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (50, 170, 50), 2);

    # Display result
    cv2.imshow("Tracking", frame)

    # Exit if ESC pressed
    k = cv2.waitKey(1) & 0xff
    if k == 27:
        break

 

코드를 실행하기 위해서는 딥러닝 데이터 파일을 받아야한다. 아래 링크에서 다운이 가능하다.

반응형

https://drive.google.com/open?id=1yJAABnQVrizsfK4AiLWObAJ629UsrXI2

https://drive.google.com/open?id=1rMdm1jSf2xv7Haoeap5IASAcRSOnmzIS

 

 

2개의 링크 파일 모두 다운받으면된다. 각각의 파일을 파이썬 파일과 같은 디렉토리에 집어 넣고 코드를 실행해보면 아래와 같이 웹캠을 통해 영상이 출력될 것이다.

 

 

딥러닝 기반이기 때문에 따로 물체를 설정하지 않아도 물체를 자동으로 추적한다. 사진상 FPS가 9로 나왔는데 실제로는 20정도 나온다.

 

만약 물체를 지정해서 추적하고 싶다면 코드 중간에

# Define a bounding box
bbox = (276, 23, 86, 320)

# Uncomment the line below to select a different bounding box
# bbox = cv2.selectROI(frame, False)

 

를 아래와 같이 수정하면 된다.

# Define a bounding box
# bbox = (276, 23, 86, 320)

# Uncomment the line below to select a different bounding box
bbox = cv2.selectROI(frame, False)

 

다만 몇가지 한계점이 있다. 우선 물체를 정확히 측정하기 위해서는 단조로운 배경과 대비되는 명확한 물체가 있어야하며, 물체가 천천히 움직일때만 추적이 가능하다. 또한 한번 물체를 놓치면 다시 추적이 안된다.

반응형
    # 테스트용