HALCON示例程序inspect_bottle_mouth.hdev玻璃瓶口缺陷检测

HALCON示例程序inspect_bottle_mouth.hdev玻璃瓶口缺陷检测

示例程序源码(加注释)

  • 定义变量并初始化
    SmoothX := 501
    ThresholdOffset := 25
    MinDefectSize := 50
    PolarResolution := 640
    RingSize := 70
    get_system (‘store_empty_region’, StoreEmptyRegion)
    set_system (‘store_empty_region’, ‘false’)
    read_image (Image, ‘bottles/bottle_mouth_01’)

  • 关于显示类函数解释
    dev_update_off ()
    dev_close_window ()
    dev_close_window ()
    dev_open_window_fit_image (Image, 0, 0, 640, 512, WindowHandle1)
    set_display_font (WindowHandle1, 16, ‘mono’, ‘true’, ‘false’)
    dev_display (Image)
    dev_set_draw (‘margin’)
    dev_set_line_width (3)
    dev_open_window_fit_size (0, 648, RingSize, PolarResolution, 150, 512, WindowHandle)
    dev_set_draw (‘margin’)
    dev_set_line_width (3)
    dev_set_color (‘red’)
    for Index := 1 to 16 by 1
    read_image (Image, ‘bottles/bottle_mouth_’ + Index$’.02’)

    • 使用形态学检测瓶口
    • 使用多个阈值来分割单通道图像
      auto_threshold (Image, Regions, 2)
    • 选取灰度值最小的分割区域
      select_obj (Regions, DarkRegion, 1)
    • 开运算
      opening_circle (DarkRegion, RegionOpening, 3.5)
    • 闭运算
      closing_circle (RegionOpening, RegionClosing, 25.5)
    • 填充孔洞
      fill_up (RegionClosing, RegionFillUp)
    • 提取区域边界
      boundary (RegionFillUp, RegionBorder, ‘outer’)
    • 膨胀边界
      dilation_circle (RegionBorder, RegionDilation, 3.5)
    • 将膨胀边界提取出
      reduce_domain (Image, RegionDilation, ImageReduced)
    • 通过拟合圆形找到瓶口中心
    • 关于edges_sub_pix算子解释传送门
      edges_sub_pix (ImageReduced, Edges, ‘canny’, 0.5, 20, 40)
    • 分割XLD轮廓,算子解释传送门
      segment_contours_xld (Edges, ContoursSplit, ‘lines_circles’, 5, 4, 2)
    • union_cocircular_contours_xld - 计算属于同一个圆的轮廓的并集。
    • union_cocircular_contours_xld(轮廓:合并的轮廓:两个圆弧的最大角距离,两个圆弧的最大重叠,连接线与圆弧切线之间的最大角度,两个圆弧之间间隙的最大长度,两个圆弧的最大半径差,两个圆弧的最大中心距离,是否合并没有拟合圆的小轮廓,迭代次数:)
      union_cocircular_contours_xld (ContoursSplit, UnionContours, 0.9, 0.5, 0.5, 200, 50, 50, ‘true’, 1)
    • XLD轮廓长度
      length_xld (UnionContours, Length)
    • sort_index - 对元组的元素进行排序并返回已排序元组的索引。取最长轮廓
      select_obj (UnionContours, LongestContour, sort_index(Length)[|Length| - 1] + 1)
    • 拟合圆形
      fit_circle_contour_xld (LongestContour, ‘ahuber’, -1, 0, 0, 3, 2, Row, Column, Radius, StartPhi, EndPhi, PointOrder)
    • 使用极坐标变换将瓶口圆环展开成矩形
    • 画圆
      gen_circle (Circle, Row, Column, Radius)
    • 膨胀
      dilation_circle (Circle, RegionDilation, 5)
    • 腐蚀
      erosion_circle (Circle, RegionErosion, RingSize - 5)
    • 求不同
      difference (RegionDilation, RegionErosion, RegionDifference)
    • 缩减定义域
      reduce_domain (Image, RegionDifference, ImageReduced)
    • polar_trans_image_ext - 将图像进行极坐标变换。
    • polar_trans_image_ext(图片:极坐标变换图,弧中心行坐标,弧中心列坐标,起始角度,结束角度,起始半径,结束半径,宽度,高度,差值方法:)
      polar_trans_image_ext (ImageReduced, ImagePolar, Row, Column, 0, rad(360), Radius - RingSize, Radius, PolarResolution, RingSize, ‘nearest_neighbor’)
    • 使用动态阈值寻找缺陷
      scale_image_max (ImagePolar, ImageScaleMax)
      mean_image (ImageScaleMax, ImageMean, SmoothX, 3)
      dyn_threshold (ImageScaleMax, ImageMean, Regions1, 55, ‘not_equal’)
      connection (Regions1, Connection)
      select_shape (Connection, SelectedRegions, ‘height’, ‘and’, 9, 99999)
    • 消除噪声区域
      closing_rectangle1 (SelectedRegions, RegionClosing1, 10, 20)
      union1 (RegionClosing1, RegionUnion)
    • 反极坐标变换
      polar_trans_region_inv (RegionUnion, XYTransRegion, Row, Column, 0, rad(360), Radius - RingSize, Radius, PolarResolution, RingSize, 1280, 1024, ‘nearest_neighbor’)
    • 显示结果
      dev_set_window (WindowHandle1)
      dev_display (Image)
      dev_set_color (‘blue’)
      dev_display (RegionDifference)
      dev_set_color (‘red’)
      dev_display (XYTransRegion)
    • 显示极坐标变换区域
      dev_set_window (WindowHandle)
    • 围绕图像中心旋转图像
      rotate_image (ImagePolar, ImageRotate, 90, ‘constant’)
      dev_display (ImageRotate)
      count_obj (RegionUnion, Number)
      if (Number > 0)
      • 镜像区域
        mirror_region (RegionUnion, RegionMirror, ‘diagonal’, PolarResolution)
        mirror_region (RegionMirror, RegionMirror, ‘row’, PolarResolution)
        dev_display (RegionMirror)
        disp_message (WindowHandle1, ‘Not OK’, ‘window’, -1, -1, ‘red’, ‘false’)

    else
    disp_message (WindowHandle1, ‘OK’, ‘window’, -1, -1, ‘forest green’, ‘false’)
    endif
    if (Index < 16)
    disp_continue_message (WindowHandle1, ‘black’, ‘true’)
    stop ()
    endif
    endfor

  • 恢复系统参数
    set_system (‘store_empty_region’, StoreEmptyRegion)

处理思路

这个例子是主要讲解了使用极坐标变换进行缺陷检测的例子。
auto_threshold 、select_obj ,自动阈值分割。
boundary提取区域边缘edges_sub_pix、segment_contours_xld、union_cocircular_contours_xld、length_xld、select_obj 、fit_circle_contour_xld 边界的提取、分割、合并、求长、选取、拟合。
polar_trans_image_ext极坐标变换polar_trans_region_inv反极坐标变换
mirror_region镜像区域

后记

大家有什么问题可以向我提问哈,我看到了第一时间回复,希望在学习的路上多多结交良师益友。

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

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

相关文章

静态主席树总结(静态区间的k大)

静态主席树总结(静态区间的&#xff4b;大) 首先我们先来看一道题 给定N个正整数构成的序列&#xff0c;将对于指定的闭区间查询其区间内的第K小值。 输入格式&#xff1a; 第一行包含两个正整数N、M&#xff0c;分别表示序列的长度和查询的个数。 第二行包含N个正整数&a…

Java中MySQL事务处理举例

实例&#xff08;以sql语句中的insert语句为例&#xff09; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement;/*** 事务的基本用法**/ …

永磁交流伺服电机的工作原理与更换新编码器后的常规零位校正方法

http://wuhuotun.blog.163.com/blog/static/73085450200910655748516/ 永磁交流伺服电机的编码器相位为何要与转子磁极相位对齐 其唯一目的就是要达成矢量控制的目标&#xff0c;使d轴励磁分量和q轴出力分量解耦&#xff0c;令永磁交流伺服电机定子绕组产生的电磁场始终正交于…

理解Java中字符流与字节流的区别

1. 什么是流 Java中的流是对字节序列的抽象&#xff0c;我们可以想象有一个水管&#xff0c;只不过现在流动在水管中的不再是水&#xff0c;而是字节序列。和水流一样&#xff0c;Java中的流也具有一个“流动的方向”&#xff0c;通常可以从中读入一个字节序列的对象被称为输入…

HALCON示例程序inspect_solar_fingers.hdev太阳能电池板电路缺陷检测

HALCON示例程序inspect_solar_fingers.hdev太阳能电池板电路缺陷检测 示例程序源码&#xff08;加注释&#xff09; 关于显示类函数解释 dev_update_off () dev_close_window () ImageName : ‘solar_cell/solar_cell_’ read_image (Image, ImageName ‘01’) dev_open_win…

C++多线程 例子

C多线程 例子2008-08-21 15:11//这是2个线程模拟卖火车票的小程序#include <windows.h>#include <iostream.h>DWORD WINAPI Fun1Proc(LPVOID lpParameter);//thread dataDWORD WINAPI Fun2Proc(LPVOID lpParameter);//thread dataintindex0;inttickets10;HANDLE hM…

2018/03/25

2019独角兽企业重金招聘Python工程师标准>>> March 25 2018 Sunday Weather&#xff1a;cloudy 1、需求&#xff1a; a0.5 b3 ca*b 求c的值&#xff1a; [rootDasoncheng sbin]# cat a.sh #!/bin/bash a0.5 b3 cecho $a*$b |bc echo $canswer referred&#xff1a;…

统计字符串中每种字符类型的个数demo

/** 统计字符串中每中字符类型的个数&#xff0c;思路&#xff1a;* 1、键盘录入一个字符串* 2、获取到每个字符&#xff0c;遍历字符串* for (int i 0; i < s.length(); i) {char ch s.charAt(i);* 3、判断每个字符属于哪种类型&#xff0c;对应的个数*/package cn.strin…

css3 图片放大缩小闪烁效果

直接把图片替换就可以了&#xff0c;我的图片是透明的&#xff0c;所以body设置为黑色的&#xff0c;不不要可以去掉 <!doctype html><html lang"en"><head> <meta charset"UTF-8"> <title>css3 图片放大缩小闪烁效果</t…

HALCON示例程序max_connection.hdev确定分割区域的最大区域数目

HALCON示例程序max_connection.hdev确定分割区域的最大区域数目 示例程序源码&#xff08;加注释&#xff09; read_image (Image, ‘monkey’) get_system (‘max_connection’, Information) set_system (‘max_connection’, 0) threshold (Image, Region, 128, 255) 区域…

elasticsearch分词聚合查询demo

2019独角兽企业重金招聘Python工程师标准>>> 我们在通过elasticsearch查询text类型的字段时&#xff0c;我们使用aggs进行聚合某个text类型field。这时elasticsearch会自动进行分词将分词后的结果进行聚合。获取每一个分词出现在文档的文档个数。注意&#xff1a;是…

软件工程进度条-第十五周

第十五周 所花时间&#xff08;包括上课&#xff09; 23 代码量&#xff08;行&#xff09; 1200 博客量&#xff08;篇&#xff09; 6 了解到的知识点 1、了解ListView的基本用法&#xff0c;并改变焦点触碰事件&#xff1b; 2、理解团队开发后进行软件项目总结的益处…

Spring实战第七章

一、SpringMVC配置代替方案 1自定DispatcherServlet 按照AbstractAnnotationConfigDispatcherServletInitializer的定义&#xff0c;它会创建DispatcherServlet和ContextLoaderListener。 AbstractAnnotationConfigDispatcherServletInitializer有三个方法是必须要重载的abstra…

EPSON TCP/IP 通信

EPSON SCARA机器人TCP/IP 通信时&#xff0c;涉及到的相关指令说明。 14.3 TCP/IP命令。 OpenNet //打开TCP/IP端口。 ChkNet //返回端口状态&#xff1a;等待读取的字节数或错误条件。 CloseNet //关闭TCP/IP端口。 SetNet //运行时或从命令窗口中设置通信端…

JDBC(九)DatabaseMetaData 数据库元数据

通过java.sql.DatabaseMetaData 接口&#xff0c;我们能获取到数据库的列表、列等信息。 DatabaseMetaData 接口包含了许多方法&#xff0c;这里值介绍常用的。 ###获取 DatabaseMetaData 实例对象 DatabaseMetaData databaseMetaData connection.getMetaData(); 复制代码###获…

C++多线程(一)

C多线程&#xff08;一&#xff09; WIN 多线程API一 简单实例比较简单的代码&#xff0c;创建10个线程&#xff0c;其中使第4个线程在一创建就挂起&#xff0c;等到其他的线程执行的差不多的时候再使第4个线程恢复执行。#include <stdio.h>#include <stdlib.h>#i…

HALCON示例程序measure_ball_bond.hdev电路板焊点位置测量

HALCON示例程序measure_ball_bond.hdev电路板焊点位置测量 示例程序源码&#xff08;加注释&#xff09; 关于显示类函数解释 dev_update_off () dev_close_window () FileName : ‘bonds/ball_bond_ccd_’ read_image (Image, FileName 1$‘02’) dev_open_window_fit_imag…

rank()over 函数的使用

1. over()是分析函数&#xff0c;可以和rank()函数配合使用&#xff0c;也可以和其他函数配合使用。取每个学科排名前三的分数&#xff0c;sql语句如下&#xff1a; select * from (select rank() over(partition by subject order by mark desc) rk,S.* from S) T where T.rk&…

天梯赛2016-L2

L2-001. 紧急救援 作为一个城市的应急救援队伍的负责人&#xff0c;你有一张特殊的全国地图。在地图上显示有多个分散的城市和一些连接城市的快速道路。每个城市的救援队数量和每一条连接两个城市的快速道路长度都标在地图上。当其他城市有紧急求助电话给你的时候&#xff0c;你…

伺服系统控制网络的重要性! 现场总线的重要性! SSCNET运动控制系统与发展趋势

引言&#xff1a;在2010年的时候&#xff0c;在北京的一个数控公司工作。产品采用的是通过运动控制卡发脉冲的方式&#xff0c;控制机床的X、Y、Z轴进行加工。 机床在加工产品的时候&#xff0c;一直存在着精度的问题&#xff0c;例如DMG的机床可以达到0.01的加工精度&#x…