|
--- |
|
base_model: microsoft/trocr-base-handwritten |
|
tags: |
|
- trocr |
|
- image-to-text |
|
- license-plate-number |
|
model-index: |
|
- name: license_plate_recognizer |
|
results: |
|
- task: |
|
type: image-to-text |
|
name: License Plate Recognition |
|
dataset: |
|
type: custom_dataset |
|
name: Custom License Plate Dataset |
|
config: default |
|
split: test |
|
revision: main |
|
metrics: |
|
- type: cer |
|
value: 0.0231 |
|
name: Test CER |
|
config: default |
|
args: |
|
max_order: 4 |
|
source: |
|
name: Hugging Face Model Card |
|
url: https://huggingface.co/PawanKrGunjan/license_plate_recognizer |
|
license: mit |
|
language: |
|
- en |
|
metrics: |
|
- cer |
|
library_name: transformers |
|
pipeline_tag: image-to-text |
|
datasets: |
|
- charliexu07/license_plates |
|
--- |
|
<!-- This model card has been generated automatically according to the information the Trainer had access to. You |
|
should probably proofread and complete it, then remove this comment. --> |
|
|
|
[<img src="https://raw.githubusercontent.com/wandb/assets/main/wandb-github-badge-28.svg" alt="Visualize in Weights & Biases" width="200" height="32"/>](https://wandb.ai/pawankrgunjan/huggingface/runs/v5cu1qdh) |
|
|
|
|
|
# license_plate_recognizer |
|
|
|
This model is a fine-tuned version of [microsoft/trocr-base-handwritten](https://huggingface.co/microsoft/trocr-base-handwritten) specifically tailored for recognizing license plate numbers from images. The fine-tuning process has been optimized to accurately decode alphanumeric characters typically found on license plates. |
|
|
|
## Model Description |
|
|
|
The base model, `microsoft/trocr-base-handwritten`, is a Transformer-based OCR model designed for recognizing handwritten text. This fine-tuned version is adapted for license plate recognition, enhancing its ability to read and transcribe license plates from various sources, including images captured under different lighting and angles. |
|
|
|
## Intended Uses & Limitations |
|
|
|
### Intended Uses |
|
- **License Plate Recognition:** This model is designed to extract and transcribe alphanumeric characters from images of license plates. It can be used in various applications such as automated toll systems, parking management, and law enforcement. |
|
|
|
### Limitations |
|
- **Character Set:** The model is optimized for the specific alphanumeric characters commonly found on license plates. It may not perform well on text outside this domain. |
|
- **Environmental Factors:** While robust to typical variations in image quality, extreme conditions like very low light, heavy blurring, or unusual angles may reduce accuracy. |
|
|
|
## Training and Evaluation Data |
|
|
|
The model was fine-tuned on a dataset consisting of license plate images. The dataset includes a diverse set of license plates captured in various environments and lighting conditions, ensuring robustness in real-world applications. However, specific details about the dataset (e.g., size, source) are not provided here. |
|
|
|
## Training Procedure |
|
|
|
### Training Hyperparameters |
|
|
|
The following hyperparameters were used during training: |
|
- **learning_rate:** 2e-05 |
|
- **train_batch_size:** 8 |
|
- **eval_batch_size:** 8 |
|
- **seed:** 42 |
|
- **optimizer:** Adam with betas=(0.9, 0.999) and epsilon=1e-08 |
|
- **lr_scheduler_type:** linear |
|
- **num_epochs:** 7 |
|
|
|
### Training Results |
|
|
|
| Training Loss | Epoch | Step | Validation Loss | Cer | |
|
|:-------------:|:-----:|:----:|:---------------:|:------:| |
|
| 0.2605 | 1.0 | 254 | 0.0798 | 0.0253 | |
|
| 0.138 | 2.0 | 508 | 0.0660 | 0.0177 | |
|
| 0.0435 | 3.0 | 762 | 0.0645 | 0.0146 | |
|
| 0.0344 | 4.0 | 1016 | 0.0594 | 0.0173 | |
|
| 0.011 | 5.0 | 1270 | 0.0626 | 0.0160 | |
|
| 0.0021 | 6.0 | 1524 | 0.0567 | 0.0120 | |
|
| 0.0007 | 7.0 | 1778 | 0.0599 | 0.0137 | |
|
|
|
### Final Evaluation Metrics |
|
- **Loss:** 0.0653 |
|
- **Cer:** 0.0231 |
|
|
|
Certainly! Here’s the updated "How to Use the Model" section with the correct username: |
|
|
|
|
|
## How to Use the Model |
|
|
|
Here is how you can use this fine-tuned model in PyTorch to recognize license plate numbers: |
|
|
|
```python |
|
from transformers import TrOCRProcessor, VisionEncoderDecoderModel |
|
from PIL import Image |
|
import requests |
|
|
|
# Load an image of a license plate |
|
url = 'https://example.com/path/to/license_plate_image.jpg' |
|
image = Image.open(requests.get(url, stream=True).raw).convert("RGB") |
|
|
|
# Initialize the processor and the fine-tuned model |
|
processor = TrOCRProcessor.from_pretrained('PawanKrGunjan/license_plate_recognizer') |
|
model = VisionEncoderDecoderModel.from_pretrained('PawanKrGunjan/license_plate_recognizer') |
|
|
|
# Preprocess the image |
|
pixel_values = processor(images=image, return_tensors="pt").pixel_values |
|
|
|
# Generate text (license plate number) |
|
generated_ids = model.generate(pixel_values) |
|
generated_text = processor.batch_decode(generated_ids, skip_special_tokens=True)[0] |
|
|
|
print("Recognized License Plate Number:", generated_text) |
|
``` |
|
|
|
In this example: |
|
1. Replace the `url` with the actual URL of an image containing a license plate. |
|
2. The model and processor are loaded from your fine-tuned model on the Hugging Face Hub (`PawanKrGunjan/license_plate_recognizer`). |
|
|
|
## Framework Versions |
|
|
|
- **Transformers:** 4.42.3 |
|
- **Pytorch:** 2.1.2 |
|
- **Datasets:** 2.20.0 |
|
- **Tokenizers:** 0.19.1 |