Skip to content

Instantly share code, notes, and snippets.

@pknowledge
Created December 17, 2019 21:52
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save pknowledge/70ea4e0aa30f728eb2a7235edd41b99a to your computer and use it in GitHub Desktop.
Save pknowledge/70ea4e0aa30f728eb2a7235edd41b99a to your computer and use it in GitHub Desktop.
Mean Shift Object Tracking in opencv python
import numpy as np
import cv2 as cv
cap = cv.VideoCapture('slow_traffic_small.mp4')
# take first frame of the video
ret, frame = cap.read()
# setup initial location of window
x, y, width, height = 300, 200, 100, 50
track_window = (x, y ,width, height)
# set up the ROI for tracking
roi = frame[y:y+height, x : x+width]
hsv_roi = cv.cvtColor(roi, cv.COLOR_BGR2HSV)
mask = cv.inRange(hsv_roi, np.array((0., 60., 32.)), np.array((180., 255., 255)))
roi_hist = cv.calcHist([hsv_roi], [0], mask, [180], [0, 180])
cv.normalize(roi_hist, roi_hist, 0, 255,cv.NORM_MINMAX)
# Setup the termination criteria, either 10 iteration or move by atleast 1 pt
term_crit = ( cv.TERM_CRITERIA_EPS | cv.TERM_CRITERIA_COUNT, 10, 1)
cv.imshow('roi',roi)
while(1):
ret, frame = cap.read()
if ret == True:
hsv = cv.cvtColor(frame, cv.COLOR_BGR2HSV)
dst = cv.calcBackProject([hsv], [0], roi_hist, [0, 180], 1)
# apply meanshift to get the new location
ret, track_window = cv.meanShift(dst, track_window, term_crit)
# Draw it on image
x,y,w,h = track_window
final_image = cv.rectangle(frame, (x,y), (x+w, y+h), 255, 3)
cv.imshow('dst', dst)
cv.imshow('final_image',final_image)
k = cv.waitKey(30) & 0xff
if k == 27:
break
else:
break
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment