data:image/s3,"s3://crabby-images/22a94/22a94a0ce97e22a531fc6f68862c8d6d1cb11874" alt=""
Object Tracking, Homographies, and Face Detection
~The sections below detail several assignments I completed for the computer vision course I took as part of my Master's in Computer Science at Georgia Institute of Technology.~
Tracking Objects
This assignment focused on utilizing various forms of Kalman Filters and Particle Filters (implemented without using the cv2.KalmanFilter and cv2.matchTemplate functions). Several examples of each filter are shown and discussed.
Kalman Filters are typically used to track dynamical systems with uncertainty in their measurements by making use of linear quadratic estimation. Although the math for a Kalman filter may seem intimidating, in principle it is merely making use of matrix math with basic physics motion equations while adding steps to account for uncertainty. The Kalman filter is split up into a prediction step that multiplies the estimate by a state transition matrix followed by a measurement update step that considers the measurement and any noise associated with it.
data:image/s3,"s3://crabby-images/1500a/1500ad22c04e99d1c364d0129ddb3c5115e0263e" alt=""
The pictures below show a Kalman Filter being utilized to follow a pedestrian as the cross a sidewalk.
data:image/s3,"s3://crabby-images/9fd35/9fd353c7396779d126350d330609c05530744513" alt=""
data:image/s3,"s3://crabby-images/31293/31293bbb48d97e94c6d477a61edf1188ef323b5b" alt=""
data:image/s3,"s3://crabby-images/f2c88/f2c88af4c571567d9b3d7dfb79f255236fb6d363" alt=""
data:image/s3,"s3://crabby-images/08db3/08db39d6638de90c0bab9907e6d378bc522478e5" alt=""
Unlike Kalman Filters, Particle Filters are much more versatile for solving high dimensional problems. Particle filters have three phases: Prediction, measurement, and resampling. The prediction phase involves taking a distribution of particles based on prior beliefs (initially random) and the measurement phase compares the sensor model (measurements) with each particle to estimate the likelihood that it matches your location. This likelihood is converted into importance weights for each particle. This is followed by a resampling step where particles are re-distributed around the most likely weights and updated based on a motion model. Resampling is important as it prevents particle depletion and ensures that your particle density better matches a probability density function.
The examples below show how particles are used to track a ball from an animation as well as Mitt Romney from a 2012 presidential debate.
data:image/s3,"s3://crabby-images/f7698/f7698889c5c7bd5c85994afb2c0aecc0e5c8f5d7" alt=""
data:image/s3,"s3://crabby-images/93a9e/93a9e6f0a9e2b91a047397a3559057114cf14bfb" alt=""
data:image/s3,"s3://crabby-images/1b4de/1b4dec0ffa373513d7a7ca9e4a0d20fa548b50cd" alt=""
data:image/s3,"s3://crabby-images/20688/20688e0775135ef24b13cea7b7cc3fbdc864b21f" alt=""
data:image/s3,"s3://crabby-images/22a94/22a94a0ce97e22a531fc6f68862c8d6d1cb11874" alt=""
data:image/s3,"s3://crabby-images/fd216/fd21646843059da51be779d016ca30d771e0e0c8" alt=""
data:image/s3,"s3://crabby-images/eea7c/eea7cff90ac431fea8529b1cedab37aeee6c6b35" alt=""
data:image/s3,"s3://crabby-images/17ab6/17ab67c814b739a8470b35ccef6cb74529c786ed" alt=""