Halcon斑点分析涉及算子及其高阶运用
涉及算子
获取图像
使用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提供了对于彩色图像的一系列算子,可以和斑点分析结合使用
纹理分析
纹理分析可用于查找规则和不规则区域,不仅使用单个灰度值,还使用像素邻域对区域进行分割
斑点分析替代方案
边缘提取(精确至亚像素)
在斑点分析中,用像素的灰度值描述区域。作为替代,通过改变边界处的灰度值描述一个区域。这种方法称为边缘检测
分类器
要选择特定的灰度值,必须先确定阈值。多数情况下,算子使用固定值或当前值。如果系统自动确定范围,则很有用,这可以通过使用分类器来实现。此外,分类器还可以用于自动根据提取的特征和样本区分好坏对象。
提速
许多在线应用程序需要高速运行。这里列出了最常用的几种方法:
- 使用ROI帮助程序快速定位检测区域
- 如果对象具有特定的最小尺寸,则算子fast_threshold是阈值的快速替代方法。在调用阈值运算符之前,也可以使用gen_region和reduce_domain。
- 默认情况下,HALCON会执行一些数据的一致性检查。这些可以通过设置关闭
- 默认情况下,HALCON使用带有参数“ init_new-image”的set_system初始化新图像
这种行为可以改变
线扫相机
线扫有时必须处理(例如传送带上的物体)“无限”序列的图像。在这种情况下结束的一幅图像是下一幅图像的开始。这意味着位于两个图像中的部分对象必须合并成一个对象。Halcon提供算子merge_regions_line_scan 帮助合并线扫描图像中的区域。
高精度
有时需要高精度。使用斑点分析很难做到这一点,一种方式是使用高分辨率,备选方案是使用灰度值特征(如area_center_gray),如果对象满足特定灰度值,则每个像素都可以分为255个值而不是一个值(前景或背景)。如果需要更高的精度,可以考虑能精确到亚像素的边缘和线条提取
PS:Halcon的OCR在预处理阶段也使用了斑点分析
灵感源于官方文档
Halcon斑点分析涉及算子及其高阶运用的更多相关文章
- Halcon斑点分析BlobAnalysis解析
斑点分析的算法非常简单:在图像中,相关对象的像素(也称为前景)通过其灰度值来识别.例如,图中示例显示了液体中的组织颗粒.这些粒子是明亮的,液体(背景)是暗的.通过选择明亮的像素(阈值),可以很容易检测 ...
- Halcon斑点分析官方示例讲解
官方示例中有许多很好的例子可以帮助大家理解和学习Halcon,下面举几个经典的斑点分析例子讲解一下 Crystals 图中显示了在高层大气中采集到的晶体样本的图像.任务是分析对象以确定特定形状的频率. ...
- Swift 烧脑体操(三) - 高阶函数
前言 Swift 其实比 Objective-C 复杂很多,相对于出生于上世纪 80 年代的 Objective-C 来说,Swift 融入了大量新特性.这也使得我们学习掌握这门语言变得相对来说更加困 ...
- php对象和数组的相互转换(还是可以去找没有没php的高阶课程看看看)(要不别人分析一下重点要点,要不自己来,不然 效果真的不好)
php对象和数组的相互转换(还是可以去找没有没php的高阶课程看看看)(要不别人分析一下重点要点,要不自己来,不然 效果真的不好) 一.总结 都是自己实现的函数 算法: 1.先判断类型,gettype ...
- Python使用map,reduce高阶函数模拟实现Spark的reduceByKey算子功能
# 使用默认的高阶函数map和reduce import randomdef map_function(arg): # 生成测试数据 return (arg,1) list_map = list(m ...
- 基于Hadoop2.0、YARN技术的大数据高阶应用实战(Hadoop2.0\YARN\Ma
Hadoop的前景 随着云计算.大数据迅速发展,亟需用hadoop解决大数据量高并发访问的瓶颈.谷歌.淘宝.百度.京东等底层都应用hadoop.越来越多的企 业急需引入hadoop技术人才.由于掌握H ...
- 迈向高阶:优秀Android程序员必知必会的网络基础
1.前言 网络通信一直是Android项目里比较重要的一个模块,Android开源项目上出现过很多优秀的网络框架,从一开始只是一些对HttpClient和HttpUrlConnection简易封装使用 ...
- Hive 高阶应用开发示例(一)
Hive的一些常用的高阶开发 内容 1.开窗函数 2.行转列,列转行,多行转一行,一行转多行 3.分组: 增强型group 4.排序 5.关联 本次的内容: 内容1 和内容2,采用 ...
- [Node.js] 闭包和高阶函数
原文地址:http://www.moye.me/2014/12/29/closure_higher-order-function/ 引子 最近发现一个问题:一部分写JS的人,其实对于函数式编程的概念并 ...
随机推荐
- 高性能可扩展mysql 笔记(一)数据库表、索引、SQL语句设计规范
个人博客网:https://wushaopei.github.io/ (你想要这里多有) 项目说明:该笔记的背景为电商平台项目,电商项目由于其高并发.多线程.高耗能等特性,在众多的项目类型中涉及 ...
- 蓝桥杯 算法提高 11-1实现strcmp函数 (JAVA方法)
蓝桥杯 算法提高 11-1实现strcmp函数 (JAVA方法) 首先这不是一个多难的题,但是网上的我没怎么找到有Java的代码,基本全都是c语言的,小编是个小白,如果有不对的地方请联系小编 问题描述 ...
- (Java实现) 光荣的梦想
光荣的梦想 Time Limit:10000MS Memory Limit:65536K Total Submit:110 Accepted:45 Description Prince对他在这片大陆上 ...
- Java实现 LeetCode 560 和为K的子数组(某著名排序大法改编)
560. 和为K的子数组 给定一个整数数组和一个整数 k,你需要找到该数组中和为 k 的连续的子数组的个数. 示例 1 : 输入:nums = [1,1,1], k = 2 输出: 2 , [1,1] ...
- Java实现 蓝桥杯VIP 算法训练 回文数
import java.util.Scanner; public class 回文数 { static int time = 0; public static int change(String st ...
- Java实现 LeetCode 86 分割链表
86. 分隔链表 给定一个链表和一个特定值 x,对链表进行分隔,使得所有小于 x 的节点都在大于或等于 x 的节点之前. 你应当保留两个分区中每个节点的初始相对位置. 示例: 输入: head = 1 ...
- [bx] and loop
1.[bx] 表示一个内存单元,它的偏移地址在bx中 mov al,[bx] 2.描述符号() 来表示一个寄存器或一个内存单元中的内容. 约定符号idata表示常量. 3.loop 标号 CPU在执行 ...
- 95题--不同的二叉搜索树II(java、中等难度)
题目描述:给定一个整数 n,生成所有由 1 ... n 为节点所组成的 二叉搜索树 . 示例如下: 分析:这一题需要对比LeetCode96题来分析:https://www.cnblogs.com/K ...
- HDU-4341 Gold miner 题解
题目大意 黄金矿工的游戏,不过每个金块可以看做是质点,没有大小,给出每个金块的坐标.抓取所花费的时间(包括返回的时间),以及价值,其中有一些金块可能会共线.求在规定时间内所获得的最大价值. 样例 样例 ...
- leetcode75之颜色分类
题目描述: 给定一个包含红色.白色和蓝色,一共 n 个元素的数组,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色.白色.蓝色顺序排列. 此题中,我们使用整数 0. 1 和 2 分别表示红色.白 ...