自动定位并识别图像中的车牌号码和车牌颜色,提供Web API和原生API。
XLPR SDK适用于为各种应用增加车牌自动识别能力,支持多个区域检测,支持车牌颜色和号码输出,提供Web API和 原生API。
XLPR主要由三个主要部分构成:D-Net、R-NET和C-Net,分别负责车牌区域的检测、车牌号码识别 和车牌颜色识别,如下图所示:
XLPR开发包的目录组织说明如下:
xlpr_sdk
| - core # 核心代码目录
| - d_net.py # 车牌检测网络
| - r_net.py # 号码识别网络
| - c_net.py # 颜色识别网络
| - utils.py # 辅助模块
| - weights # 预训练权重目录
| - d-net-c.pt # d_net权重
| - r-net-c.pt # r_net权重
| - c-net-c.pt # c_net权重
| - samples # 测试图片目录
| - test-1.jpg
| - ....
| - serve.py # Web UI及API服务
| - api_test.py # Web API调用示例代码
| - requirements.txt # 依赖声明文件
在第一次使用之前,首先安装依赖文件:
pip install -r requirements.txt
执行如下命令启动Web UI:
python serve.py
然后使用浏览器访问 http://127.0.0.1:7860
,即可打开Web UI。
在Web UI中打开一个图像文件,然后点击[Submit]按钮,就可以进行识别,如下图所示:
右侧的输出图像上叠加了检测到的车牌信息,输出结果为一个数组,每个成员包含如下字段:
下图是检测新能源车牌的示例:
下图是检测黄牌的示例:
api_name: /predict
输入参数:
img_in
:输入图像输出结果:
bbox
| label
| color
Python调用示例如下:
from gradio_client import Client, handle_file
client = Client("http://127.0.0.1:7860/")
result = client.predict(
img_in=handle_file('./samples/test-1.jpg'),
api_name="/predict" )
print(result)
执行结果如下:
Web API特别适合将车牌识别能力集成到Java、C#、Javascript等其他语言开发的应用中。
除了Web API,XLPR SDK也提供了Python原生API。
XLpr
是SDK的入口类,使用其predict()
方法对传入的图片进行处理,并返回叠加
结果的图片和检测结果数据。
XLpr
实例的predict()
调用示例代码如下:
from core.xlpr import XLpr
import cv2
xlpr = XLpr()
img_in = cv2.imread('samples/test-1.jpg')
img_out, results = xlpr.predict(img_in)
DetectionNet
是D-NET
的实现类,使用其predict()
方法对传入的图片进行处理,并
返回车牌包围框集合。
DetectionNet
实例的predict()
方法调用示例代码如下:
from core.d_net import DetectionNet
import cv2
d_net = DetectionNet()
img_list = [ cv2.imread('samples/test-1.jpg') ]
bbxs_list = d_net.predict(img_list)
RecognitionNet
是R-NET
的实现类,使用其predict_image_patches()
方法对指定的
图片的多个区域进行号码识别。例如:
from core.d_net import DetectionNet
from core.r_net import RecognitionNet
import cv2
d_net = DetectionNet()
r_net = RecognitionNet()
img_list = [ cv2.imread('samples/test-1.jpg') ]
bbxs_list = d_net.predict(img_list)
img, bbxs = img_list[0], bbxs_list[0]
labels = r_net.predict_image_patches(img, bbxs)
ColorNet
是C-NET
的实现类,使用其predict_image_patches()
方法对指定的图片的多个
区域进行颜色识别。例如:
from core.d_net import DetectionNet
from core.c_net import ColorNet
import cv2
d_net = DetectionNet()
c_net = ColorNet()
img_list = [ cv2.imread('samples/test-1.jpg') ]
bbxs_list = d_net.predict(img_list)
img, bbxs = img_list[0], bbxs_list[0]
colors = c_net.predict_image_patches(img, bbxs)
本站所提供软件包仅用于学习和研究,请依法合规使用。
本站所提供软件包均提供完整源码,使用前请认真阅读源代码和文档以确保充分理解软件包的设计与功能实现,本站不承担 因不当使用本站所提供软件包而造成的任何法律风险或财产损失责任。