0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

应用的编程环境HALCON18.05

新机器视觉 来源:MrCode 作者:MrCode 2021-04-18 10:31 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

最近特无聊是吧,那在家学点做点科技类的小事业吧。

应用的编程环境HALCON18.05,这里讲一种常用套路

*表示程序注释

1.采图或者自己写下字母和数字,分成训练与识别两个部分;

2.阈值分割出字符;

3.创建手写体识别器;

4.训练该识别器;

5.执行识别;

具体过程如下:

**--------------------------------------

*(1) Training of the OCR ofhandwrite letter

* 关闭更新

dev_update_off()

* Set theimage path (make sure, that you have set HALCONIMAGES to the HALCON imagedirectory)

*

* Step 0:Preparations 文件路径

FontName:= 'E:/Halcon/OCR/handwirteC/'

*

* Step 1:Segmentation 读图与字符分割

dev_update_window('off')

dev_get_window(WindowHandle)

read_image(Image,FontName+ '/handword1.jpg')

aafcc4e6-9fbb-11eb-8b86-12bb97331649.jpg

有时间可以写各种字符,每个相同字符多写几次,越多越好,增加训练的精准度;

把这栏作为训练样本

ab2b518a-9fbb-11eb-8b86-12bb97331649.png

阈值分割出字符。注意:这里要用一次膨胀,把i与j这些字符的点与字符体连接在一起,构成一个整体字符;

ab447d04-9fbb-11eb-8b86-12bb97331649.jpg

threshold(ImageReduced, RawSegmentation, 0, 75)

* Connectthe i's and j's with their dots

* 将i与j的点与线连接起来,构成一个整体

dilation_circle(RawSegmentation, RegionDilation, 19)

dev_set_color('green')

dev_display(RegionDilation)

connection(RegionDilation, ConnectedRegions)

* Reduceeach connected component (character) to its original shape

intersection(ConnectedRegions, RegionDilation, RegionIntersection)

count_obj(ConnectedRegions, Number)

sort_region(RegionIntersection, FinalLetters, 'first_point', 'true', 'column')

*Displaysegments

*显示分割块

dev_clear_window()

dev_display(ImageReduced)

dev_set_color('green')

dev_set_line_width(2)

dev_set_shape('rectangle1')

dev_set_draw('margin')

dev_display(FinalLetters)

我们来检查一下各个字符的分割与排序情况,尤其是对于i,j这类字符有没有实现整体性

ab70ea9c-9fbb-11eb-8b86-12bb97331649.png

我们看到20个字母被分割成了21个,原因就是这个j 没有被构成一个整体。然后我们再次调整一下dialation参数到22,并且注意也被膨胀太多了把相邻字母也连进来了

dilation_circle(RawSegmentation, RegionDilation, 22)

这次很好,20个字母完整分割

ab942b2e-9fbb-11eb-8b86-12bb97331649.jpg

* Step2: Training filegeneration

* 把teacher信号自己手写进来,创建训练文件TrainingFileName,训练文件都是.trf格式的,可以在硬盘里查询到。

*这里我们用append的函数把teacher信号一个一个地与被训练字符联系起来。

TrainingNames:=['b','b','a','b','d','c','e','f','h','i','i','i','d','c','e','e','g','j','i','h']

*训练文件TrainingFileName

TrainingFileName:= FontName + 'TrainingFile.trf'

sort_region(FinalLetters, SortedRegions, 'first_point', 'true', 'column')

shape_trans(SortedRegions, RegionTrans, 'rectangle1')

area_center(RegionTrans, Area, Row, Column)

MeanRow:= mean(Row)

dev_set_check('give_error')

for I :=0 to |TrainingNames| -1by 1

select_obj (SortedRegions, CharaterRegions,I+1)

append_ocr_trainf (CharaterRegions, Image,TrainingNames[I], TrainingFileName)

disp_message(WindowHandle, TrainingNames[I], 'image', MeanRow - 140, Column[I] - 6,'yellow', 'false')

endfor

abaa7744-9fbb-11eb-8b86-12bb97331649.png

可以查询一下训练文件

abb3d226-9fbb-11eb-8b86-12bb97331649.png

abbfb1d6-9fbb-11eb-8b86-12bb97331649.png

* Step3: Training 执行训练

CharNames:= uniq(sort(TrainingNames))

create_ocr_class_mlp(8, 10, 'constant', 'default', CharNames, 10, 'none', 10, 42, OCRHandle)

trainf_ocr_class_mlp(OCRHandle, TrainingFileName, 200, 1, 0.01, Error, ErrorLog)

*write_ocr_class_mlp产生一个.omc文件

write_ocr_class_mlp(OCRHandle, FontName+'Classifier')

clear_ocr_class_mlp(OCRHandle)

_________________________________

Do OCR执行识别

打开新的图片,建立被识别区域,步骤如下

abe85226-9fbb-11eb-8b86-12bb97331649.jpg

* Step 0: Preparations

FontName :='E:/Halcon/OCR/handwirteC/'

TrainingDocument:=FontName+'Classifier.omc'

*TrainingDocument:=FontName+'Class1.omc'

*

* Step 1: Segmentation

dev_update_window ('off')

dev_get_window (WindowHandle)

read_image (Image,FontName+'/handword1.jpg')

gen_rectangle1 (ROI_new, 2077.7,301.848, 2327.78, 2235.87)

reduce_domain (Image, ROI_new,ImageReducedNew)

binary_threshold (ImageReducedNew,Region_1, 'max_separability', 'dark', UsedThreshold1)

dilation_circle (Region_1,RegionDilation, 25.5)

dev_set_color ('green')

dev_display (RegionDilation)

connection (RegionDilation,ConnectedRegions)

intersection (ConnectedRegions,RegionDilation, RegionIntersection)

sort_region (RegionIntersection,Characters, 'character', 'true', 'row')

在这里,我们还是要查看一下膨胀的设置是否正确,尤其对于i,j类字符

ac0322ea-9fbb-11eb-8b86-12bb97331649.png

*Step 3 读取分类器

read_ocr_class_mlp(TrainingDocument, OCRHandle1)

*Classification

do_ocr_multi_class_mlp(Characters, Image, OCRHandle1, Class, Confidence)

* Step 4 Display results

area_center(Characters, Area, Row, Column)

dev_display(Image)

set_display_font(WindowHandle, 16, 'sans', 'true', 'false')

disp_message(WindowHandle, Class, 'image', Row - 146, Column + 8, 'blue', 'false')

*set_display_font(WindowHandle, 16, 'mono', 'true', 'false')

disp_message(WindowHandle, 'Classification result', 'window', 12, 12, 'black', 'true')

ac0e62a4-9fbb-11eb-8b86-12bb97331649.jpg

我们看到手写体的确不容易做好,这里与训练样本有关系,所以需要更大的样本量来优化识别器。

这里我们可以打开训练文件.trf,在不自己继续添加样本的情况下做一下无监督学习,把已有的字体做扭曲与各种变换的训练。

然后再次训练这个.trf文件,替换掉之前的训练文件。

ac4954d6-9fbb-11eb-8b86-12bb97331649.jpg

ac536cc8-9fbb-11eb-8b86-12bb97331649.jpg

ac5ced3e-9fbb-11eb-8b86-12bb97331649.jpg

训练完后,再次读取新的分类器,执行OCR, 这里重复代码

*Step 3 读取分类器

read_ocr_class_mlp(TrainingDocument, OCRHandle1)

*Classification

do_ocr_multi_class_mlp(Characters, Image, OCRHandle1, Class, Confidence)

* Step 4 Display results

area_center(Characters, Area, Row, Column)

dev_display(Image)

set_display_font(WindowHandle, 16, 'sans', 'true', 'false')

disp_message(WindowHandle, Class, 'image', Row - 146, Column + 8, 'blue', 'false')

*set_display_font(WindowHandle, 16, 'mono', 'true', 'false')

disp_message(WindowHandle, 'Classification result', 'window', 12, 12, 'black', 'true')

我们看到,新的识别器(上图)效果好于第一次的识别器(下图)

从 7/12提高到8/12

ac6fd28c-9fbb-11eb-8b86-12bb97331649.png

ac8f7632-9fbb-11eb-8b86-12bb97331649.png

最后有必要就可以写操作界面了, 这里不再赘述

ac9c8296-9fbb-11eb-8b86-12bb97331649.png

责任编辑:lq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 编程
    +关注

    关注

    90

    文章

    3730

    浏览量

    97555
  • 阈值
    +关注

    关注

    0

    文章

    124

    浏览量

    19009
  • 识别器
    +关注

    关注

    0

    文章

    27

    浏览量

    7881

原文标题:在家做手写体识别器

文章出处:【微信号:vision263com,微信公众号:新机器视觉】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    多工况环境耦合测试:新能源汽车电驱总成性能测试环境

    随着新能源汽车产业的高速发展,电驱总成作为整车的核心部件之一,其性能、可靠性及环境适应能力直接影响整车品质。在这一背景下,电驱总成性能测试系统的重要性日益凸显,而环境仓则成为其中不可或缺的关键设备
    的头像 发表于 04-30 10:26 317次阅读
    多工况<b class='flag-5'>环境</b>耦合测试:新能源汽车电驱总成性能测试<b class='flag-5'>环境</b>仓

    labview插入.net控件,运行报错,提示“无法加载控件”。有哪位大佬知道什么原因吗?

    labview2020,32位,halcon19.11,64位。(halcon可以正常使用)
    发表于 04-18 23:03

    线性化编程与结构化编程的不同点

    线性化编程是将整个用户程序连续放置在一个循环程序块(OB1)中,按顺序执行的编程范式。这种结构与PLC所代替的硬接线继电器控制类似,CPU逐条地处理指令,体现了早期PLC编程的简单性和直观性。说白了就是一条路走到黑,所有功能从上
    的头像 发表于 03-16 16:58 666次阅读
    线性化<b class='flag-5'>编程</b>与结构化<b class='flag-5'>编程</b>的不同点

    极端环境下的产品可靠性验证:环境例行试验方法与数据分析

    环境例行试验是一种用于评估批量生产产品环境适应性的试验方法。其主要目的是考核生产过程的稳定性,确保产品在预期的环境条件下能够正常工作。环境例行试验,是指在产品批量生产过程中,定期从生产
    的头像 发表于 03-13 16:55 708次阅读
    极端<b class='flag-5'>环境</b>下的产品可靠性验证:<b class='flag-5'>环境</b>例行试验方法与数据分析

    开发者分享 | 一次完整的 HPM EtherCAT 实战:环境、通信与极限测试

    概要1、vscode开发环境搭建2、EtherCAT与RK3562通讯测试3、编程IGH主站+HPM极限通讯测试4、ADC+EUI显示测试5、ADC远采系统1.vscode开发环境搭建1.1SDK
    的头像 发表于 02-09 16:32 2.1w次阅读
    开发者分享 | 一次完整的 HPM EtherCAT 实战:<b class='flag-5'>环境</b>、通信与极限测试

    CH341编程软件下载

    一款外国人设计的CH341编程软件,针对24CXX,25CXX等编程下载用,有更新资料见闲鱼上”于人杂货铺“
    发表于 01-23 15:37 16次下载

    从零开始安装并配置开源AI编程神器OpenCode

    编程神器OpenCode吧! 一,第一步:环境准备 (Node.js & opencode 然后键入命令,“/connect",连接编程大模型供应商。 选择“Z.AI Coding Plan”,如下所示
    的头像 发表于 01-22 21:22 2137次阅读
    从零开始安装并配置开源AI<b class='flag-5'>编程</b>神器OpenCode

    芯片编程器使用指南:如何避免芯片烧录过程中的常见错误

    芯片烧录失败多源于细节疏漏,使用编程器需规避常见错误。首要确保芯片与编程器适配,核查封装、电压协议并验证芯片 ID;重视环境与连接,做好静电防护、保障电源稳定及触点清洁;规范文件流程,严格版本核对
    的头像 发表于 12-30 10:59 768次阅读

    一文了解Mojo编程语言

    Mojo 是一种由 Modular AI 公司开发的编程语言,旨在将 Python 的易用性与 C 语言的高性能相结合,特别适合人工智能(AI)、高性能计算(HPC)和系统级编程场景。以下是关于
    发表于 11-07 05:59

    生态环境智慧监测系统方案

    在生态环境保护与治理体系中,精准掌握大气、水体、土壤等环境要素的实时状态,是开展污染防治、生态修复及环境决策的核心前提,直接关系到区域生态安全、人居环境质量及可持续发展目标的实现。 随
    的头像 发表于 10-22 17:10 943次阅读
    生态<b class='flag-5'>环境</b>智慧监测系统方案

    CoDeSys3基础编程及应用指南

    电子发烧友网站提供《CoDeSys3基础编程及应用指南.pdf》资料免费下载
    发表于 09-23 17:45 2次下载

    编程逻辑控制器PLC是什么?如何实现上网通信?

    编程逻辑控制器(PLC)是一种专为工业环境设计的数字运算操作电子系统,其核心是通过可编程存储器存储逻辑运算、顺序控制、定时、计数和算术运算等指令,并通过数字或模拟输入/输出控制各类机械或生产过程
    的头像 发表于 09-22 17:27 1328次阅读

    信捷XS STUDIO编程软件V2.3.2版本的全新功能

    XS Studio(V2.3.2)编程软件,是面向XS系列的编程组态软件,集成了PLC编程、可视化HMI、安全PLC、控制器实时核、现场总线及运动控制功能,提供了一套完整的包括配置、编程
    的头像 发表于 09-20 14:19 2753次阅读
    信捷XS STUDIO<b class='flag-5'>编程</b>软件V2.3.2版本的全新功能

    物联网平台应用环境监控:低代码零编程简化开发,组态应用

    传统环境监控系统开发常陷入两难困境,企业开发周期长、开发维护成本贵,基层运维人员不懂技术,遇到参数调整只能依赖IT团队。而物联网平台驱动的环境监控系统,以低代码零编程为核心,通过“可视化组态应用”将
    的头像 发表于 08-29 15:33 1184次阅读

    多功能自动环境监测气象站

    环境监测
    pingao141378
    发布于 :2025年07月22日 17:49:09