YOLT is an extension of the YOLO v2 framework that can evaluate satellite images of arbitrary size, and runs at ~50 frames per second. Current applications include vechicle detection (cars, airplanes, boats), building detection, and airport detection.
The YOLT code alters a number of the files in src/*.c to allow further functionality. We also built a python wrapper around the C functions to improve flexibility. We utililize the default data format of YOLO, which places images and labels in different directories. For example:
/data/images/train1.tif
/data/labels/train1.txt
Each line of the train1.txt file has the format
<object-class> <x> <y> <width> <height>
Where x, y, width, and height are relative to the image's width and height. Labels can be created with LabelImg, and converted to the appropriate format with the /yolt/scripts/convert.py script.
arXiv paper: You Only Look Twice: Rapid Multi-Scale Object Detection In Satellite Imagery
Blog2: You Only Look Twice (Part II) — Vehicle and Infrastructure Detection in Satellite Imagery
Blog4: Car Localization and Counting with Overhead Imagery, an Interactive Exploration
Blog5: The Satellite Utility Manifold; Object Detection Accuracy as a Function of Image Resolution
Blog6: Panchromatic to Multispectral: Object Detection Performance as a Function of Imaging Bands
The following has been tested on Ubuntu 16.04.2
Install nvidia-docker
Build docker file
nvidia-docker build -t yolt yolt_docker_name /path_to_yolt/docker
Launch the docker container
nvidia-docker run -it -v /raid:/raid yolt_docker_name
# '/raid' is the root directory of your machine, which will
# be shared with the docker container
Run Makefile
cd /path_to_yolt/
make clean
make
Commands should be executed within the docker file. To run the container (with name yolt_train0):
nvidia-docker run -it -v --name yolt_train0 yolt_docker_name
cd /path_to_yolt/scripts
python yolt2.py --help
# e.g. train boats and planes
cd /path_to_yolt/scripts
python yolt2.py \
--mode train \
--outname 3class_boat_plane \
--object_labels_str boat,boat_harbor,airplane \
--cfg_file ave_standard.cfg \
--nbands 3 \
--train_images_list_file boat_airplane_all.txt \
--single_gpu_machine 0 \
--keep_valid_slices False \
--max_batches 60000 \
--gpu 0
# e.g. test on boats, cars, and airplanes
cd /path_to_yolt/scripts
python yolt2.py \
--mode valid \
--outname qgis_labels_all_boats_planes_cars_buffer \
--object_labels_str airplane,airport,boat,boat_harbor,car \
--cfg_file ave_standard.cfg \
--valid_weight_dir train_cowc_cars_qgis_boats_planes_cfg=ave_26x26_2017_11_28_23-11-36 \
--weight_file ave_standard_30000_tmp.weights \
--valid_testims_dir qgis_validation/all \
--keep_valid_slices False \
--valid_make_pngs True \
--valid_make_legend_and_title False \
--edge_buffer_valid 1 \
--valid_box_rescale_frac 1 \
--plot_thresh_str 0.4 \
--slice_sizes_str 416 \
--slice_overlap 0.2 \
--gpu 2
If you plan on using YOLT in your work, please consider citing YOLO and YOLT