当前位置: 首页 > news >正文

闲庭信步使用图像验证平台加速FPGA的开发:第三十课——车牌识别的FPGA实现(2)实现车牌定位

    (本系列只需要modelsim即可完成数字图像的处理,每个工程都搭建了全自动化的仿真环境,只需要双击top_tb.bat文件就可以完成整个的仿真,大大降低了初学者的门槛!!!!如需要该系列的工程文件请关注知识星球:成工fpga,https://t.zsxq.com/DMeqH,关注即送200GB学习资料,链接已置顶!)

上篇我们轻松实现了车牌定位的预处理,得到的最终预处理图片如下所示。注意一下,本工程是要求测试的图片要尽可能是正的,不要斜,如果是斜的图片,实际处理的过程中要先进行各种校正,至于如何校正不是本文的重点。

得到如上预处理的图片,如何进行车牌边界的定位呢?其实很明显,车牌的边界应该都是连续和相对连续的横线或者竖线,所以我们分别对每行或者每列的图像值为1的点进行求和存储,最后再对前后行存储的数据和进行比较,变化大于设定阈值的行或者列就是车牌的边缘。

在\src\plate_location文件夹下新建horizontal_location.sv文件,完成车牌上下边界的定位。首先完成每行图像数据值的叠加(不是0就是1,就是一行所有像素点求和),并保存到数组ram中。

在图片的最后一行,将前面每行求和的数据从数组ram中一一读出来。

用ud_edge_flag信号来标示上下边界,ud_edge_flag==0时,ram前后两行数据的变化大于阈值THRESHOLD,那就是上边界(反映在图片上是下边界,应用bmp图像是从下往上);如果ud_edge_flag==1,ram前后两行数据的变化大于阈值THRESHOLD,那就是下边界。

最后对上下边界进行适当的调整,这个根据实际情况来,一般边界也不是1行,调整是为了在边界线的中间位置。

完成上下边界的定位,那就开始左右边界的定位,在\src\plate_location文件夹下新建vertical_location.sv文件,思路和求上下边界基本一致。首先将每列的数据分别相加后存放人数组ram中。

在图片的最后一行,将前面每=列求和的数据从数组ram中一一读出来。这儿为了解决图片稍微倾斜的问题,取相邻的五列ram数据进行叠加。

用lr_edge_flag信号来标示左右边界,lr_edge_flag==0时,ram前后多列数据的变化大于阈值THRESHOLD,那就是左边界;如果lr_edge_flag==1,ram前后多列数据的变化大于阈值THRESHOLD,那就是右边界。

最后对左右边界进行适当的调整,这个也是根据实际情况来。

完成车牌上下左右边界的初步定位,还需要进一步的调整,在\src\plate_location文件夹下新建plate_boarder_adjust.sv模块,主要完成车牌比例调整,检测边界是否有效等功能,并将车牌定位的区域缩到字符的区域,这个模块成工基本没有进行太大的改动。

在\src\plate_location文件夹下新建plate_location模块,完成目前所有模块的集成,如下所示。

完成车牌和字符边界的定位,我们要把定位的信息反应在图片上,也就是在图片上将车牌的位置标出来,看看对不对,在\src\plate_location文件夹新建location_out.sv模块,用来将车牌定位和字符定位的信息反应到原图片上,也就是进行叠加。思路也是非常的简单,找到要画线的区域,用固定的颜色标出来即可。

在下一个initial块中,完成两帧图片的保存。

打开img下的output文件夹,可以看到车牌边界的定位和字符区域的定位。

http://www.dtcms.com/a/293470.html

相关文章:

  • XCKU035‑1SFVA784C Xilinx FPGA KintexUltraScale AMD
  • C# 类 封装 属性 练习题
  • 深度学习 --- 激活函数
  • 计算机底层入门 05 汇编学习环境通用寄存器内存
  • MDC(Mapped Diagnostic Context) 的核心介绍与使用教程
  • LINUX 722 逻辑卷快照
  • (Arxiv-2025)HiDream-I1:一种高效图像生成基础模型,采用稀疏扩散Transformer
  • 在PyCharm中复现LaneNet车道线检测模型
  • JavaScript 01 JavaScript 是什么
  • 医疗系统伪代码
  • Ctenos7最小化安装 可以ping通
  • MySQL InnoDB存储引擎深度解析:从原理到优化
  • 【JavaSE】JDBC和连接池学习笔记
  • k8s:利用helm离线部署consul v1.21.2
  • 【Altium Designer2025】电子设计自动化(EDA)软件——Altium Designer25版保姆级下载安装详细图文教程(附安装包)
  • @PostConstruct 注解
  • Python进阶第三方库之Numpy
  • Docker-compose:服务编排
  • M3088NL是一款网络滤波器/变压器支持100M和1000M网络环境,适用于高速网络传输场景M3088
  • 单片机的几种GPIO输入输出模型详解
  • JavaWeb学习打卡11(cookie(甜点)详解)
  • iView Table组件二次封装
  • RAG实战指南 Day 21:检索前处理与查询重写技术
  • 数据库隔离级别
  • SQL语句中锁的使用与优化
  • 正则表达式:文本处理的强大工具
  • 傲软录屏 专业高清录屏软件 ApowerREC Pro 下载与保姆级安装教程!!
  • 3.5 模块化编程实践
  • 路径平滑优化算法--Polynomial Spiral(多项式螺旋法)
  • JavaScript 02 数据类型和运算符数组对象