You Only Look Once (YOLO) is a series of real-time object detection systems based on convolutional neural networks. First introduced by Joseph Redmon et al. in 2015,[1] YOLO has undergone several iterations and improvements, becoming one of the most popular object detection frameworks.[2]
The name "You Only Look Once" refers to the fact that the algorithm requires only one forward propagation pass through the neural network to make predictions, unlike previous region proposal-based techniques like R-CNN that require thousands for a single image.
Compared to previous methods like R-CNN and OverFeat,[3] instead of applying the model to an image at multiple locations and scales, YOLO applies a single neural network to the full image. This network divides the image into regions and predicts bounding boxes and probabilities for each region. These bounding boxes are weighted by the predicted probabilities.
OverFeat was an early influential model for simultaneous object classification and localization.[3][4] Its architecture is as follows:
Train a neural network for image classification only ("classification-trained network"). This could be one like the AlexNet.
The last layer of the trained network is removed, and for every possible object class, initialize a network module at the last layer ("regression network"). The base network has its parameters frozen. The regression network is trained to predict the coordinates of two corners of the object's bounding box.
During inference time, the classification-trained network is run over the same image over many different zoom levels and croppings. For each, it outputs a class label and a probability for that class label. Each output is then processed by the regression network of the corresponding class. This results in thousands of bounding boxes with class labels and probability. These boxes are merged until only one single box with a single class label remains.
The original YOLO algorithm, introduced in 2015,[1] divides the image into an grid of cells. If the center of an object's bounding box falls into a grid cell, that cell is said to "contain" that object. Each grid cell predicts B bounding boxes and confidence scores for those boxes. These confidence scores reflect how confident the model is that the box contains an object and how accurate it thinks the box is that it predicts.
In more detail, the network performs the same convolutional operation over each of the patches. The output of the network on each patch is a tuple as follows:where
is the conditional probability that the cell contains an object of class , conditional on the cell containing at least one object.
are the center coordinates, width, and height of the -th predicted bounding box that is centered in the cell. Multiple bounding boxes are predicted to allow each prediction to specialize in one kind of bounding box. For example, slender objects might be predicted by while stout objects might be predicted by .
is the predicted intersection over union (IoU) of each bounding box with its corresponding ground truth.
The network architecture has 24 convolutional layers followed by 2 fully connected layers.
During training, for each cell, if it contains a ground truth bounding box, then only the predicted bounding boxes with the highest IoU with the ground truth bounding boxes is used for gradient descent. Concretely, let be that predicted bounding box, and let be the ground truth class label, then are trained by gradient descent to approach the ground truth, is trained towards , other are trained towards zero.
If a cell contains no ground truth, then only are trained by gradient descent to approach zero.
Released in 2016, YOLOv2 (also known as YOLO9000)[6][7] improved upon the original model by incorporating batch normalization, a higher resolution classifier, and using anchor boxes to predict bounding boxes. It could detect over 9000 object categories. It was also released on GitHub under the Apache 2.0 license.[8]
YOLOv3, introduced in 2018, contained only "incremental" improvements, including the use of a more complex backbone network, multiple scales for detection, and a more sophisticated loss function.[9]
Subsequent versions of YOLO (v4, v5, etc.)[10][11][12][13] have been developed by different researchers, further improving performance and introducing new features. These versions are not officially associated with the original YOLO authors but build upon their work.[5] As of 2023[update], there are up to YOLOv8.[2]