Python基于Opencv和SVM机器学习算法和百度AI平台车牌识别系统设计毕业源码案例设计

开发软件:Pycharm+Python3.6  数据库:mysql
 
## opencv车牌识别原理简介
* 车牌字符识别使用的算法是opencv的SVM
* opencv的SVM使用代码来自于opencv附带的sample,StatModel类和SVM类都是sample中的代码
* 训练数据文件`svm.dat`和`svmchinese.dat`
* 使用`图像边缘`和`车牌颜色`定位车牌,再识别`字符`
* 两种方法都无法识别时调用百度api(有手动按钮)

### 一. 车牌图像预处理
* 1.将彩色图像转化为灰度图
* 2.采用20*20模版对图像进行高斯模糊来缓解由照相机或其他环境噪声(如果不这么做,我们会得到很多垂直边缘,导致错误检测。)
* 3.使用Otsu自适应阈值算法获得图像二值化的阈值,并由此得到一副二值化图片 
* 4.采用闭操作,去除每个垂直边缘线之间的空白空格,并连接所有包含 大量边缘的区域(这步过后,我们将有许多包含车牌的候选区域) 
* 5.由于大多数区域并不包含车牌,我们使用轮廓外接矩形的纵横比和区域面积,对这些区域进行区分。
    * a.首先使用findContours找到外部轮廓
    * b.使用minAreaRect获得这些轮廓的最小外接矩形,存储在vector向量中
    * c.使用面积和长宽比阈值,作基本的验证


### 二. 车牌图像定位
  车牌定位的主要工作是从摄入的汽车图像中找到汽车牌照所在位置,并把车牌从该区域中准确地分割出来,供字符分割使用。
因此,牌照区域的确定是影响系统性能的重要因素之一,牌照的定位与否直接影响到字符分割和字符识别的准确率。
目前车牌定位的方法很多,但总的来说可以分为以下4类:

* (1)基于颜色的分割方法,这种方法主要利用颜色空间的信息,实现车牌分割,包括彩色边缘算法、颜色距离和相似度算法等; 
* (2)基于纹理的分割方法,这种方法主要利用车牌区域水平方向的纹理特征进行分割,包括小波纹理、水平梯度差分纹理等; 
* (3)基于边缘检测的分割方法; 
* (4)基于数学形态法的分割方法。  

为了代码实现上的方便,我采用的是基于边缘检测的分割方法和基于颜色的分割方法。

* 车牌中有大量的垂直边缘,这个特征可以定位车牌。
* 根据阈值找到对应颜色来定位车牌。

### 三. 车牌图像矩形矫正

因为摄像头和车辆车牌之间的角度有不同的变化, 一般所拍摄的车牌图像都不是理想状态下的矩形, 如果这样将会给后面的字符分割带来不利的影响, 增加了字符分割的难度, 更增加了后续的字符识别的困难, 造成识别率下降。因此, 在字符分割之前, 我们需要进行对倾斜的矩形车牌进行校正。

### 四. 车牌图像字符分割

要识别车牌字符,前提是先进行车牌字符的正确分割与提取。字符分割的任务是把多列或多行字符图像中的每个字符从整个图像中切割出来成为单个字符。车牌字符的正确分割对字符的识别是很关键的。传统的字符分割算法可以归纳为以下三类:直接分割法、基于识别基础上的分割法、自适应分割线类聚法。直接分割法简单,但它的局限是分割点的确定需要较高的准确性;基于识别基础上的分割法是把识别和分割结合起来,但是需要识别的高准确性,它根据分类和识别的耦合程度又有不同的划分;自适应分割线聚类法是要建立一个分类器,用它来判断图像的每一列是否是分割线,它是根据训练样本来进行自适应学习的神经网络分类器,但对于粘连字符训练困难。也有直接把字符组成的单词当作一个整体来识别的,诸如运用马尔科夫数学模型等方法进行处理,这些算法主要应用于印刷体文本识别。

### 五. 车牌图像字符识别

* 去除固定车牌的铆钉
* 对字符分割的图块使用训练好的svm模型进行识别
* 判断最后一个数是否是车牌边缘,假设车牌边缘被认为是1,1太细,认为是边缘

  • 11
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
车牌识别系统是一种基于深度学习和opencv的应用程序,通过对车辆图片或视频中的车牌进行识别。下面是一个简单的车牌识别系统码实现: ```python import cv2 import numpy as np import tensorflow as tf # 加载预训练的深度学习模型 model = tf.keras.models.load_model('path/to/pretrained/model.h5') # 加载车牌检测器 plate_cascade = cv2.CascadeClassifier('path/to/haarcascade_plate.xml') # 车牌字符集 char_set = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'J', 'K', 'L', 'M', 'N', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'] # 读取车牌图片 image = cv2.imread('path/to/image.jpg') # 转为灰度图像 gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) # 检测车牌 plates = plate_cascade.detectMultiScale(gray, 1.1, 4) # 遍历每个检测到的车牌 for (x, y, w, h) in plates: # 提取车牌图像 plate_image = image[y:y + h, x:x + w] # 调整尺寸为模型输入尺寸 resized_image = cv2.resize(plate_image, (80, 80)) # 转为灰度图像 grayscale_image = cv2.cvtColor(resized_image, cv2.COLOR_BGR2GRAY) # 归一化 normalized_image = grayscale_image / 255. # 添加批次维度 batched_image = np.expand_dims(normalized_image, axis=0) # 使用深度学习模型进行预测 predictions = model.predict(batched_image) # 解码预测结果 decoded_predictions = [char_set[np.argmax(p)] for p in predictions] # 输出车牌识别结果 license_plate = ''.join(decoded_predictions) print("识别结果:", license_plate) # 绘制车牌框 cv2.rectangle(image, (x, y), (x + w, y + h), (0, 255, 0), 2) # 标注车牌字符 cv2.putText(image, license_plate, (x, y), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 255, 0), 2) # 显示结果图像 cv2.imshow('License Plate Detection', image) cv2.waitKey(0) cv2.destroyAllWindows() ``` 以上是一个简单的车牌识别系统码示例,其中使用了训练好的深度学习模型对车牌进行识别,同时利用Haar特征的级联分类器对车牌进行检测。最终在图像上显示了检测到的车牌以及识别结果。请注意,这只是一个简单的示例,实际的车牌识别系统会更加复杂,需要根据具体需求进行进一步的优化和改进。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

软硬件源码设计案例

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值