涉及算子

获取图像

使用ROI

对齐ROI或图像

校正图像

基础内容这里不再重述

预处理图像(过滤)

基础:

mean_image(平均平滑过滤),gauss_filter(高斯滤波),binomial_filter(二项式滤波器),median_image(中值滤波)

高级:

smooth_image(滤镜过滤),anisotropic_diffusion(各向异性扩散滤波),fill_interlace(针对视频流图像滤波),rank_image(等级滤波器)

提取分割参数

基础:

gray_histo_abs(计算绝对灰度值分布),histo_to_thresh(从直方图确定灰度值阈值)

高级:

intensity(计算灰度值的平均值和偏差)

分割图像

基础:

threshold(使用全局阈值分割图像),fast_threshold(使用全局阈值快速处理图像),binary_threshold(二进制阈值),dyn_threshold(局部阈值),histo_to_thresh,gray_histo(计算灰度值分布)

高级:

local_threshold(Sauvola算法分割),var_threshold(局部均值和标准差分析分割),watersheds(分水岭方法),watersheds_threshold(通过阈值使用分水岭方法),regiongrowing(区域生长),regiongrowing_mean(平均灰度区域生长)

处理区域

基础:

connection(计算区域的连接组件),select_shape(通过形状特征选择),opening_circle(通过圆形开启区域),closing_circle(通过圆形封闭区域),opening_rectangle1,closeing_rectangle1,difference(计算区域差异),intersection(计算区域交点),union1(计算区域并集),shape_trans(变换形状),fill_up(填充区域中的孔)

高级:

select_shape_proto(特定关系选择区域),select_gray(灰度值特征选择区域),clip_region(裁剪区域为),sort_region(区域排序),skeleton(计算区域的骨架),partition_dynamic(动态分区),rank_region(区域等级)

特征提取

基础:

area_center(中心区域),smallest_rectangle1(平行坐标轴的最小矩形),samlllest_rectangle2(任意方向最小矩形),compactness(计算区域紧密度),eccentricity(偏心率),elliptic_axis(椭圆轴),area_center_gray(计算灰度图像中区域的面积和重心),intensity,min_max_gray(计算区域最大最小灰度值)

高级:

diameter_region(计算两区域边界点最大距离),inner_rectangle1(区域的最大内部矩形),inner_circle,gray_histo_abs,entropy_gary(确定图像的熵和各向异性)

结果转换为世界坐标

基础:

image_points_to_world_plane(转换像素点)

高级:

gen_contour_region_xld(生成XLD轮廓),contour_to_world_plane_xld(转换XLD轮廓)

可视化结果

高阶运用

斑点分析实用方法

色彩处理

使用三个颜色通道代替只使用一个灰度通道,Halcon提供了对于彩色图像的一系列算子,可以和斑点分析结合使用

纹理分析

纹理分析可用于查找规则和不规则区域,不仅使用单个灰度值,还使用像素邻域对区域进行分割

斑点分析替代方案

边缘提取(精确至亚像素)

在斑点分析中,用像素的灰度值描述区域。作为替代,通过改变边界处的灰度值描述一个区域。这种方法称为边缘检测

分类器

要选择特定的灰度值,必须先确定阈值。多数情况下,算子使用固定值或当前值。如果系统自动确定范围,则很有用,这可以通过使用分类器来实现。此外,分类器还可以用于自动根据提取的特征和样本区分好坏对象。

提速

许多在线应用程序需要高速运行。这里列出了最常用的几种方法:

  1. 使用ROI帮助程序快速定位检测区域
  2. 如果对象具有特定的最小尺寸,则算子fast_threshold是阈值的快速替代方法。在调用阈值运算符之前,也可以使用gen_region和reduce_domain。
  3. 默认情况下,HALCON会执行一些数据的一致性检查。这些可以通过设置关闭
  4. 默认情况下,HALCON使用带有参数“ init_new-image”的set_system初始化新图像

    这种行为可以改变

线扫相机

线扫有时必须处理(例如传送带上的物体)“无限”序列的图像。在这种情况下结束的一幅图像是下一幅图像的开始。这意味着位于两个图像中的部分对象必须合并成一个对象。Halcon提供算子merge_regions_line_scan 帮助合并线扫描图像中的区域。

高精度

有时需要高精度。使用斑点分析很难做到这一点,一种方式是使用高分辨率,备选方案是使用灰度值特征(如area_center_gray),如果对象满足特定灰度值,则每个像素都可以分为255个值而不是一个值(前景或背景)。如果需要更高的精度,可以考虑能精确到亚像素的边缘和线条提取

PS:Halcon的OCR在预处理阶段也使用了斑点分析

灵感源于官方文档

Halcon斑点分析涉及算子及其高阶运用的更多相关文章

  1. Halcon斑点分析BlobAnalysis解析

    斑点分析的算法非常简单:在图像中,相关对象的像素(也称为前景)通过其灰度值来识别.例如,图中示例显示了液体中的组织颗粒.这些粒子是明亮的,液体(背景)是暗的.通过选择明亮的像素(阈值),可以很容易检测 ...

  2. Halcon斑点分析官方示例讲解

    官方示例中有许多很好的例子可以帮助大家理解和学习Halcon,下面举几个经典的斑点分析例子讲解一下 Crystals 图中显示了在高层大气中采集到的晶体样本的图像.任务是分析对象以确定特定形状的频率. ...

  3. Swift 烧脑体操(三) - 高阶函数

    前言 Swift 其实比 Objective-C 复杂很多,相对于出生于上世纪 80 年代的 Objective-C 来说,Swift 融入了大量新特性.这也使得我们学习掌握这门语言变得相对来说更加困 ...

  4. php对象和数组的相互转换(还是可以去找没有没php的高阶课程看看看)(要不别人分析一下重点要点,要不自己来,不然 效果真的不好)

    php对象和数组的相互转换(还是可以去找没有没php的高阶课程看看看)(要不别人分析一下重点要点,要不自己来,不然 效果真的不好) 一.总结 都是自己实现的函数 算法: 1.先判断类型,gettype ...

  5. Python使用map,reduce高阶函数模拟实现Spark的reduceByKey算子功能

    # 使用默认的高阶函数map和reduce import randomdef map_function(arg):  # 生成测试数据 return (arg,1) list_map = list(m ...

  6. 基于Hadoop2.0、YARN技术的大数据高阶应用实战(Hadoop2.0\YARN\Ma

    Hadoop的前景 随着云计算.大数据迅速发展,亟需用hadoop解决大数据量高并发访问的瓶颈.谷歌.淘宝.百度.京东等底层都应用hadoop.越来越多的企 业急需引入hadoop技术人才.由于掌握H ...

  7. 迈向高阶:优秀Android程序员必知必会的网络基础

    1.前言 网络通信一直是Android项目里比较重要的一个模块,Android开源项目上出现过很多优秀的网络框架,从一开始只是一些对HttpClient和HttpUrlConnection简易封装使用 ...

  8. Hive 高阶应用开发示例(一)

    Hive的一些常用的高阶开发 内容    1.开窗函数   2.行转列,列转行,多行转一行,一行转多行   3.分组: 增强型group   4.排序  5.关联 本次的内容: 内容1 和内容2,采用 ...

  9. [Node.js] 闭包和高阶函数

    原文地址:http://www.moye.me/2014/12/29/closure_higher-order-function/ 引子 最近发现一个问题:一部分写JS的人,其实对于函数式编程的概念并 ...

随机推荐

  1. 高性能可扩展mysql 笔记(一)数据库表、索引、SQL语句设计规范

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 项目说明:该笔记的背景为电商平台项目,电商项目由于其高并发.多线程.高耗能等特性,在众多的项目类型中涉及 ...

  2. 蓝桥杯 算法提高 11-1实现strcmp函数 (JAVA方法)

    蓝桥杯 算法提高 11-1实现strcmp函数 (JAVA方法) 首先这不是一个多难的题,但是网上的我没怎么找到有Java的代码,基本全都是c语言的,小编是个小白,如果有不对的地方请联系小编 问题描述 ...

  3. (Java实现) 光荣的梦想

    光荣的梦想 Time Limit:10000MS Memory Limit:65536K Total Submit:110 Accepted:45 Description Prince对他在这片大陆上 ...

  4. Java实现 LeetCode 560 和为K的子数组(某著名排序大法改编)

    560. 和为K的子数组 给定一个整数数组和一个整数 k,你需要找到该数组中和为 k 的连续的子数组的个数. 示例 1 : 输入:nums = [1,1,1], k = 2 输出: 2 , [1,1] ...

  5. Java实现 蓝桥杯VIP 算法训练 回文数

    import java.util.Scanner; public class 回文数 { static int time = 0; public static int change(String st ...

  6. Java实现 LeetCode 86 分割链表

    86. 分隔链表 给定一个链表和一个特定值 x,对链表进行分隔,使得所有小于 x 的节点都在大于或等于 x 的节点之前. 你应当保留两个分区中每个节点的初始相对位置. 示例: 输入: head = 1 ...

  7. [bx] and loop

    1.[bx] 表示一个内存单元,它的偏移地址在bx中 mov al,[bx] 2.描述符号() 来表示一个寄存器或一个内存单元中的内容. 约定符号idata表示常量. 3.loop 标号 CPU在执行 ...

  8. 95题--不同的二叉搜索树II(java、中等难度)

    题目描述:给定一个整数 n,生成所有由 1 ... n 为节点所组成的 二叉搜索树 . 示例如下: 分析:这一题需要对比LeetCode96题来分析:https://www.cnblogs.com/K ...

  9. HDU-4341 Gold miner 题解

    题目大意 黄金矿工的游戏,不过每个金块可以看做是质点,没有大小,给出每个金块的坐标.抓取所花费的时间(包括返回的时间),以及价值,其中有一些金块可能会共线.求在规定时间内所获得的最大价值. 样例 样例 ...

  10. leetcode75之颜色分类

    题目描述: 给定一个包含红色.白色和蓝色,一共 n 个元素的数组,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色.白色.蓝色顺序排列. 此题中,我们使用整数 0. 1 和 2 分别表示红色.白 ...