使用FastAPI构建车牌检测识别服务

概述

FastAPI

FastAPI是一个现代的高性能 Web 框架,用于使用 Python 构建 API。它可以让开发者轻松快速高效地构建 API,同时提供 API 的自动验证、序列化和文档记录等功能,是构建 Web 服务和微服务的热门选择。

YOLO

YOLO(YOLO(You Only Look Once)是一种流行的物体检测图像分割模型,由华盛顿大学的约瑟夫-雷德蒙(Joseph Redmon)和阿里-法哈迪(Ali Farhadi)开发。YOLO 于 2015 年推出,因其高速度和高精确度而广受欢迎。多年来,从传统的计算机视觉技术到先进的深度学习模型,物体检测技术都有了长足的发展。YOLO 模型系列一直走在这一发展的前沿,不断突破实时物体检测的极限。YOLO 的独特方法将物体检测视为一个单一的回归问题,在单次评估中直接从完整图像中预测边界框和类概率。这种革命性的方法使YOLO 模型在保持高精度的同时,速度明显快于两阶段检测方法。YOLO11融入了计算机视觉研究的最新进展,为实际应用提供了更好的速度-精度权衡。

使用YOLO11实现车牌检测

得益于YOLO模型的速度-精度权衡,即使是使用nano模型,也能在很短时间内训练出可用于一般场景使用的车牌检测模型。

这里我们从CCPD2019数据集选取10000副图片子集和CCPD2020全部图片作为数据集,根据其标注方法生成训练YOLO模型所需要的数据格式。具体数据集制作方法不在此展开。

检测训练

import datetime
from ultralytics import YOLO

def yolo11_detect_train():
    
    model = YOLO('yolo11n.yaml').load('yolo11n.pt')
    
    model.info()
    data='data.yaml'     
    project= 'runs_normal'
    start_time = datetime.datetime.now()
    print(f"开始训练 {
     start_time.strftime('%Y-%m-%d %H:%M:%S')}")
    
    #CCPD图片imgsz=640, 设置batch 64(占用9GB 显存)

    model.train(data=data, 
                epochs=100, 
                imgsz=640, 
                batch=64, 
                workers=8, 
                project=project,
                fliplr = 0.0,
                )
    
    end_time = datetime.datetime.now()
    print(f"训练结束 {
     end_time.strftime('%Y-%m-%d %H:%M:%S')}")


if __name__ == '__main__':

    yolo11_detect_train()

 

车牌识别

常用的车牌识别神经网络有多种,包括CRNN、Intel LPRNet、飞桨PaddleOCR等等,可以选择一种进行训练,均有不错的识别效果。

本项目选择使用CRNN,在CCPD数据集和自行收集制作的车牌数据集进行了训练,能够比较准确的识别常见的车牌,在大部分场景下具有良好的效果。

车牌检测和识别程序

本项目主要构建了class PlateRecognizer进行车牌检测、车牌识别、图像标注等处理。

class PlateRecognizer:
    def __init__(self):
        #初始化yolo检测模型和车牌识别模型
        self.device = torch.device("cuda" if torch.cuda.is_available() else "cpu")
        self.detect_model = YOLO('weights/yolo11n_plate.pt')  # 初始化检测模型
        self.rec_model = init_model(self.device, 'weights/model_color.pth', is_color=True)  # 初始化识别模型
        self.result_list = []
        self.imgsz = 1280
        self.output_path = 'output'
        self.save_image=True
    
    #运行检测推理和车牌识别
    def det_rec_plate(self, img):
        self.result_list=[]
        img_ori = copy.deepcopy(img)
    	#运行检测推理
        results = self.detect_model.predict(source = img,
                            save = False,
            
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值