/DistanceEstimationTracking

This repository contains the source code of the paper: Distance Estimation and Animal Tracking for Wildlife Camera Trapping, Peter Johanns, Timm Haucke, Volker Steinhage

Primary LanguagePythonMIT LicenseMIT

Table of contents

  1. Overview
  2. Instructions
  3. Custom Input
  4. Examplary Input and Output
  5. Reproducibility

Overview: Distance Estimation and Tracking for Wildlife Camera Trapping

This repository contains the source code of the paper "Distance Estimation and Animal Tracking for Wildlife Camera Trapping", Peter Johanns, Timm Haucke, Volker Steinhage [arXiv] [Ecological Informatics]

In wildlife density estimation the analysis of camera trap videos is essential for many procedures and often involves labourious, manual analysis.

Most density estimation models require the recognition of an animal in a captured video and its distance in meters to the camera. Some even require an approximation of its movement speed. In practice, combinations of pre-recorded reference videos, additional sensors and manual annotation are used to retrieve this information.

We propose a fully automatic approach that only requires the camera trap video and the width of the Field Of View (FOV) in degrees of the used device. Our approach recognizes animals, calculates their distance to the camera and tracks animals across the complete video, completely automatic.

For an input video our pipeline outputs per frame the position of all visible animals in the current img, their distances to the camera in meters and the 3D position relative to the camera (x, y, z) with the camera at the center of the coordinate system. The output is saved into a csv file like this one and can be used for further processing with tabulary tools like Microsoft Excel or LibreOffice Calc, if desired.

Alt text

Instructions

We provide the possibility to try out the pipeline by yourself on an examplary input video (S01) seen below. The input image is split into single frames and stored here

You can use this Colab notebook Open in Colab

  1. Open the Colab Notebook (a Google account is required) Open in Colab

  2. Click all the "Play" buttons at the upper left corner of each cell from top to bottom. Alt text

    • Colab will now install all required libraries and apply the pipeline to the input video
    • This process will take some time (~20 min) due to the installation
    • Colab will notify you, if the process is completed
  3. You can find the output .csv file at the left file explorer menu under the folder inference_test/output.csv or if you can't wait that long, here.

Alt text

Custom Input

You can also upload your own files and try out the model. You can either upload single images or a complete video.

  • Single images:

    1. Create directory at left file explorer menu (see 3., instructions) under Images/<YOUR_DIRECTORY> and upload your files by right-clicking on the folder.
    2. Change single_imgs = False to single_imgs = True
    3. Change input_frames_dir = "Images/S01_color" to input_frames_dir = "Images/<YOUR_DIRECTORY>"
    4. Change input_fov_deg = 89.89943662633006" to input_fov_deg = <THE FOV in degrees of the used camera>"
  • Videos:

    1. Create directory at left file explorer menu (see 3., instructions) under Images/<YOUR_DIRECTORY> and upload your files by right-clicking on the folder.

    NOTE: You have to split up the video into single .png images before uploading them to the directory!

    Remaining steps identical to step iii. and iv. above

Examplary Input and Output

S01, input video for pipeline

Pipeline output, visualized by projecting the tracks back to 3D.

S01_tracked_3D_animation.mp4

Reproducibility

This version uses an updated MegaDetector version. If you wish to reproduce the results of the original publication, please use tag v1.0, which uses MegaDetector v4.1.