Skip to content

jianzhnie/RefineDet_Pytorch

Repository files navigation

Single-Shot Refinement Neural Network for Object Detection

A higher performance PyTorch implementation of Single-Shot Refinement Neural Network for Object Detection. The official and original Caffe code can be found here.

Table of Contents

       

Performance

VOC2007 Test

mAP (Single Scale Test)
Arch Paper Caffe Version Our PyTorch Version
RefineDet320 80.0% 79.52% 79.81%
RefineDet512 81.8% 81.85% 80.50%

Installation

  • Install PyTorch by selecting your environment on the website and running the appropriate command.
    • Note: You should use at least PyTorch0.4.0
  • Clone this repository.
    • Note: We currently only support Python 3+.
  • Then download the dataset by following the instructions below.
  • Note: For training, we currently support VOC and COCO, and aim to add ImageNet support soon.

Datasets

To make things easy, we provide bash scripts to handle the dataset downloads and setup for you. We also provide simple dataset loaders that inherit torch.utils.data.Dataset, making them fully compatible with the torchvision.datasets API.

COCO

Microsoft COCO: Common Objects in Context

Download COCO 2014
# specify a directory for dataset to be downloaded into, else default is ~/data/
sh data/scripts/COCO2014.sh

VOC Dataset

PASCAL VOC: Visual Object Classes

Download VOC2007 trainval & test
# specify a directory for dataset to be downloaded into, else default is ~/data/
sh data/scripts/VOC2007.sh # <directory>
Download VOC2012 trainval
# specify a directory for dataset to be downloaded into, else default is ~/data/
sh data/scripts/VOC2012.sh # <directory>

Training RefineDet

  • First download the fc-reduced VGG-16 PyTorch base network weights at: https://s3.amazonaws.com/amdegroot-models/vgg16_reducedfc.pth

  • By default, we assume you have downloaded the file in the RefineDet.PyTorch/weights dir:

  • To train RefineDet320 or RefineDet512 using the train scripts train_refinedet320.sh and train_refinedet512.sh. You can manually change them as you want.

./train_refinedet320.sh  #./train_refinedet512.sh
  • Note:
    • For training, an NVIDIA GPU is strongly recommended for speed.
    • For instructions on Visdom usage/installation, see the Installation section.
    • You can pick-up training from a checkpoint by specifying the path as one of the training parameters (again, see train_refinedet.py for options)

Evaluation

To evaluate a trained network:

./eval_refinedet.sh

You can specify the parameters listed in the eval_refinedet.py file by flagging them or manually changing them.

References

Releases

No releases published

Packages

No packages published