博客
关于我
图像中米粒个数的识别(2)——如何从左到右依次给米粒计数
阅读量:716 次
发布时间:2019-03-21

本文共 1363 字,大约阅读时间需要 4 分钟。

图像中米粒个数识别及排序方法

我在之前的文章中详细探讨了如何实现图像中的米粒个数识别以及计数相关的算法和程序实现。但是有一个问题一直困扰着我:最后的米粒计数结果看起来是从任何位置开始的,这样如何才能确保我们能够从图像左上角开始,延续到右下角结束呢?

主要思路

我的主要思路是,从代号矩阵(L 记录米粒坐标)中统计出每个米粒的横纵坐标位置,并将其存储在一个元胞数组1中。然后,我们提取这个矩阵中的横坐标或纵坐标的最小值(根据排序方式选择横向或纵向)并存储在另一个元胞数组2中。

接下来,我们依次遍历数组2,针对最小值所在的行,找到元胞数组1中对应的米粒坐标,将其赋值到数组2中。这一步完成后,元胞数组2就包含了按照从左到右或从上到下的顺序排列的米粒坐标。

可能有点抽象,我们直接来看代码实现:

程序设计

以下是实现从左到右排序的具体代码示例:

% 从左到右依次计数n = 元胞数组大小RC = zeros(n, 2); % 初始化存储横纵坐标的元胞数组for k = 1:1:n    [r, c] = find(L == k);    RC(k, 1) = r; % 第k个米粒的横坐标    RC(k, 2) = c; % 第k个米粒的纵坐标end% 提取坐标矩阵的最小值(行最小值)row_min = zeros(n, 1);for jj = 1:1:n    row_min(jj, 1) = min(RC(jj, 1));end% 根据最小值对RC排序并赋值给RC2RC2 = zeros(n, 2);for jjj = 1:1:n    [~, kkk] = min(row_min); % 找到最小值的行索引    RC2(jjj, 1) = RC(kkk, 1);    RC2(jjj, 2) = RC(kkk, 2);end% 生成排序后的图像figureimshow(f);title('按顺序排序')hold onfor k = 1:1:n    r = RC2(k, 1);    c = RC2(k, 2);    rbar = mean(r); % 计算均值纵坐标    cbar = mean(c); % 计算均值横坐标    plot(cbar, rbar, 'Marker', 'o', 'MarkerEdgeColor', 'k', 'MarkerFaceColor', 'k', 'MarkerSize', 10); % 标注顺序号    plot(cbar, rbar, 'Marker', '*', 'MarkerEdgeColor', 'w'); % 标注排序标志    text(cbar, rbar, num2str(k), 'Color', 'red', 'FontSize', 14); % 标注序号endhold off

你可以看到,图像中米粒的大小按从左到右的顺序排列了。这也意味着从上到下的排列方式只需要将RC 矩阵的列和行交换位置即可实现。比如,将RC(jj, 1)改为RC(jj, 2),就可以实现自上而下的排序效果。

总结

通过上述方法,我们成功实现了从图像左上角到右下角的米粒坐标排序。这无疑为后续的图像分析和处理提供了有力的基础。希望以上内容能对你有所帮助!

转载地址:http://qrzrz.baihongyu.com/

你可能感兴趣的文章
MongoDB出现Error parsing command line: unrecognised option ‘--fork‘ 的解决方法
查看>>
mxGraph改变图形大小重置overlay位置
查看>>
MongoDB可视化客户端管理工具之NoSQLbooster4mongo
查看>>
Mongodb学习总结(1)——常用NoSql数据库比较
查看>>
MongoDB学习笔记(8)--索引及优化索引
查看>>
mongodb定时备份数据库
查看>>
mppt算法详解-ChatGPT4o作答
查看>>
mpvue的使用(一)必要的开发环境
查看>>
MQ 重复消费如何解决?
查看>>
mqtt broker服务端
查看>>
MQTT 保留消息
查看>>
MQTT 持久会话与 Clean Session 详解
查看>>
MQTT工作笔记0007---剩余长度
查看>>
MQTT工作笔记0009---订阅主题和订阅确认
查看>>
Mqtt搭建代理服务器进行通信-浅析
查看>>
MS Edge浏览器“STATUS_INVALID_IMAGE_HASH“兼容性问题
查看>>
ms sql server 2008 sp2更新异常
查看>>
MS UC 2013-0-Prepare Tool
查看>>
MSBuild 教程(2)
查看>>
msbuild发布web应用程序
查看>>