车牌识别:HALCON智能检测全解析

bash 复制代码
dev_close_window()

**读取图片

bash 复制代码
read_image (Car2025, 'D:/ltg/Pictures/Images/car/CarSample.png')
dev_open_window(0, 0, -1, -1, 'black', WindowHandle)
dev_display(Car2025)

**转灰度图

bash 复制代码
rgb1_to_gray(Car2025, GrayImage)

**二值化处理(可用灰度直方图筛选)

bash 复制代码
threshold (GrayImage, Regions, 7, 99)

**连通(阻断分区域)打断

bash 复制代码
connection(Regions, ConnectedRegions)
复制代码
**形态学处理 相关算子[本例图像清晰未用到]
*操作	HALCON算子	典型作用	常使用场景
*-----------------------------------------------------------------------
*膨胀	dilation_circle	扩大区域,连接断裂部分	连接分散目标、裂缝填补、目标区域扩展
*腐蚀	erosion_circle	消除噪声,分离目标区域	背景噪声去除、目标分离、形态边界缩小
*开运算	opening_circle	去除噪声,平滑边界	去除细小杂质、优化形状、改善识别结果
*闭运算	closing_circle	填充孔洞,平滑边界	修复孔洞、封闭边界、填补不规则缺陷

**可用特征直方图筛选目标区域(以面积为主[配合特征检测工具])

bash 复制代码
select_shape(ConnectedRegions, SelectedRegions, 'area', 'and', 15000, 18000)

***处理图片-转正图片

**生成一个仿射矩阵

bash 复制代码
shape_trans(SelectedRegions, RegionTrans, 'rectangle2')

**得到仿射矩阵的中心点坐标

bash 复制代码
area_center(RegionTrans, Area, Row, Column)

**得到仿射矩阵的斜率Phi

bash 复制代码
orientation_region(RegionTrans, Phi)

**判断斜率Phi正负,扶正图形

bash 复制代码
if (Phi>=0)
    Angle:=0
else
    Angle:=180
endif

**生成一个仿射矩阵

bash 复制代码
vector_angle_to_rigid(Row, Column, Phi, Row, Column, rad(Angle), HomMat2D)

**若车牌图片文字倾斜,则可以纠正(将 "Phi" 参数更改为角度参数 "rad(?)")

bash 复制代码
hom_mat2d_slant(HomMat2D, Phi, 'x', Column, Row, HomMat2DSlant)

**仿射矩阵转正(ROI区域)

bash 复制代码
affine_trans_region(RegionTrans, RegionAffineTrans, HomMat2D, 'nearest_neighbor')

**对原图进行转正

bash 复制代码
affine_trans_image(Car2025, ImageAffineTrans, HomMat2D, 'constant', 'false')

**车牌区域扣图

bash 复制代码
reduce_domain(ImageAffineTrans, RegionAffineTrans, ImageReduced)

****开始识别车牌

**灰度化

bash 复制代码
rgb1_to_gray(ImageReduced, GrayImage1)

**反转图像,由'黑底白字'图像转为'白底黑字'图像[重要,字符识别依据]

bash 复制代码
invert_image(GrayImage1, ImageInvert)

**二值化[作用:生成红色目标区域]

bash 复制代码
threshold (GrayImage1, Regions1, 114, 188)

**开运算,去掉外框

bash 复制代码
opening_rectangle1(Regions1, RegionOpening, 3, 5)

**打断/分割整张图形为单个区域

bash 复制代码
connection(RegionOpening, ConnectedRegions1)

**选择ROI区域(多依面积为主,设置在每个字符占的面积最小区域和最大区域为一区间)

bash 复制代码
select_shape(ConnectedRegions1, SelectedRegions1, 'area', 'and', 600, 800)

**对ROI区域按列排序

bash 复制代码
sort_region(SelectedRegions1, SortedRegions, 'character', 'true', 'column')

**读取训练好的字符库

bash 复制代码
read_ocr_class_mlp('D:/Program Files/MVTec/HALCON-22.11-Steady/ocr/CNLicense_Plate_mlp.omc', OCRHandle)

**按字符库对比识别"对应/归类"相应字符,形成字符串数组Class

bash 复制代码
do_ocr_multi_class_mlp(SortedRegions, ImageInvert, OCRHandle, Class, Confidence)

***显示对应字符到屏幕上

bash 复制代码
dev_display(ImageAffineTrans)

**设置显示字体

bash 复制代码
set_display_font(WindowHandle, 30, 'mono', 'true', 'false')

**统计显示的字符数

bash 复制代码
count_obj(SortedRegions, Number)

**依次显示读取的字符

bash 复制代码
for Index:=1 to Number by 1
    select_obj(SortedRegions, ObjectSelected, Index)
    area_center(ObjectSelected,Area1, Row1, Column1)
    dev_disp_text(Class[Index-1],'window', Row1, Column1, 'black', [], [])
endfor
write_string(WindowHandle, Class)
disp_message(WindowHandle, Class, 'image', Row1, Column1, 'blue', 'true')
相关推荐
小超同学你好2 分钟前
Langgraph 18. Skill 四种形态 —— Inline / File-based / External / Meta(含代码示例)
人工智能·语言模型·langchain
不只会拍照的程序猿2 分钟前
《嵌入式AI筑基笔记02:Python数据类型01,从C的“硬核”到Python的“包容”》
人工智能·笔记·python
uzong3 分钟前
Skill 被广泛应用,到底什么是 Skill,今天详细介绍一下
人工智能·后端·面试
Jokeny7 分钟前
OpenClaw本地"养虾"全攻略:数据真·不出电脑,本地大模型+飞书自动化方案
人工智能
reesn7 分钟前
copaw梳理
人工智能
算法玩不起7 分钟前
以乳腺癌诊断数据为例的医学AI分类建模方法入门
人工智能·分类·数据挖掘
Jay_Franklin10 分钟前
Quarto与Python集成使用
开发语言·python·markdown
Tadas-Gao23 分钟前
Mem0分层记忆系统:大语言模型长期记忆的架构革命与实现范式
人工智能·语言模型·自然语言处理·架构·大模型·llm·transformer
极客小俊28 分钟前
Windows 卸载 OpenClaw
人工智能
吴佳浩 Alben30 分钟前
GPU 生产环境实践:硬件拓扑、显存管理与完整运维体系
运维·人工智能·pytorch·语言模型·transformer·vllm