GitXplorerGitXplorer
p

IPcam_tracker

public
22 stars
10 forks
0 issues

Commits

List of commits on branch master.
Unverified
1947222dc1dcfa6ee507c443f381d3045f780f2c

Corrected bug in reseting tracking positions

ppablogsal committed 9 years ago
Unverified
3049a2aacd39d9c4ca69f949c08f47ee6ed48b54

Added docstring to new class method

ppablogsal committed 9 years ago
Unverified
ae2c7495713861e5ae225afe14de42a71cc22ab5

Refactored the image sending logic and corrected a bug in ip_cam regarding the drawing of the detection circle

ppablogsal committed 9 years ago
Unverified
f9cc0ea88423e259d96c9af4fdf74abf726dc4ca

Refactored the Camera layer of abstraction

ppablogsal committed 9 years ago
Unverified
02d7f95e050e5694c74ebe36e414092b975a04ba

Corrected some things in README

ppablogsal committed 9 years ago
Unverified
0291c4825a39eb11a61019dbde9fd54f6c8512af

Added docstrings to main script

ppablogsal committed 9 years ago

README

The README file for this repository.

What is THIS?

This is an IP-CAM tracker. I use it to track the movement and behaviour of my cat (his name is BMO - as in Adventure Time ). I love cats and I love gathering statistics and controlling stuff so I joined the best of the two worlds.... In Python!

Note: You can track whatever thing that moves, not only cats.

Note: This is so optimized that even runs in a Raspberry Pi 2 in real time!

What does THIS do?

This uses your boring IP-CAM to produce an awesome surveillance device. The software connects to your IP-CAM and starts gathering images from the video-feed and processing them to detect if something is moving in the image ( More on how the processing is achieved ). For each processed image it sends the coordinates of the centroid of the moving object to further processing ( this "further processing" can be for example, translating the image coordinates to named places as "In the corner of the room" ). The software detects when the moving object changed its place and stayed in the new destination for a while and then it sends you an update using Telegram...With an image!

At the end of the day, it sends you a report with how long the moving object has stayed in each place and a heatmap of the room where you can see the most visited places

How the IMAGE PROCESSING is done?

The processing pipeline works as follows:

  • For each frame in the stream we first transform it to greyscale and blur it. This is because we do not want sharp areas of the image to interfer in the detection process. The bluring is achieved convoluting the image with a gaussian kernel ( technicisms are awesome! ).

* We need to construct the background. We could use a static image without moving objects but that will not work because the ambient light will change among other factors. So what we do is calculate the weighted average of all the frames in the video stream as they come one by one. In this way the changing parts of the frames will be diluted in the average and we can track all the changing properties of the static part of the image. The weight can be chosen in the configuration file.

  • When we have added the image to our background we calculate the difference between our frame and this background. This can have a lot of noise ( a lot of little parts of the image will change ) so in order to clean this differenced image we will binarize the image choosing only the pixels that have at least certain threshold that can be adjusted in the configuration file. Then we dilate this thresholded image to maximize the deletion and remove sharp edges.

  • Finally in this thresholded image we calculate the centroid of the detected pixel to have some sort of "moving object position" and we yield the centroid coordinates.

What about that TELEGRAM stuff?

Oh, thank you for asking! The reporting part of the software is achieved in the form of a Telegram bot. When started, the software instantiates a Telegram bot when provided with a KEY for the Telegram bot API and then start spamming you with images each time your cat/moving object changes position for more than 10 seconds ( this is also configurable ).

THIS will work with my IP CAM?

As it is probably not. But we have been clever in the design! The only thing you need to change is the IP of your camera in the configuration file and the URL where your camera dumps the video stream ( read your camera documentation for this or ask in the deep abyss that Internet is ) and you are done.

Stuff to be done

  • Unit Tests
  • More Unit Tests
  • Async IO
  • Deployment Stuff
  • pip install crazy-ip-tracker