halcon 多车牌识别

news2024/11/20 19:34:03

文章目录

  • 车牌定位
  • 字符分割
  • 字符识别
  • 多张图片

车牌定位

dev_close_window()
dev_open_window(0,0,512,400,'black',WindowHandle)
list_image_files('C:/Users/Augustine/Desktop/车牌照图片','jpg',[],ImageFiles)
for i:=0 to |ImageFiles|-1 by 1
    read_image(Image, ImageFiles[i])
    *获取三色通道
    decompose3(Image, r, g, b)
    *将三色通道处理为hsv
    trans_from_rgb(r,g,b,h,s,v,'hsv')
    *按照s方式阈值处理
    threshold (s, Regions, 177, 251)
    *膨胀运算
    dilation_rectangle1(Regions, RegionDilation, 1, 3)
    connection(RegionDilation, ConnectedRegions)
    *选择特征
    select_shape (ConnectedRegions, SelectedRegions, 'area', 'and', 6639.49, 9284.42)
    *闭运算,先膨胀在腐蚀
    closing_rectangle1(SelectedRegions,RegionClosing,150, 200)
    *开运算
    opening_rectangle1(RegionClosing,RegionOpening,10,10)
    *获取最小外接矩形
    smallest_rectangle2(RegionOpening,Row,Column,Phi,Length1, Length2)
    *产生最小外界矩形
    gen_rectangle2(Rectangle,Row,Column,Phi,Length1,Length2)
    *获取数量
    count_obj(RegionOpening,Number)
    * 仿射变换
    a:=deg(Phi)
    if(a<-90)
        if(a<=-180)
            a:=180+a
            Phi:=rad(a)
        endif
    endif
    vector_angle_to_rigid(Row, Column, Phi, Row, Column, Phi, HomMat2D)
    affine_trans_region(Rectangle, RegionAffineTrans, HomMat2D, 'nearest_neighbor')
    affine_trans_image(Image, ImageAffineTrans, HomMat2D, 'constant', 'false')
    *裁剪
    reduce_domain(ImageAffineTrans,RegionAffineTrans,ImageReduced)
endfor

在这里插入图片描述

字符分割

  *裁剪
    reduce_domain(ImageAffineTrans,RegionAffineTrans,ImageReduced)
    *做车牌处理,字符分割
    decompose3(ImageReduced,r,g,b)
    *阈值处理
    threshold(r,Region,140, 255)
    *去除噪声
    opening_rectangle1(Region, RegionOpening1, 1,2)
    connection(RegionOpening1, ConnectedRegions1)
    select_shape (ConnectedRegions1, SelectedRegions1, 'area', 'and', 91, 306.9)
    *排序
    sort_region(SelectedRegions1, SortedRegions, 'character', 'true', 'column')

字符识别

 count_obj(SortedRegions,Number)
    if(Number == 6)
        *反转图片
        invert_image(r,ImageInvert)
        *分类识别
        read_ocr_class_mlp('Industrial_0-9A-Z_Rej.omc', OCRHandle)
        do_ocr_multi_class_mlp(SortedRegions, ImageInvert, OCRHandle, Class, Confidence)
        *车牌中没有I,将识别的I改成1
        dev_clear_window()
        dev_display(Image)
        set_display_font(WindowHandle,50, 'mono', 'true', 'false')
        carNumber:=''
        for Index:=1 to |Class|-1 by 1
            data:=Class[Index]
            if(data=='I')
                data:=1
            endif
            carNumber:=carNumber+data
        endfor
    endif
    dev_set_color('red')
    set_tposition(WindowHandle,150,100)
    write_string(WindowHandle,carNumber)

在这里插入图片描述

多张图片

dev_close_window()
dev_open_window(0,0,512,400,'black',WindowHandle)
list_image_files('C:/Users/Augustine/Desktop/车牌照图片','jpg',[],ImageFiles)
for i:=0 to |ImageFiles|-1 by 1
    read_image(Image, ImageFiles[i])
    *获取三色通道
    decompose3(Image, r, g, b)
    *将三色通道处理为hsv
    trans_from_rgb(r,g,b,h,s,v,'hsv')
    *按照s方式阈值处理
    threshold (s, Regions, 177, 251)
    *膨胀运算
    dilation_rectangle1(Regions, RegionDilation, 1, 3)
    connection(RegionDilation, ConnectedRegions)
    *选择特征
    select_shape (ConnectedRegions, SelectedRegions, 'area', 'and', 6639.49, 9284.42)
    *闭运算,先膨胀在腐蚀
    closing_rectangle1(SelectedRegions,RegionClosing,150, 200)
    *开运算
    opening_rectangle1(RegionClosing,RegionOpening,10,10)
     *获取数量
    count_obj(RegionOpening,Number)
    
    if(Number!=1)
        if(Number ==0)
            *换通道定位车牌,处理第二张
            threshold (s, Regions1, 108, 188)
            connection(Regions1, ConnectedRegions2)
            select_shape (ConnectedRegions2, SelectedRegions2, ['column','row','area'], 'and', [145.61,385.75,81.52], [335.57,411.74,10000])
            opening_rectangle1(SelectedRegions2, RegionOpening2, 2, 3)
            connection(RegionOpening2, ConnectedRegions3)
            select_shape (ConnectedRegions3, SelectedRegions3, ['row','column'], 'and', [376.792,145.61], [414.427,380.38])
            closing_circle(SelectedRegions3, RegionClosing1,3)
            closing_rectangle1(RegionClosing1, RegionClosing2, 15, 30)
            connection(RegionClosing2, ConnectedRegions4)
            select_shape (ConnectedRegions4, SelectedRegions4, 'area', 'and', 31.36, 3920.25)
            opening_rectangle1(SelectedRegions4, RegionOpening, 3, 2)
            erosion_circle(RegionOpening, RegionOpening, 1.5)
        endif
    endif
    
    
    *获取最小外接矩形
    smallest_rectangle2(RegionOpening,Row,Column,Phi,Length1, Length2)
    *产生最小外界矩形
    gen_rectangle2(Rectangle,Row,Column,Phi,Length1,Length2)
    * 仿射变换
    a:=deg(Phi)
    if(a<-90)
        if(a<=-180)
            a:=180+a
            Phi:=rad(a)
        endif
    endif
    vector_angle_to_rigid(Row, Column, Phi, Row, Column, Phi, HomMat2D)
    affine_trans_region(Rectangle, RegionAffineTrans, HomMat2D, 'nearest_neighbor')
    affine_trans_image(Image, ImageAffineTrans, HomMat2D, 'constant', 'false')
    *裁剪
    reduce_domain(ImageAffineTrans,RegionAffineTrans,ImageReduced)
    *做车牌处理,字符分割
    decompose3(ImageReduced,r,g,b)
    *阈值处理
    threshold(r,Region,140, 255)
    *去除噪声
    opening_rectangle1(Region, RegionOpening1, 1,2)
    connection(RegionOpening1, ConnectedRegions1)
    select_shape (ConnectedRegions1, SelectedRegions1, 'area', 'and', 91, 306.9)
    *排序
    sort_region(SelectedRegions1, SortedRegions, 'character', 'true', 'column')
    
    count_obj(SortedRegions,Number)
    
    if(Number!=6)
        *第二张图片处理
    endif
    
    
    
    if(Number == 6)
        *反转图片
        invert_image(r,ImageInvert)
        *分类识别
        read_ocr_class_mlp('Industrial_0-9A-Z_Rej.omc', OCRHandle)
        do_ocr_multi_class_mlp(SortedRegions, ImageInvert, OCRHandle, Class, Confidence)
        *车牌中没有I,将识别的I改成1
        dev_clear_window()
        dev_display(Image)
        set_display_font(WindowHandle,50, 'mono', 'true', 'false')
        carNumber:=''
        for Index:=1 to |Class|-1 by 1
            data:=Class[Index]
            if(data=='I')
                data:=1
            endif
            carNumber:=carNumber+data
        endfor
    endif
    dev_set_color('red')
    set_tposition(WindowHandle,150,100)
    write_string(WindowHandle,carNumber)
endfor

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1124126.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

GoLong的学习之路(一)语法之变量与常量

目录 GoLang变量批量声明变量的初始化类型推导短变量声明匿名变量 常量iota&#xff08;特殊&#xff09;&#xff08;需要重点记忆&#xff09; GoLang go的诞生为了解决在21世纪多核和网络化环境越来越复杂的变成问题而发明的Go语言。 go语言是从Ken Thomepson发明的B语言和…

RPA对财务报表的影响

在企业的财务管理中&#xff0c;财务报表分析能够帮助管理人员及时掌握企业的生产经营状况与财务状况&#xff0c;并为管理人员的科学决策提供财务数据支撑&#xff0c;规避企业经营风险。然而&#xff0c;传统的财务报表准备过程通常是繁琐、耗时和容易出错的&#xff0c;RPA技…

如何给R128在FreeRTOS下配置/data目录

在调试音频、usb等模块时&#xff0c;会发现SDK的根目录下没有/data该目录&#xff0c;导致无法存储所需要的文件&#xff0c;这就是因为/data目录没有配置好的原因。 1、选上配置 首先需要选上的配置&#xff1a; 运行mrtos_menuconfig&#xff0c;选上COMPONENT_LITTLEFS …

IDC报告:腾讯云领跑工业云市场,装备制造领域位列行业第一

10月23日&#xff0c;全球领先的IT市场研究和咨询公司IDC发布了《中国工业云IaaSPaaS市场份额&#xff0c;2022&#xff1a;分化初现》报告&#xff0c;腾讯云凭借领先的技术优势和助力实体经济数字化转型成果&#xff0c;成为头部厂商中增速最快的云计算厂商。在装备制造领域&…

服务器数据恢复-raid0硬盘故障导致服务器崩溃的数据恢复案例

服务器故障&分析&#xff1a; 某公司一台服务器&#xff0c;共2块磁盘组建了一组raid0磁盘阵列。RAID0阵列中有1块硬盘出现故障离线&#xff0c;导致服务器崩溃。 通过和用户方的沟通&#xff0c;北亚企安数据恢复工程师初步判断&#xff1a;故障服务器中出现故障离线的硬盘…

为什么学完了 C#觉得自己什么都干不了?

为什么学完了 C#觉得自己什么都干不了&#xff1f; 俺一向的观点&#xff1a;&#xff08;1&#xff09;学跟干是两码事。学&#xff0c;你要往外掏钱或时间或两个都得掏。干&#xff0c;是你从别人兜里掏钱。&#xff08;2&#xff09;如果没有干的需求&#xff0c;那么可以啥…

软件外包开发迭代管理工具

软件迭代的管理工具有助于团队有效地规划、跟踪和管理迭代开发过程&#xff0c;确保项目按时交付&#xff0c;并与团队成员之间进行协作。以下是一些常用的软件迭代管理工具&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#…

【触想智能】工控一体机与5G物联网技术结合是未来发展趋势

工控一体机也叫工业电脑一体机&#xff0c;是工业应用非常重要的一种产品。目前&#xff0c;工控一体机在工业领域的应用已经非常普及&#xff0c;在繁忙的生产车间、数字化机床、自助服务终端设备等场景中&#xff0c;我们都有看到它的身影。 工控一体机应用的普及已经潜移默化…

Java程序设计2023-第四次上机练习

8-1三子棋 编写程序&#xff0c;实现简单的三子棋游戏。在三子棋中&#xff0c;双方在33的棋盘中轮流下棋&#xff0c;一方用*示&#xff0c;另一方用O表示。如果一方的3个棋子占据了同一行&#xff0c;同一列或者对角线&#xff0c;则该方获胜。如果棋盘已被棋子占满&#xf…

LLM实战(二)| 使用ChatGPT API提取文本topic

在大模型前时代&#xff0c;构建机器学习模型通常需要标注数据&#xff0c;然后使用这些标注数据来训练机器学习模型&#xff0c;这个过程一般需要几个月的时间&#xff0c;然而&#xff0c;在大模型时代下&#xff0c;几个小时就可以完成&#xff0c;比如情感分类&#xff0c;…

Windows环境如何使用Zblog+cpoalr搭建个人网站并远程访问?

文章目录 1. 前言2. Z-blog网站搭建2.1 XAMPP环境设置2.2 Z-blog安装2.3 Z-blog网页测试2.4 Cpolar安装和注册 3. 本地网页发布3.1. Cpolar云端设置3.2 Cpolar本地设置 4. 公网访问测试5. 结语 1. 前言 想要成为一个合格的技术宅或程序员&#xff0c;自己搭建网站制作网页是绕…

sql server 生成连续日期和数字

在sqlserver里&#xff0c;可以利用系统表master..spt_values里面存储的连续数字0到2047&#xff0c;结合dateadd&#xff08;&#xff09;函数生成连续的日期 select convert (varchar(10),dateadd(d, number, getdate()),23) as workday from master..spt_values where type…

深入篇【Linux】学习必备:进程环境变量/进程切换

深入篇【Linux】学习必备&#xff1a;进程环境变量/进程切换 Ⅰ.环境变量Ⅱ.深层意义Ⅲ.全局属性Ⅳ.进程切换 Ⅰ.环境变量 1.环境变量是什么&#xff1f;&#xff1a;环境变量是系统提供的一组name/value形式的变量&#xff0c;不同的环境变量有不同的用户。 一般是用来指定操作…

【QT开发笔记-基础篇】| 第四章 事件QEvent | 4.9 右键菜单事件

本节对应的视频讲解&#xff1a;B_站_链_接 【QT开发笔记-基础篇】 第4章 事件 4.9 右键菜单事件 本章要实现的整体效果如下&#xff1a; QEvent::ContextMenu ​ 在窗口/控件上点击鼠标右键时&#xff0c;触发该事件&#xff0c;它对应的子类是 QContextMenuEvent 首先&…

无人值守变电站运维技术模式及应用-安科瑞黄安南

近年来&#xff0c;市场电子资源需求量的逐步上升&#xff0c;使变电系统建设逐步向复杂环境拓展。为保障变电系统运行稳定性及人员管理安全性&#xff0c;无人值班变电站技术运用势在必行&#xff0c;是解决复杂条件下变电设备运行不稳定及人员设备管理效益低下问题的重要核心…

打工人神器(随时会删,抓紧看)

今天是一期打工人神器&#xff0c;相信大家在工作上多多少少都遇到过一些这样的难题&#xff0c;比如找不到素材&#xff1f;写不出文案&#xff1f;等等之类&#xff0c;如果你遇到过以上这些情况&#xff0c;那么今天的干货分享一定要看完&#xff01; 一、犀牛视频下载器 视…

k8s-----10、Controller-Deployment

Controller-Deployment 1、什么是controller2、 pod和controller关系3、Deployment控制器应用场景3.1 部署时yaml文件书写3.2 实际部署应用3.3 升级回滚3.3.1 升级3.3.2 回滚 3.4 弹性伸缩 1、什么是controller 在集群上管理和运行容器的对象 2、 pod和controller关系 pod是…

怎么用一个二维码展示多个内容?二维码汇总一个的方法

怎么将多个二维码内容组合到一个二维码中呢&#xff1f;最近有些小伙伴在问&#xff0c;在让别人扫码展示内容时&#xff0c;如何将其他二维码内容做成列表的形式&#xff0c;被浏览信息的人选择点击跳转到其他二维码展示对应的内容。比如制作旅游景点攻略&#xff0c;点击对应…

Python基础教程:列表(List)的常用操作

嗨喽~大家好呀&#xff0c;这里是魔王呐 ❤ ~! python更多源码/资料/解答/教程等 点击此处跳转文末名片免费获取 列表是Python中最基本的数据结构&#xff0c;列表是最常用的Python数据类型&#xff0c;列表的数据项不需要具有相同的类型。 列表中的每个元素都分配一个数字 -…

java--赋值运算符

1.基本赋值运算符 1.1.就是“”&#xff0c;从右边往左看。 2.扩展赋值运算符 注意&#xff1a;扩展的赋值运算符隐含了强制类型转换。 byte x 10; byte y 20; x x y ;//这样写会报错 x y;/*这样不会报错&#xff0c;原因是java默认的都是int形式的 &#xff0c;然后上面…