基于openCV的车牌识别(模板匹配)python版

article/2025/5/7 12:53:11

利用提供的模板进行车牌识别:
模板:在这里插入图片描述
测试数据:
在这里插入图片描述
整体思路分为3个步骤:①将图像中车牌位置截取出来;②将车牌安照字符进行分割;③对分割好的字符图像进行模板匹配。实验基于jupyter进行,具体代码见附件。
第一步:截取车牌图像
一开始使用颜色特征进行,因为前几个图片整体构图都比较简单,颜色较为单一,特别是前两个,车牌部分较亮,其余部分较暗,不管使用颜色直方图或者直接二值化处理都可以提取出车牌部分。但是对于“4.jpg”,以及附加题中的绿牌车,这种方法提取效果欠佳,因此考虑使用sobel算子进行轮廓检测。
具体步骤如下:
先对图像进行高斯去噪,而后转为灰度图,因为车牌号码在y方向轮廓更为明显,所以对y方向进行轮廓检测:
在这里插入图片描述
用自适应阈值对图像进行二值化处理:
在这里插入图片描述
用因为所给图像都较小,所以连续使用两次中值滤波对图像进行平滑处理:
在这里插入图片描述
然后进行闭运算,使图像连为一块:
在这里插入图片描述
获取轮廓最小包围矩形:
在这里插入图片描述
然后用该矩形框坐标对原图进行裁剪,得到车牌图片:
在这里插入图片描述
图中可以看到裁剪得到的图片四周存在噪点,所以需要对车牌进行进一步的处理。思路为,将得到的图片二值化:
在这里插入图片描述
先对上下边框进行处理计算每一行的黑色像素的个数,并显示成直方图:
在这里插入图片描述
显然,靠近边缘部分存在波谷,但没有值为0的地方,这是因为左边还有黑色像素干扰。另外,有时候还存在着上下接边的情况。但是因为车牌的字符部分,即中间部分(扣除边框以外的地方)必然是存在着连续的大量的黑色像素,所以对车牌垂直方向进行划分,由中间向两边遍历,并设定一个阈值,当低于这个阈值的时候,判定已经超出车牌字符部分。经多次尝试,阈值选取为平均像素的四分之一能够得到较好的判定结果。而后利用获取的两个波谷坐标对车牌进行切割:在这里插入图片描述
同样,按列计算黑色像素个数,得到直方图:
在这里插入图片描述
显然,每个黑色像素点为0的区域,都是字符间隙,这可以作为后续字符分割的依据。但当前木匾为切除左右多余部分,因此采取办法是由两边向中间遍历,如果出现第一个0的值,那么查看该点左侧(如果是右边开始遍历的话就是查看其右侧)黑色像素的宽度是否大于某个阈值,如果没有大于该阈值,则判定其属于空白部分或者边框部分,原理是前期处理出来的图像边框通常都很细,该阈值经实验后设定为4,能够得到较好结果。而后用获取到的两端的波谷坐标对图像进行左右边框切除:
在这里插入图片描述
查看在原图中的裁剪效果:
在这里插入图片描述
检查该方法对其他9张图片的提取效果:
在这里插入图片描述
验证该算法均能有效提取出车牌字符部分。
对补充题进行实验,得到效果如下:
在这里插入图片描述
可见,采用此种办法,对车牌相对图片较小的目标、存在光线干扰的目标都有较好的提取效果,但是对于倾斜的目标,由于采取办法是轮廓最小矩形提取,所以无法有较好效果,因此考虑对车牌图片加入角度检测。
角度检测办法采用线性拟合的方式,由于检测到的车牌轮廓是由许多点组成的,那么可以近似认为这些点的拟合直线的斜率就是车牌的倾斜角:
在这里插入图片描述
由于轮廓点选取存在差异,因此拟合直线的斜率和实际车牌角度并不是完全相符,因此选取一个阈值作为检测范围,对拟合直线的斜率求绝对值,若值大于该阈值,判定该车牌为倾斜,进而对原图片进行旋转操作后再次重复车牌检测的步骤,即可裁剪得到需要的车牌图片,否则直接输出裁剪得到的车牌图片:
在这里插入图片描述
在这里插入图片描述
第二步、第三步:对字符进行分割并识别
已知第一步提取得到的车牌分两种类型,分为电动车车牌和油车车牌,可以通过对长宽比的筛选区分两种车牌,而后根据两种车牌的国标尺寸进行字符分割。
具体方法为将所有提取到的车牌图片先resize至统一尺寸,经实验,我选择油车车牌尺寸为:(140,32),新能源车车牌尺寸为:(155,32)。而后利用其字符占宽相同的特征,直接使用字宽尺寸进行切割。
模板匹配采取openCV中的matchTemplate方法进行,匹配算法使用cv2.TM_CCOEFF_NORMED(归一化相关系数匹配法)。
在对提取到的车牌进行模板匹配前,为提高匹配准确率,事先对模板图片进行预处理,具体过程为将模板二值化,并且resize至19×32的大小(与待匹配图片大小相同):

在这里插入图片描述
观察发现“7”存在噪点,手动去除:
在这里插入图片描述
得到两种车牌的切割识别效果如下(准确率仅计算数字部分):
在这里插入图片描述
在这里插入图片描述
由表格可知,字符分割效果比较良好,分割得到的字符基本都处于图片的正中间,无缺损,包括3个补充题的车牌,均得到有效处理。
字符识别,即模板匹配部分,平均识别精度为85.38%。对于黄色车牌,识别精度为95.45%。问题最大的是蓝色车牌,由于蓝色车牌的数字部分为白色,直接使用cv2.TM_CCOEFF_NORMED,会导致判别时将蓝底部分作为数字旁别,后续考虑二值化后通过计算黑色像素个数来判定是否为蓝色车牌,若为蓝色车牌,则颜色取反。绿色车牌识别精度较低的原因在于其字符所使用的字体与模板不同,导致模板无法较好匹配。

特征设计

将前期分割好的图片进行二值化处理,并对模板图片进行二值化处理。由于分割的图片大小和模板大小一致,所以可以考虑两种特征比较得方法
①将两个图片对应点的像素相减(白减黑),若相同,则计数器加一,最终得到一个累计值。将10个数字模板依次与待匹配图片进行相同操作,对比10个模板的累计值大小,值最大的,认为匹配度最高,对应得那个数则为识别结果;
②分别累计模板图片和待匹配图片得黑色像素个数,而后将两个图片得黑色像素个数相减,绝对值最小的,则认为匹配度最高。
匹配情况见下图(第一行方法①识别的结果,第二行为方法②识别的结果):
在这里插入图片描述
在这里插入图片描述
由表可知,方法①的平均准确率为84.36%,略低于归一化相关系数匹配法,其中对蓝色车牌识别精度为66.67%,优于归一化相关系数匹配法,方法②的平均准确率为30%,时三种方法中精度最低的。原因在于方法②容易受到噪点干扰。

具体代码见链接:基于openCV的车牌识别(模板匹配)python版


http://chatgpt.dhexx.cn/article/gmnRC20u.shtml

相关文章

OpenCV-顶帽运算(TOPHAT)

作者:翟天保Steven 版权声明:著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处 原理 形态学是图像处理中常见的名词,图像处理的形态学基本属于数学形态学的范畴,是一门建立在格论和拓扑…

小白都能学会的python+opencv,带你从人脸识别做到车牌识别,成为别人口中赞叹的高手!

一.第一步,对于小白来说,用什么编辑很难选择,怎么下载免费的编辑器也不会,会用电脑下载的又总是被下载许多附带的垃圾软件,这个问题让我来解决,这里我们首先需要安装两个软件以及配置一个pip豆瓣源&#xf…

基于VS与OpenCV的模板匹配学习(2):边缘匹配+图像金字塔

基于VS与OpenCV的模板匹配学习(2) 边缘模板匹配图像金字塔 基于C与OpenCV的模板匹配学习(1)OpenCV matchTemplate()示例 文章目录 基于VS与OpenCV的模板匹配学习(2)边缘模板匹配图像金字塔前言一、边缘检…

Struts2的基本流程的详细介绍

Struts2的基本流程 10级学员 张帅鹏课堂笔记 概述: Struts2框架由三部分构成:核心控制器、业务控制器和用户实现的业务逻辑组件。在这三部分中,struts2框架提供了核心控制器StrutsPrepareAndExecuteFilter,而用户需要实现业务控…

jQuery插件autoComplete介绍(10级学员 张帅鹏总结)

jQuery插件autoComplete介绍 概述:AutoComplete为自动填充,展示之意。用户在使用文本框搜索信息时,使用插件的autoplete方法绑定文本框。当在文本框中输入某个字符时,通过该方法中的指定的数据URL,返回相匹配的数据&a…

C语言 编写Vector方法

Vector是一个单口进出的数组结构有一点像栈的结构。 首先建立这样一个结构体,里面包含一个数组以及一个位置标记,数组来存放进入的元素,标记指向尾部最后一个没有存放东西的数组位置。当然数组元素可以自定义为任何格式,甚至也可…

多组数据的输入方法(c语言实现)

先说方法之前先来浅聊一下scanf 开始进入正题 1.EOF法 EOF(end of file)就是文件的结束&#xff0c;通常来判断文件的操作是否结束的标志。 EOF不是特殊字符&#xff0c;而是定义在头文件<stdio.h>的常量&#xff0c;等于-1&#xff1b; 就如牛客网上的一道题为例&…

c语言:数组插入处理

规定输入9个元素&#xff0c;排序后&#xff0c;再输入一个数要求按原来排序的规律将它插入数组中。 初始化数组函数&#xff1a; void assign_value_to_array(int val[])//数组赋值 {int star;//数组开始位printf("请输入%d个数&#xff1a;",num);for(star0;star&…

电子测量——用C语言设计测量数据误差处理的通用程序

题目要求 参考例2-2-6的解题过程&#xff0c;用C语言或MATLAB设计测量数据误差处理的通用程序&#xff0c;要求如下&#xff1a; &#xff08;1&#xff09;提供测试数据输入、粗大误差判别准则选择等的人机界面&#xff1b; &#xff08;2&#xff09;编写程序使用说明&#…

c语言区简单数据类型,c语言简单数据类型有哪些

c语言中简单的数据类型分别为&#xff1a;1、整型【int、short、long、long long】&#xff1b;2、浮点型【float&#xff0c;double】&#xff1b;3、字符型【char】。 c语言中简单的数据类型分别为&#xff1a; 1、整(数)型int&#xff1a;基本整数型&#xff0c;用于存储整数…

C语言-基本数据类型

C语言中有3种基本数据类型&#xff0c;分别是整型、字符型和实型&#xff08;浮点型&#xff09;&#xff0c;下表列出的是32位平台数据类型的长度及其取值范围 类别名称类型名数据长度取值范围整型[有符号]整型[signed] int32位-2147483648~2147483647(-2^31 ~ 2^31-1)[有符号…

C语言处理excel

思路来源&#xff1a;https://blog.csdn.net/hongzhen91/article/details/57422897 目录 1 写2 读先看 代码&#xff01;结果分析可知 1 写 .csv 是 excel 后缀&#xff0c;跳跃间隔符是 ‘,’ FILE *fp ;fp fopen("./test.csv","w") ; // 写 for (i0 ;…

C语言基础——数据运算

一 运算基础 运算的本质是根据已有数据&#xff0c;进行各种运算处理&#xff0c;得到新的数据。所以&#xff0c;运算的基础就是数据。在数据的表示方法中&#xff0c;声明的变量只是一个空的指代&#xff0c;并没有和具体的数据进行关联。如果要使用变量&#xff0c;就要把数…

C语言数据溢出

文章目录 int 类型char int 类型 unsigned int num -1;printf("%u", num);解析&#xff1a; 首先在寄存器产生一个负数-1&#xff0c;它在计算机中存储的补码是 32个1&#xff0c;共32个二进制位&#xff0c;当按照赋值号赋给无符号num变量时&#xff0c;符号位变成…

C语言 数据处理

在不使用scanf函数如何对输入的数进行逆序输出呢&#xff1f;首先要得到该数的位数&#xff0c;因为需要在顺序输出里使用。 代码如下: int Getfigure(int n) {int tmp0; //计算循环次数while(n ! 0){n / 10;tmp;}return tmp; //该数的位数 } 其次要清楚该处理…

【Keil 5安装教程】

文章目录 一、安装mdk二、激活mdk三、安装STM32芯片包四、安装C51单片机五、激活C51单片机 一、安装mdk 1、在解压的安装包里&#xff0c;点击运行mdk514.exe文件&#xff1b; 2、在弹出的页面中点击NEXT&#xff1b; 3、打勾I Agree&#xff0c;点击Next&#xff1b; 4、在…

keil3 安装教程

安装前先关闭杀毒软件和360卫士&#xff0c;注意安装路径不能有中文&#xff0c;安装包路径也不要有中文。 1.选中【Keiluvision 3 C51版】压缩包&#xff0c;鼠标右击选择【解压到Keil uvision 3 C51版】。 2.双击打开【Keiluvision 3 C51版】文件夹。 3.选中【KEILc51v802…

keil安装指导

keil arm 5.36下载地址 C51 960a下载地址 注册码 这个自己搜索下载 安装指导 注意&#xff1a; 如果你想C51和ARM一起安装&#xff0c;那就先安装C51再ARM版本的。如果你已经先安装完了ARM的也没关系&#xff0c;安装完C51的再重新安装下ARM的就可以 安装C51 双击你下…

c语言定义函数时形参定义的位置

今天在读Zlib库源码中第三方contrib/minizip文件时&#xff0c;发现一个有意思的东西&#xff1a; 定义函数时&#xff0c;其形参的类型放在函数()后面&#xff0c;()里只放了形参名 虽然这样最终用编译器&#xff08;如gcc等&#xff09;编译时是可以通过的&#xff0c;但是…

C语言函数(函数分类,参数,调用,声名及定义)

文章目录 [TOC](文章目录)一、C语言中函数的分类二、函数的参数及调用三、函数的嵌套调用和链式访问四、函数的声名和定义 一、C语言中函数的分类 库函数自定义函数 库函数&#xff1a;在开发的过程中&#xff0c;每个程序员都可能用得到&#xff0c;为了支持可移植性和提高程…