You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
361 lines
16 KiB
361 lines
16 KiB
--- |
|
comments: true |
|
description: Learn to accurately identify and count objects in real-time using Ultralytics YOLOv8 for applications like crowd analysis and surveillance. |
|
keywords: object counting, YOLOv8, Ultralytics, real-time object detection, AI, deep learning, object tracking, crowd analysis, surveillance, resource optimization |
|
--- |
|
|
|
# Object Counting using Ultralytics YOLOv8 |
|
|
|
## What is Object Counting? |
|
|
|
Object counting with [Ultralytics YOLOv8](https://github.com/ultralytics/ultralytics/) involves accurate identification and counting of specific objects in videos and camera streams. YOLOv8 excels in real-time applications, providing efficient and precise object counting for various scenarios like crowd analysis and surveillance, thanks to its state-of-the-art algorithms and deep learning capabilities. |
|
|
|
<table> |
|
<tr> |
|
<td align="center"> |
|
<iframe loading="lazy" width="720" height="405" src="https://www.youtube.com/embed/Ag2e-5_NpS0" |
|
title="YouTube video player" frameborder="0" |
|
allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" |
|
allowfullscreen> |
|
</iframe> |
|
<br> |
|
<strong>Watch:</strong> Object Counting using Ultralytics YOLOv8 |
|
</td> |
|
<td align="center"> |
|
<iframe loading="lazy" width="720" height="405" src="https://www.youtube.com/embed/Fj9TStNBVoY" |
|
title="YouTube video player" frameborder="0" |
|
allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" |
|
allowfullscreen> |
|
</iframe> |
|
<br> |
|
<strong>Watch:</strong> Class-wise Object Counting using Ultralytics YOLOv8 |
|
</td> |
|
</tr> |
|
</table> |
|
|
|
## Advantages of Object Counting? |
|
|
|
- **Resource Optimization:** Object counting facilitates efficient resource management by providing accurate counts, and optimizing resource allocation in applications like inventory management. |
|
- **Enhanced Security:** Object counting enhances security and surveillance by accurately tracking and counting entities, aiding in proactive threat detection. |
|
- **Informed Decision-Making:** Object counting offers valuable insights for decision-making, optimizing processes in retail, traffic management, and various other domains. |
|
|
|
## Real World Applications |
|
|
|
| Logistics | Aquaculture | |
|
| :-----------------------------------------------------------------------------------------------------------------------------------------------------: | :----------------------------------------------------------------------------------------------------------------------------------------------------------: | |
|
| ![Conveyor Belt Packets Counting Using Ultralytics YOLOv8](https://github.com/ultralytics/docs/releases/download/0/conveyor-belt-packets-counting.avif) | ![Fish Counting in Sea using Ultralytics YOLOv8](https://github.com/ultralytics/docs/releases/download/0/fish-counting-in-sea-using-ultralytics-yolov8.avif) | |
|
| Conveyor Belt Packets Counting Using Ultralytics YOLOv8 | Fish Counting in Sea using Ultralytics YOLOv8 | |
|
|
|
!!! example "Object Counting using YOLOv8 Example" |
|
|
|
=== "Count in Region" |
|
|
|
```python |
|
import cv2 |
|
|
|
from ultralytics import YOLO, solutions |
|
|
|
model = YOLO("yolov8n.pt") |
|
cap = cv2.VideoCapture("path/to/video/file.mp4") |
|
assert cap.isOpened(), "Error reading video file" |
|
w, h, fps = (int(cap.get(x)) for x in (cv2.CAP_PROP_FRAME_WIDTH, cv2.CAP_PROP_FRAME_HEIGHT, cv2.CAP_PROP_FPS)) |
|
|
|
# Define region points |
|
region_points = [(20, 400), (1080, 404), (1080, 360), (20, 360)] |
|
|
|
# Video writer |
|
video_writer = cv2.VideoWriter("object_counting_output.avi", cv2.VideoWriter_fourcc(*"mp4v"), fps, (w, h)) |
|
|
|
# Init Object Counter |
|
counter = solutions.ObjectCounter( |
|
view_img=True, |
|
reg_pts=region_points, |
|
names=model.names, |
|
draw_tracks=True, |
|
line_thickness=2, |
|
) |
|
|
|
while cap.isOpened(): |
|
success, im0 = cap.read() |
|
if not success: |
|
print("Video frame is empty or video processing has been successfully completed.") |
|
break |
|
tracks = model.track(im0, persist=True, show=False) |
|
|
|
im0 = counter.start_counting(im0, tracks) |
|
video_writer.write(im0) |
|
|
|
cap.release() |
|
video_writer.release() |
|
cv2.destroyAllWindows() |
|
``` |
|
|
|
=== "Count in Polygon" |
|
|
|
```python |
|
import cv2 |
|
|
|
from ultralytics import YOLO, solutions |
|
|
|
model = YOLO("yolov8n.pt") |
|
cap = cv2.VideoCapture("path/to/video/file.mp4") |
|
assert cap.isOpened(), "Error reading video file" |
|
w, h, fps = (int(cap.get(x)) for x in (cv2.CAP_PROP_FRAME_WIDTH, cv2.CAP_PROP_FRAME_HEIGHT, cv2.CAP_PROP_FPS)) |
|
|
|
# Define region points as a polygon with 5 points |
|
region_points = [(20, 400), (1080, 404), (1080, 360), (20, 360), (20, 400)] |
|
|
|
# Video writer |
|
video_writer = cv2.VideoWriter("object_counting_output.avi", cv2.VideoWriter_fourcc(*"mp4v"), fps, (w, h)) |
|
|
|
# Init Object Counter |
|
counter = solutions.ObjectCounter( |
|
view_img=True, |
|
reg_pts=region_points, |
|
names=model.names, |
|
draw_tracks=True, |
|
line_thickness=2, |
|
) |
|
|
|
while cap.isOpened(): |
|
success, im0 = cap.read() |
|
if not success: |
|
print("Video frame is empty or video processing has been successfully completed.") |
|
break |
|
tracks = model.track(im0, persist=True, show=False) |
|
|
|
im0 = counter.start_counting(im0, tracks) |
|
video_writer.write(im0) |
|
|
|
cap.release() |
|
video_writer.release() |
|
cv2.destroyAllWindows() |
|
``` |
|
|
|
=== "Count in Line" |
|
|
|
```python |
|
import cv2 |
|
|
|
from ultralytics import YOLO, solutions |
|
|
|
model = YOLO("yolov8n.pt") |
|
cap = cv2.VideoCapture("path/to/video/file.mp4") |
|
assert cap.isOpened(), "Error reading video file" |
|
w, h, fps = (int(cap.get(x)) for x in (cv2.CAP_PROP_FRAME_WIDTH, cv2.CAP_PROP_FRAME_HEIGHT, cv2.CAP_PROP_FPS)) |
|
|
|
# Define line points |
|
line_points = [(20, 400), (1080, 400)] |
|
|
|
# Video writer |
|
video_writer = cv2.VideoWriter("object_counting_output.avi", cv2.VideoWriter_fourcc(*"mp4v"), fps, (w, h)) |
|
|
|
# Init Object Counter |
|
counter = solutions.ObjectCounter( |
|
view_img=True, |
|
reg_pts=line_points, |
|
names=model.names, |
|
draw_tracks=True, |
|
line_thickness=2, |
|
) |
|
|
|
while cap.isOpened(): |
|
success, im0 = cap.read() |
|
if not success: |
|
print("Video frame is empty or video processing has been successfully completed.") |
|
break |
|
tracks = model.track(im0, persist=True, show=False) |
|
|
|
im0 = counter.start_counting(im0, tracks) |
|
video_writer.write(im0) |
|
|
|
cap.release() |
|
video_writer.release() |
|
cv2.destroyAllWindows() |
|
``` |
|
|
|
=== "Specific Classes" |
|
|
|
```python |
|
import cv2 |
|
|
|
from ultralytics import YOLO, solutions |
|
|
|
model = YOLO("yolov8n.pt") |
|
cap = cv2.VideoCapture("path/to/video/file.mp4") |
|
assert cap.isOpened(), "Error reading video file" |
|
w, h, fps = (int(cap.get(x)) for x in (cv2.CAP_PROP_FRAME_WIDTH, cv2.CAP_PROP_FRAME_HEIGHT, cv2.CAP_PROP_FPS)) |
|
|
|
line_points = [(20, 400), (1080, 400)] # line or region points |
|
classes_to_count = [0, 2] # person and car classes for count |
|
|
|
# Video writer |
|
video_writer = cv2.VideoWriter("object_counting_output.avi", cv2.VideoWriter_fourcc(*"mp4v"), fps, (w, h)) |
|
|
|
# Init Object Counter |
|
counter = solutions.ObjectCounter( |
|
view_img=True, |
|
reg_pts=line_points, |
|
names=model.names, |
|
draw_tracks=True, |
|
line_thickness=2, |
|
) |
|
|
|
while cap.isOpened(): |
|
success, im0 = cap.read() |
|
if not success: |
|
print("Video frame is empty or video processing has been successfully completed.") |
|
break |
|
tracks = model.track(im0, persist=True, show=False, classes=classes_to_count) |
|
|
|
im0 = counter.start_counting(im0, tracks) |
|
video_writer.write(im0) |
|
|
|
cap.release() |
|
video_writer.release() |
|
cv2.destroyAllWindows() |
|
``` |
|
|
|
???+ tip "Region is Movable" |
|
|
|
You can move the region anywhere in the frame by clicking on its edges |
|
|
|
### Argument `ObjectCounter` |
|
|
|
Here's a table with the `ObjectCounter` arguments: |
|
|
|
| Name | Type | Default | Description | |
|
| ----------------- | ------ | -------------------------- | ---------------------------------------------------------------------- | |
|
| `names` | `dict` | `None` | Dictionary of classes names. | |
|
| `reg_pts` | `list` | `[(20, 400), (1260, 400)]` | List of points defining the counting region. | |
|
| `line_thickness` | `int` | `2` | Line thickness for bounding boxes. | |
|
| `view_img` | `bool` | `False` | Flag to control whether to display the video stream. | |
|
| `view_in_counts` | `bool` | `True` | Flag to control whether to display the in counts on the video stream. | |
|
| `view_out_counts` | `bool` | `True` | Flag to control whether to display the out counts on the video stream. | |
|
| `draw_tracks` | `bool` | `False` | Flag to control whether to draw the object tracks. | |
|
|
|
### Arguments `model.track` |
|
|
|
{% include "macros/track-args.md" %} |
|
|
|
## FAQ |
|
|
|
### How do I count objects in a video using Ultralytics YOLOv8? |
|
|
|
To count objects in a video using Ultralytics YOLOv8, you can follow these steps: |
|
|
|
1. Import the necessary libraries (`cv2`, `ultralytics`). |
|
2. Load a pretrained YOLOv8 model. |
|
3. Define the counting region (e.g., a polygon, line, etc.). |
|
4. Set up the video capture and initialize the object counter. |
|
5. Process each frame to track objects and count them within the defined region. |
|
|
|
Here's a simple example for counting in a region: |
|
|
|
```python |
|
import cv2 |
|
|
|
from ultralytics import YOLO, solutions |
|
|
|
|
|
def count_objects_in_region(video_path, output_video_path, model_path): |
|
"""Count objects in a specific region within a video.""" |
|
model = YOLO(model_path) |
|
cap = cv2.VideoCapture(video_path) |
|
assert cap.isOpened(), "Error reading video file" |
|
w, h, fps = (int(cap.get(x)) for x in (cv2.CAP_PROP_FRAME_WIDTH, cv2.CAP_PROP_FRAME_HEIGHT, cv2.CAP_PROP_FPS)) |
|
region_points = [(20, 400), (1080, 404), (1080, 360), (20, 360)] |
|
video_writer = cv2.VideoWriter(output_video_path, cv2.VideoWriter_fourcc(*"mp4v"), fps, (w, h)) |
|
counter = solutions.ObjectCounter( |
|
view_img=True, reg_pts=region_points, names=model.names, draw_tracks=True, line_thickness=2 |
|
) |
|
|
|
while cap.isOpened(): |
|
success, im0 = cap.read() |
|
if not success: |
|
print("Video frame is empty or video processing has been successfully completed.") |
|
break |
|
tracks = model.track(im0, persist=True, show=False) |
|
im0 = counter.start_counting(im0, tracks) |
|
video_writer.write(im0) |
|
|
|
cap.release() |
|
video_writer.release() |
|
cv2.destroyAllWindows() |
|
|
|
|
|
count_objects_in_region("path/to/video.mp4", "output_video.avi", "yolov8n.pt") |
|
``` |
|
|
|
Explore more configurations and options in the [Object Counting](#object-counting-using-ultralytics-yolov8) section. |
|
|
|
### What are the advantages of using Ultralytics YOLOv8 for object counting? |
|
|
|
Using Ultralytics YOLOv8 for object counting offers several advantages: |
|
|
|
1. **Resource Optimization:** It facilitates efficient resource management by providing accurate counts, helping optimize resource allocation in industries like inventory management. |
|
2. **Enhanced Security:** It enhances security and surveillance by accurately tracking and counting entities, aiding in proactive threat detection. |
|
3. **Informed Decision-Making:** It offers valuable insights for decision-making, optimizing processes in domains like retail, traffic management, and more. |
|
|
|
For real-world applications and code examples, visit the [Advantages of Object Counting](#advantages-of-object-counting) section. |
|
|
|
### How can I count specific classes of objects using Ultralytics YOLOv8? |
|
|
|
To count specific classes of objects using Ultralytics YOLOv8, you need to specify the classes you are interested in during the tracking phase. Below is a Python example: |
|
|
|
```python |
|
import cv2 |
|
|
|
from ultralytics import YOLO, solutions |
|
|
|
|
|
def count_specific_classes(video_path, output_video_path, model_path, classes_to_count): |
|
"""Count specific classes of objects in a video.""" |
|
model = YOLO(model_path) |
|
cap = cv2.VideoCapture(video_path) |
|
assert cap.isOpened(), "Error reading video file" |
|
w, h, fps = (int(cap.get(x)) for x in (cv2.CAP_PROP_FRAME_WIDTH, cv2.CAP_PROP_FRAME_HEIGHT, cv2.CAP_PROP_FPS)) |
|
line_points = [(20, 400), (1080, 400)] |
|
video_writer = cv2.VideoWriter(output_video_path, cv2.VideoWriter_fourcc(*"mp4v"), fps, (w, h)) |
|
counter = solutions.ObjectCounter( |
|
view_img=True, reg_pts=line_points, names=model.names, draw_tracks=True, line_thickness=2 |
|
) |
|
|
|
while cap.isOpened(): |
|
success, im0 = cap.read() |
|
if not success: |
|
print("Video frame is empty or video processing has been successfully completed.") |
|
break |
|
tracks = model.track(im0, persist=True, show=False, classes=classes_to_count) |
|
im0 = counter.start_counting(im0, tracks) |
|
video_writer.write(im0) |
|
|
|
cap.release() |
|
video_writer.release() |
|
cv2.destroyAllWindows() |
|
|
|
|
|
count_specific_classes("path/to/video.mp4", "output_specific_classes.avi", "yolov8n.pt", [0, 2]) |
|
``` |
|
|
|
In this example, `classes_to_count=[0, 2]`, which means it counts objects of class `0` and `2` (e.g., person and car). |
|
|
|
### Why should I use YOLOv8 over other object detection models for real-time applications? |
|
|
|
Ultralytics YOLOv8 provides several advantages over other object detection models like Faster R-CNN, SSD, and previous YOLO versions: |
|
|
|
1. **Speed and Efficiency:** YOLOv8 offers real-time processing capabilities, making it ideal for applications requiring high-speed inference, such as surveillance and autonomous driving. |
|
2. **Accuracy:** It provides state-of-the-art accuracy for object detection and tracking tasks, reducing the number of false positives and improving overall system reliability. |
|
3. **Ease of Integration:** YOLOv8 offers seamless integration with various platforms and devices, including mobile and edge devices, which is crucial for modern AI applications. |
|
4. **Flexibility:** Supports various tasks like object detection, segmentation, and tracking with configurable models to meet specific use-case requirements. |
|
|
|
Check out Ultralytics [YOLOv8 Documentation](https://docs.ultralytics.com/models/yolov8/) for a deeper dive into its features and performance comparisons. |
|
|
|
### Can I use YOLOv8 for advanced applications like crowd analysis and traffic management? |
|
|
|
Yes, Ultralytics YOLOv8 is perfectly suited for advanced applications like crowd analysis and traffic management due to its real-time detection capabilities, scalability, and integration flexibility. Its advanced features allow for high-accuracy object tracking, counting, and classification in dynamic environments. Example use cases include: |
|
|
|
- **Crowd Analysis:** Monitor and manage large gatherings, ensuring safety and optimizing crowd flow. |
|
- **Traffic Management:** Track and count vehicles, analyze traffic patterns, and manage congestion in real-time. |
|
|
|
For more information and implementation details, refer to the guide on [Real World Applications](#real-world-applications) of object counting with YOLOv8.
|
|
|