Skip to content

Luxios22/AnomalyDetectionCVPR2018-Pytorch

 
 

Repository files navigation

AnomalyDetectionCVPR2018-Pytorch

Pytorch version of - https://github.com/WaqasSultani/AnomalyDetectionCVPR2018

Future Improvements

In this section, I list the future improvements I intend to add to this repository. Please feel free to recommend new features. I also happily accept PR's! 😏

  • I3D feature extraction
  • MFNET feature extraction

Known Issues:

  • AUC is not exactly as reported in the paper (0.71 vs 0.75) - might be affected by the weights of C3D
  • Faulty video_demo

Install Anaconda Environment

conda env create -f environment.yml

conda activate adCVPR18

Download C3D Weights

I couldn't upload here the weights for the C3D model because the file is too big, but it can be found here: https://github.com/DavideA/c3d-pytorch

Precomputed Features

Can be downloaded from: https://drive.google.com/drive/folders/1rhOuAdUqyJU4hXIhToUnh5XVvYjQiN50?usp=sharing

Pre-Trained Anomaly Detector

Check out exps/models for for trained models on the pre-computed features

The loss graph during training is shown here:

Features Extraction

python feature_extractor.py --dataset_path "path-to-dataset" --pretrained_3d "path-to-pretrained-fe"

Training

python TrainingAnomalyDetector_public.py --features_path "path-to-dataset" --annotation_path "path-to-train-annos"

Generate ROC Curve

python generate_ROC.py --features_path "path-to-dataset" --annotation_path "path-to-annos"

Using my pre-trained model after 40K iterations, I achieve this following performance on the test-set. I'm aware that the current model doesn't achieve AUC of 0.75 as reported in the original paper. This can be caused by different weights of the C3D model.

Demo *

python video_demo.py --feature_extractor "path-to-pretrained-fe" --feature_method "fe-method" --ad_model "path-to-pretrained-ad-model" --n_segments "number-of-segments"

For example, the command could be like python video_demo.py --feature_extractor pretrained/c3d.pickle --feature_method c3d --ad_model exps/models/model_final_100000.weights --n_segments 32

Then it will open a GUI and the GUI would let you load a video and run the Anomaly Detection code (including feature extraction) and output a graph of the Anomaly Detection prediction.

Annotation *

python annotation_methods.py --path_list LIST_OF_VIDEO_PATH --dir_list LIST_OF_LIST_WITH_PATH_AND_VIDEO_NAME --normal_or_not LIST_TRUE_FALUE

This is currently just for demo but will allow training with nex videos

*Contrbuted by Peter Overbury of Sussex Universty IISP Group

Cite

@misc{anomaly18cvpr-pytorch,
  author       = "Eitan Kosman",
  title        = "Pytorch implementation of Real-World Anomaly Detection in Surveillance Videos",
  howpublished = "\url{https://github.com/ekosman/AnomalyDetectionCVPR2018-Pytorch}",
  note         = "Accessed: 20xx-xx-xx"
}

FAQ

Q: video_demo doesn't show videos
A: Downlaod and install LAVFilters: http://forum.doom9.org/showthread.php?t=156191

Releases

No releases published

Packages

No packages published

Languages

  • Python 50.5%
  • Jupyter Notebook 49.5%