Update README.md
Browse files# License Plate Character Detection Model
This repository contains a YOLOv8-based model for detecting characters in license plates. The model is trained to identify and localize individual characters on vehicle license plates, which can be useful for various applications such as automated parking systems, traffic monitoring, and vehicle identification.
## Model Details
- **Model Architecture**: YOLOv8
- **Task**: Character detection in license plates
- **Performance Metrics**: Accuracy, Precision, Recall
## Visual Demonstration
![val_batch2_labels.jpg](https://cdn-uploads.huggingface.co/production/uploads/6537b44c01281b544234189c/3IJuAynR7Mg3bHISgeCgZ.jpeg)
This image demonstrates the model's ability to detect and localize individual characters on a license plate. The bounding boxes show the detected characters.
## Installation
To use this model, you'll need to have Python installed along with the following dependencies:
```
pip install ultralytics
pip install torch
pip install huggingface_hub
```
## Usage
Here's a basic example of how to use the model:
```python
from ultralytics import YOLO
import cv2
import numpy as np
# Load the YOLOv8 model
model = YOLO('path/to/your/best.pt') # Load your trained model
# Read the image
image = cv2.imread('path/to/your/image.jpg')
# Run inference on the image
results = model(image)
# Process the results
for result in results:
boxes = result.boxes.cpu().numpy() # Get bounding boxes
for box in boxes:
# Get box coordinates
x1, y1, x2, y2 = box.xyxy[0]
x1, y1, x2, y2 = int(x1), int(y1), int(x2), int(y2)
# Draw bounding box
cv2.rectangle(image, (x1, y1), (x2, y2), (0, 255, 0), 2)
# If you have class names, you can add them to the image
if box.cls is not None:
label = f"{result.names[int(box.cls[0])]} {box.conf[0]:.2f}"
cv2.putText(image, label, (x1, y1 - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.9, (0, 255, 0), 2)
# Save or display the result
cv2.imwrite('output_image.jpg', image)
# Or to display (if running in an environment with GUI):
# cv2.imshow('Result', image)
# cv2.waitKey(0)
# cv2.destroyAllWindows()
```
## Training
If you want to train the model on your own dataset:
1. Prepare your dataset in the appropriate format for YOLOv8.
2. Use the YOLOv8 training script with your custom configuration.
## Model Performance
### Accuracy
Our model achieves an overall accuracy of [97.12]% on the test set. Here's a breakdown of accuracy for each character:
![labels.jpg](https://cdn-uploads.huggingface.co/production/uploads/6537b44c01281b544234189c/EegpnQl3Fn9UO48Z242Gq.jpeg)
### Confusion Matrix
Below is the confusion matrix for our model, showing its performance across all characters:
![confusion_matrix.png](https://cdn-uploads.huggingface.co/production/uploads/6537b44c01281b544234189c/_IyyLB2_9W8drXRi5UZ_h.png)
This matrix provides insights into which characters are most often confused with each other, helping to identify areas for potential improvement.
### Additional Metrics
![results.png](https://cdn-uploads.huggingface.co/production/uploads/6537b44c01281b544234189c/YLmzwlKgSN_qZ5Ix_SvgP.png)
- Precision: [99.3]%
- Recall: [93.45]%
- mAP (mean Average Precision): [97.544]%
For any questions or feedback, please open an issue in this repository.
@@ -1,15 +1,14 @@
|
|
1 |
-
---
|
2 |
-
license: mit
|
3 |
-
metrics:
|
4 |
-
- accuracy
|
5 |
-
- precision
|
6 |
-
- recall
|
7 |
-
- confusion_matrix
|
8 |
-
tags:
|
9 |
-
-
|
10 |
-
-
|
11 |
-
-
|
12 |
-
-
|
13 |
-
-
|
14 |
-
pipeline_tag: object-detection
|
15 |
---
|
|
|
1 |
+
---
|
2 |
+
license: mit
|
3 |
+
metrics:
|
4 |
+
- accuracy
|
5 |
+
- precision
|
6 |
+
- recall
|
7 |
+
- confusion_matrix
|
8 |
+
tags:
|
9 |
+
- License-Plate-Character-Detector
|
10 |
+
- Character recognition
|
11 |
+
- ocr
|
12 |
+
- YOLOv8m
|
13 |
+
pipeline_tag: object-detection
|
|
|
14 |
---
|