Object Tracking এবং Movement Detection (অবজেক্ট ট্র্যাকিং এবং মুভমেন্ট ডিটেকশন)
অবজেক্ট ট্র্যাকিং হলো একটি প্রক্রিয়া যেখানে ভিডিও বা রিয়েল-টাইম ফুটেজ থেকে নির্দিষ্ট অবজেক্টের অবস্থান পর্যবেক্ষণ করা হয় এবং মুভমেন্ট ডিটেকশন হলো চলমান অবজেক্ট বা অবস্থানের পরিবর্তন সনাক্ত করা। এই প্রযুক্তি সাধারণত ভিডিও সিকিউরিটি, সেলফ-ড্রাইভিং কার, স্পোর্টস অ্যানালাইসিস, এবং রিয়েল-টাইম সিস্টেমে ব্যবহৃত হয়।
Object Tracking টেকনিকস
অবজেক্ট ট্র্যাকিংয়ে বিভিন্ন টেকনিক ব্যবহৃত হয়, যার মধ্যে উল্লেখযোগ্য কয়েকটি হলো:
১. Kalman Filter
- বর্ণনা: Kalman Filter হলো একটি রিসারচ-এবং-প্রেডিকশন অ্যালগরিদম, যা অবজেক্টের অবস্থান প্রেডিক্ট করে এবং অবজেক্টের গতি, অবস্থান, এবং গুণগত মান ধরে রাখে।
- ব্যবহার: স্বয়ংক্রিয় যানবাহন, ড্রোন ট্র্যাকিং এবং অন্যান্য গতিশীল অবজেক্ট পর্যবেক্ষণে।
২. Mean Shift এবং Camshift (Continuously Adaptive Mean Shift)
- Mean Shift: অবজেক্টের কালার হিস্টোগ্রামের ভিত্তিতে ট্র্যাকিং করা হয়।
- Camshift: Mean Shift এর একটি উন্নত সংস্করণ, যা অবস্থান এবং আকারের পরিবর্তন অনুযায়ী ট্র্যাকিং এলাকাকে অ্যাডাপ্ট করে।
- ব্যবহার: ফেস ট্র্যাকিং এবং স্টেশনারি অবজেক্ট ট্র্যাকিংয়ে কার্যকর।
import cv2
# ভিডিও লোড
cap = cv2.VideoCapture('video.mp4')
# ট্র্যাকিংয়ের জন্য ROI নির্বাচন
ret, frame = cap.read()
r, h, c, w = 200, 20, 300, 20 # ROI এর পজিশন সেট করা
track_window = (c, r, w, h)
# ROI এর HSV এবং হিস্টোগ্রাম তৈরি
roi = frame[r:r+h, c:c+w]
hsv_roi = cv2.cvtColor(roi, cv2.COLOR_BGR2HSV)
roi_hist = cv2.calcHist([hsv_roi], [0], None, [180], [0, 180])
cv2.normalize(roi_hist, roi_hist, 0, 255, cv2.NORM_MINMAX)
# ট্র্যাকিংয়ের জন্য Camshift ব্যবহার
while True:
ret, frame = cap.read()
if ret:
hsv = cv2.cvtColor(frame, cv2.COLOR_BGR2HSV)
dst = cv2.calcBackProject([hsv], [0], roi_hist, [0, 180], 1)
# CamShift ব্যবহার করে ট্র্যাকিং
ret, track_window = cv2.CamShift(dst, track_window, (cv2.TERM_CRITERIA_EPS | cv2.TERM_CRITERIA_COUNT, 10, 1))
pts = cv2.boxPoints(ret)
pts = np.int0(pts)
img2 = cv2.polylines(frame, [pts], True, 255, 2)
cv2.imshow('Tracking', img2)
if cv2.waitKey(1) & 0xFF == ord('q'):
break
else:
break
cap.release()
cv2.destroyAllWindows()৩. Optical Flow
- বর্ণনা: Optical Flow প্রযুক্তি ব্যবহার করে বিভিন্ন ফ্রেমে অবজেক্টের গতি শনাক্ত করা হয়। Lucas-Kanade এবং Farneback Optical Flow হলো এই পদ্ধতির দুটি সাধারণ অ্যালগরিদম।
- ব্যবহার: ফিচার ট্র্যাকিং, গতি বিশ্লেষণ, এবং হিউম্যান এক্টিভিটি রিকগনিশনে।
Movement Detection টেকনিকস
মুভমেন্ট ডিটেকশন সাধারণত দুটি ফ্রেমের মধ্যে পার্থক্য নির্ণয় করে করা হয়। এর মাধ্যমে ফ্রেমের নির্দিষ্ট অংশে গতি সনাক্ত করা হয়।
১. Background Subtraction
- বর্ণনা: Background Subtraction টেকনিকে পূর্বের ব্যাকগ্রাউন্ড ফ্রেম এবং বর্তমান ফ্রেমের মধ্যে পার্থক্য নির্ণয় করে মুভমেন্ট ডিটেক্ট করা হয়।
- ব্যবহার: ভিডিও সিকিউরিটি এবং স্টেশনারি অবজেক্ট ডিটেকশনে।
import cv2
cap = cv2.VideoCapture('video.mp4')
fgbg = cv2.createBackgroundSubtractorMOG2()
while True:
ret, frame = cap.read()
if ret:
fgmask = fgbg.apply(frame)
cv2.imshow('Movement Detection', fgmask)
if cv2.waitKey(1) & 0xFF == ord('q'):
break
else:
break
cap.release()
cv2.destroyAllWindows()২. Frame Differencing
- বর্ণনা: দুটি ফ্রেমের মধ্যে পিক্সেল পার্থক্য নির্ণয় করে মুভমেন্ট সনাক্ত করা হয়।
- ব্যবহার: সিম্পল এবং রিয়েল-টাইম মুভমেন্ট ডিটেকশনে কার্যকর।
import cv2
cap = cv2.VideoCapture('video.mp4')
ret, frame1 = cap.read()
ret, frame2 = cap.read()
while cap.isOpened():
diff = cv2.absdiff(frame1, frame2)
gray = cv2.cvtColor(diff, cv2.COLOR_BGR2GRAY)
blur = cv2.GaussianBlur(gray, (5,5), 0)
_, thresh = cv2.threshold(blur, 20, 255, cv2.THRESH_BINARY)
dilated = cv2.dilate(thresh, None, iterations=3)
contours, _ = cv2.findContours(dilated, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
for contour in contours:
if cv2.contourArea(contour) < 900:
continue
(x, y, w, h) = cv2.boundingRect(contour)
cv2.rectangle(frame1, (x, y), (x+w, y+h), (0, 255, 0), 2)
cv2.imshow("Movement Detection", frame1)
frame1 = frame2
ret, frame2 = cap.read()
if cv2.waitKey(40) == 27:
break
cap.release()
cv2.destroyAllWindows()Object Tracking এবং Movement Detection এর প্রয়োগ ক্ষেত্র
- ভিডিও সিকিউরিটি: অবজেক্ট ট্র্যাকিং এবং মুভমেন্ট ডিটেকশন প্রযুক্তি সিকিউরিটি ক্যামেরায় ব্যবহার করা হয়।
- স্বয়ংক্রিয় যানবাহন: ট্রাফিক এবং পথচারীদের অবস্থান ট্র্যাকিং করে সড়ক নিরাপত্তা নিশ্চিত করতে।
- স্পোর্টস অ্যানালাইসিস: খেলোয়াড়দের গতিবিধি এবং অবস্থান বিশ্লেষণে।
- রিমোট সেন্সিং এবং ড্রোন ট্র্যাকিং: নির্দিষ্ট অঞ্চলে অবজেক্ট পর্যবেক্ষণ এবং ট্র্যাকিংয়ে।
- মেডিকেল ইমেজিং: রোগ নির্ণয়ে চলমান অংশ সনাক্তকরণ এবং বিশ্লেষণে।
সারসংক্ষেপ
Object Tracking এবং Movement Detection ইমেজ প্রসেসিং এবং কম্পিউটার ভিশনের গুরুত্বপূর্ণ শাখা। Kalman Filter, Mean Shift, Camshift, এবং Optical Flow সহ বিভিন্ন পদ্ধতি অবজেক্ট ট্র্যাকিংয়ে ব্যবহৃত হয়। Frame Differencing এবং Background Subtraction মুভমেন্ট ডিটেকশনের জন্য কার্যকর। এই প্রযুক্তিগুলো বিভিন্ন ক্ষেত্রে যেমন সিকিউরিটি, স্বয়ংক্রিয় যানবাহন, স্পোর্টস অ্যানালাইসিস এবং মেডিকেল ইমেজিংয়ে গুরুত্বপূর্ণ ভূমিকা পালন করে।