/Multitarget-tracker

Hungarian algorithm + Kalman filter multitarget tracker implementation.

Primary LanguageC++

travis ci:

Multitarget-tracker

Hungarian algorithm + Kalman filter multitarget tracker implementation.

Demo Videos

  • MobileNet SSD and tracking for low resolution and low quality videos from car DVR:

Tracking:

  • Mouse tracking:

Tracking:

  • Motion Detection and tracking:

Motion Detection and tracking:

  • Multiple Faces tracking:

Multiple Faces tracking:

  • Simple Abandoned detector:

Simple Abandoned detector:

Parameters

  1. Background substraction: built-in Vibe, SuBSENSE and LOBSTER; MOG2 from opencv; MOG, GMG and CNT from opencv_contrib
  2. Foreground segmentation: contours
  3. Matching: Hungrian algorithm or algorithm based on weighted bipartite graphs
  4. Tracking: Linear or Unscented Kalman filter for objects center or for object coordinates and size
  5. Use or not local tracker (LK optical flow) for smooth trajectories
  6. KCF, MIL, MedianFlow, GOTURN or MOSSE tracking for lost objects and collision resolving
  7. Haar face detector from OpenCV
  8. HOG and C4 pedestrian detectors
  9. SSD detector from OpenCV and models from chuanqi305/MobileNet-SSD
  10. YOLO and Tiny YOLO detectors from https://pjreddie.com/darknet/yolo/
  11. Simple Abandoned detector
Old Build Instructions (ambiguous)
  1. Download project sources
  2. Install CMake
  3. Install OpenCV (https://github.com/opencv/opencv) and OpenCV contrib (https://github.com/opencv/opencv_contrib) repositories
  4. Configure project CmakeLists.txt, set OpenCV_DIR. If opencv_contrib don't installed then set disable options USE_OCV_BGFG, USE_OCV_KCF and USE_OCV_UKF
  5. Go to the build directory and run make
New Build Instructions - taken from here
  1. You need CMake gui application, start it.
  2. Select folder Mulitarget-tracker (with CMakeLists.txt file) as source code directory.
  3. Select subfolder build as.. build directory.
  4. Push a button Configure, select your MSVC compiler. Wait.
  5. If OpenCV wasn't founded automatic then select OpenCV_DIR manually. Push a button Configure again.
  6. Push a button Generate.
  7. Now the folder build contains a solution file (.sln). Lets open it in Visual studio!

Usage:

       Usage:
         ./MultitargetTracker <path to movie file> [--example]=<number of example 0..3> [--start_frame]=<start a video from this position> [--end_frame]=<play a video to this position> [--end_delay]=<delay in milliseconds after video ending> [--out]=<name of result video file> [--show_logs]=<show logs> [--gpu]=<use OpenCL>
         ./MultitargetTracker ../data/atrium.avi -e=1 -o=../data/atrium_motion.avi
       Press:
       * 'm' key for change mode: play|pause. When video is paused you can press any key for get next frame.
       * Press Esc to exit from video

       Params: 
       1. Movie file, for example ../data/atrium.avi
       2. [Optional] Number of example: 0 - MouseTracking, 1 - MotionDetector, 2 - FaceDetector, 3 - PedestrianDetector, 4 - MobileNet SSD detector, 5 - YOLO detector
          -e=0 or --example=1
       3. [Optional] Frame number to start a video from this position
          -sf=0 or --start_frame==1500
       4. [Optional] Play a video to this position (if 0 then played to the end of file)
          -ef=0 or --end_frame==200
       5. [Optional] Delay in milliseconds after video ending
          -ed=0 or --end_delay=1000
       6. [Optional] Name of result video file
          -o=out.avi or --out=result.mp4
       7. [Optional] Show Trackers logs in terminal
          -sl=1 or --show_logs=0
       8. [Optional] Use built-in OpenCL
          -g=1 or --gpu=0

Thirdparty libraries

License

GNU GPLv3: http://www.gnu.org/licenses/gpl-3.0.txt