A TensorFlow 2.0 implementation of YOLOv4: Optimal Speed and Accuracy of Object Detection
This implementation runs (for now) inference with the original Darknet weights from AlexeyAB. See the roadmap section to see what's next.
To install this package, you can run:
pip install tf2_yolov4
pip install tensorflow
# Check that tf2_yolov4 is installed properly
python -c "from tf2_yolov4.model import YOLOv4; print(YOLOv4)"
Requirements:
- MacOs >= 10.15 since tensorflow-addons is not available for older release of MacOs
- Python >= 3.6
- Compatible versions between TensorFlow and TensorFlow Addons: check the compatibility matrix
Our YOLOv4 implementation supports the weights
argument similarly to Keras applications. To load a model with pretrained
weights, you can simply call:
# Loads Darknet weights trained on COCO
model = YOLOv4(
input_shape,
num_classes,
anchors,
weights="darknet",
)
If weights are available locally, they will be used. Otherwise, they will be automatically downloaded.
- Inference
- CSPDarknet53 backbone with Mish activations
- SPP Neck
- YOLOv3 Head
- Load Darknet Weights
- Image loading and preprocessing
- YOLOv3 box postprocessing
- Handling non-square images
- Training
- Training loop with YOLOv3 loss
- CIoU loss
- Cross mini-Batch Normalization
- Self-adversarial Training
- Mosaic Data Augmentation
- DropBlock
- Enhancements
- Automatic download of pretrained weights (like Keras applications)
Download model
https://github.com/AlexeyAB/darknet#how-to-evaluate-ap-of-yolov4-on-the-ms-coco-evaluation-server
# Transfer model
convert-darknet-weights yolov4.weights -o yolov4.h5
# Run
python test.py