3233
- 收藏
- 点赞
- 分享
- 举报
目标分割与统计
本帖最后由 9crk 于 2015-1-4 21:26 编辑
比如桌上一堆米,互相无接触(其实就算有接触,用一些腐蚀算法也可以去掉碰触连接的地方),需要数出来有多少粒米,或者每一粒米的位置(事实上,把每一粒米的位置找出来然后根据此米粒的形状判断其是否缺陷,这是很常见的需求)。
回归正题。
常用的方法是递归,如果找到一个黑点后,向其四周找,如果还有黑点,就继续向其四周找,无限循环下去(当然,为了避免重复,需要建立一个表格,如果这一点找过了,就不对它进行判断了)
这个方法的致命弱点是效率,它可能会需要庞大的stack空间进行递归,并且大小不可控,而且在DSP的BIOS操作系统上,stack错误会直接导致系统死掉。
以下推荐一个分割与标记的方法:two pass,可以将每一个连通区域分开并标记上不同的编号。

步骤如下:
[quote]
(1)第一次扫描:
访问当前像素B(x,y),如果B(x,y) == 1:
a、如果B(x,y)的领域中像素值都为0,则赋予B(x,y)一个新的label:
label += 1, B(x,y) = label;
b、如果B(x,y)的领域中有像素值 > 1的像素Neighbors:
1)将Neighbors中的最小值赋予给B(x,y):
B(x,y) = min{Neighbors}
2)记录Neighbors中各个值(label)之间的相等关系,即这些值(label)同属同一个连通区域;
labelSet = { label_m, .., label_n },labelSet中的所有label都属于同一个连通区域(注:这里可以有多种实现方式,只要能够记录这些具有相等关系的label之间的关系即可)
(2)第二次扫描:
访问当前像素B(x,y),如果B(x,y) > 1:
a、找到与label = B(x,y)同属相等关系的一个最小label值,赋予给B(x,y);
完成扫描后,图像中具有相同label值的像素就组成了同一个连通区域。[/quote]
比如桌上一堆米,互相无接触(其实就算有接触,用一些腐蚀算法也可以去掉碰触连接的地方),需要数出来有多少粒米,或者每一粒米的位置(事实上,把每一粒米的位置找出来然后根据此米粒的形状判断其是否缺陷,这是很常见的需求)。
回归正题。
常用的方法是递归,如果找到一个黑点后,向其四周找,如果还有黑点,就继续向其四周找,无限循环下去(当然,为了避免重复,需要建立一个表格,如果这一点找过了,就不对它进行判断了)
这个方法的致命弱点是效率,它可能会需要庞大的stack空间进行递归,并且大小不可控,而且在DSP的BIOS操作系统上,stack错误会直接导致系统死掉。
以下推荐一个分割与标记的方法:two pass,可以将每一个连通区域分开并标记上不同的编号。

步骤如下:
[quote]
(1)第一次扫描:
访问当前像素B(x,y),如果B(x,y) == 1:
a、如果B(x,y)的领域中像素值都为0,则赋予B(x,y)一个新的label:
label += 1, B(x,y) = label;
b、如果B(x,y)的领域中有像素值 > 1的像素Neighbors:
1)将Neighbors中的最小值赋予给B(x,y):
B(x,y) = min{Neighbors}
2)记录Neighbors中各个值(label)之间的相等关系,即这些值(label)同属同一个连通区域;
labelSet = { label_m, .., label_n },labelSet中的所有label都属于同一个连通区域(注:这里可以有多种实现方式,只要能够记录这些具有相等关系的label之间的关系即可)
(2)第二次扫描:
访问当前像素B(x,y),如果B(x,y) > 1:
a、找到与label = B(x,y)同属相等关系的一个最小label值,赋予给B(x,y);
完成扫描后,图像中具有相同label值的像素就组成了同一个连通区域。[/quote]
我来回答
回答2个
时间排序
认可量排序
认可0
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片
相关问答
-
2018-12-27 13:41:14
-
2018-12-04 17:23:57
-
2020-08-18 11:36:27
-
2019-01-18 11:28:44
-
2018-12-14 14:41:37
-
2016-11-23 17:42:54
-
2025-09-14 12:26:13
-
2017-02-09 14:56:16
-
2023-10-09 14:01:50
-
2020-09-30 10:48:30
-
2020-04-11 17:22:32
-
02018-10-17 17:13:23
-
2019-01-19 11:26:02
-
2018-01-07 15:52:32
-
2013-08-23 12:47:47
-
2013-08-25 10:51:17
-
2021-03-16 16:33:41
-
2019-11-22 22:36:43
-
2017-09-07 20:25:01
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
5hisi3516cv610 + gc4336p 夜晚很模糊
-
5AIISP(功能演示,SC4336P为BGGR,强制转RGGB,会导致颜色异常)
-
5rv1106使用luckfox的SDK,设备树和驱动都写好了,结果设备文件没有生成
-
5海思3516cv610中如何进行SD卡升级,根据官方文档操作,烧录进板子时,走的默认uboot,没有执行uboot升级。
-
5G610Q-IPC-38E 夜晚很暗 有什么办法解决吗 已经补光了
-
10转换模型时,SoC版本里没显示hi3516cv610芯片
-
5hisi3516cv610 使用 yolov8n 模型训练 要如何提高 这里识别的是人
-
10有人在海思平台接过SC035HGS吗
-
5关于hi3519dv500,以SD卡虚拟 U 盘操作
-
5ss928 sample_venc代码移植到openEuler24.03上执行报错 [sample_comm_vi_start_dev]-1068: vi set dev attr failed wi
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认

微信扫码分享
QQ好友
