* ball_seq.hdev: Inspection of Ball Bonding

* 关闭更新
dev_update_off ()
*图像集合
ImageNames := 'die/' + ['die_02','die_03','die_04','die_07']
*设置显示颜色为混合颜色
dev_set_colored (12)
*读取图像
read_image (Bond, ImageNames[0])
*获取图像宽高
get_image_size (Bond, Width, Height)
*关闭窗体
dev_close_window ()
*开启与图像宽高一样大小的窗体
dev_open_window (0, 0, Width, Height, 'black', WindowHandle)
*设置显示字体
set_display_font (WindowHandle, 16, 'mono', 'true', 'false')
*设置显示填充形式,两种,margin表示边界,fill表示全部填充
dev_set_draw ('margin')
*设置线宽
dev_set_line_width (3)
*获取图像数量
NumImages := |ImageNames|
for I := 0 to NumImages - 1 by 1
    *读取图像
    read_image (Bond, ImageNames[I])
    *显示图像
    dev_display (Bond)
    *求取最大和最小灰度值
    min_max_gray (Bond, Bond, 0, Min, Max, Range)
    *灰度图像分割
    threshold (Bond, Bright, Max - 80, 255)
    *变换形状
    shape_trans (Bright, Die, 'rectangle2')
    *显示图像
    dev_display (Die)
    *截取图像
    reduce_domain (Bond, Die, DieGrey)
    * 求取最大和最小灰度值
    min_max_gray (Die, Bond, 0, Min, Max, Range)
     *灰度图像分割
    threshold (DieGrey, Wires, 0, Min + 30)
    *填充图像
    fill_up_shape (Wires, WiresFilled, 'area', 1, 100)
    *开运算,去除半斑点
    opening_circle (WiresFilled, Balls, 9.5)
    *分割区域
    connection (Balls, SingleBalls)
    *选择给定形状的区域
    select_shape_std (SingleBalls, Rect, 'rectangle1', 90)
    *区域求差集
    difference (SingleBalls, Rect, IntermediateBalls)
    *生成一个空白区域
    gen_empty_region (Forbidden)
    *分割重叠区域
    expand_gray (IntermediateBalls, Bond, Forbidden, RegionExpand, 4, 'image', 6)
    *开运算,去除半斑点
    opening_circle (RegionExpand, RoundBalls, 15.5)
    *根据区域第一个点排序
    sort_region (RoundBalls, FinalBalls, 'first_point', 'true', 'column')
    *求区域的最小外接圆
    smallest_circle (FinalBalls, Row, Column, Radius)
    NumBalls := |Radius|
    Diameter := 2 * Radius
    meanDiameter := sum(Diameter) / NumBalls
    mimDiameter := min(Diameter)
    *显示图像
    dev_display (RoundBalls)
    if (I != NumImages)
       *右下角显示 'Press Run (F5) to continue' 这个信息
        disp_continue_message (WindowHandle, 'black', 'true')
    endif
    stop ()
endfor

Blob分析之ball_seq.hdev的更多相关文章

  1. Blob分析之bottle.hdev

    * 分割读取啤酒瓶子上的数字* bottle.hdev: Segment and read numbers on a beer bottle* 第0步* Step 0: Preparations*定义 ...

  2. Blob分析之board.hdev

    * board.hdev: Detection of missing solder* 获取当前系统参数get_system ('clip_region', Information)*设置当前系统参数s ...

  3. Blob分析之 ball.hdev

    * ball.hdev: Inspection of Ball Bonding * 关闭窗体更新 dev_update_window ('off')*关闭窗体dev_close_window ()*打 ...

  4. 常用机器视觉工具----图像分析工具(blob分析)

    http://blog.sina.com.cn/s/blog_67cc4eb70100ivnt.html Blob分析:Blob分析目的在于对图像中的2-D形状进行检测和分析,得到诸如目标位置.形状. ...

  5. opencv 在工业中的应用:blob分析

    在工业中经常要检测一副图像中物体的数量,位置,大小,面积等信息,这就要用到BLOB分析,我用OPENCV做了个BLOB分析的DEMO. (1)打开一幅图像 (2)进行参数设置,设定二值化阙值,并选择是 ...

  6. Blob分析--粘连颗粒检测 基于距离变换的分水岭区域分割 盆地与原连通域求交集

    文章转自微信公众号:机器视觉那些事 *******************************************************************公众号:机器视觉那些事儿*** ...

  7. Halcon 笔记2 Blob分析

    1. 数组操作 2. 可视化-更新窗口 (1)单步模式-总是:则可以自动显示图像: (2)单步模式-从不:需要调用显示函数才能显示图像. (3)单步模式-清空显示:将原图清除,再显示新图 3. 图像处 ...

  8. Halcon blob分析基本处理步骤

    Halcon,blob分析 应用场景,二值化后的灰度图像对比度清晰 基本处理流程 1 读取图片 read_image(变量名,'路径') //halcon字符串使用单引号'' 2 预处理 2.1 RO ...

  9. Blob分析之board _components.hdev

    *用立体方法分割板子组件的示例程序*Application program to illustrate the segmentation* of board _components.hdev  wit ...

随机推荐

  1. TensorFlow中的显存管理器——BFC Allocator

    背景 作者:DeepLearningStack,阿里巴巴算法工程师,开源TensorFlow Contributor] 使用GPU训练时,一次训练任务无论是模型参数还是中间结果都需要占用大量显存.为了 ...

  2. Blazor带我重玩前端(二)

    概览 Blazor目前有两种托管模式,一种是Server-Side模式,一种是WebAssembly模式.官方首先支持的是Service-Side模式,使用WebAssembly模式,需要更新到最新版 ...

  3. videojs兼容ie8

    从网上找到很多这个videojs兼容ie8的解决方案,一个一个的试,最后发现没有一个是靠谱的.我好无奈啊…… 先看图(ie上访问必须是线上地址) 看代码: <!DOCTYPE html> ...

  4. 央行数字货币(CBDCs)的互操作性至关重要

    CBDCs(央行数字货币)将在我们的有生之年产生重大的金融转变.然而,除非这些工具吸取了法定货币的教训,否则创新将毫无意义.互操作性一直是影响CBDC采用和功能的最重要障碍之一.因此,各国央行在这一理 ...

  5. 使用Git GUI工具 上传本地仓库到 gitee码云仓库

    前言: 网上关于git的命令操作与使用很多教程和博客,在使用git工具时我发现有一个 git Gui 可视化工具,我觉得十分的亲切,由于我之前一直是使用svn作为版本控制管理工具,都是可视化操作,使用 ...

  6. 每天一点python:正则表达式中的findall方法

    举例:使用findall获取所有匹配的正则表达式文本,然后逐一替换. #! python3 """ A regular expression example: find ...

  7. Spring入门案例

    一.Spring基本介绍 1.什么是Spring Spring 是分层的 Java SE/EE 应用 full-stack 轻量级开源框架,以 IoC(Inverse Of Control: 反转控制 ...

  8. css导航菜单二级显示的问题

    m项目中出现了二级菜单的标签是在导航的里面,用css ul>li:hover ul>li>ul>li 这样子实现不了鼠标经过时导航里二级菜单的显示,这里个人感觉是冲突了.最后通 ...

  9. Java数组倒置

    Java数组之    -- 数组倒置 方法一 :  package mytest; public class test2 { public static void main(String[] args ...

  10. [CISCN2019 华东南赛区]Double Secret

    0x01 进入页面如下 提示我们寻找secret,再加上题目的提示,猜测这里有secret页面,我们尝试访问,结果如下 根据它这个话的意思,是让我们传参,然后它会给你加密,我们试一下 发现输入的1变成 ...