MATLAB图像重心计算

图像重心(或质心)计算是计算机视觉和图像处理领域

应用领域广泛:包括医疗,生物,动画,机器人等。

该文章通过灰度转换->二值化->质心计算

以下是代码中涉及的一些数学概念和公式:

  1. 灰度转换

    • 从RGB到灰度的转换通常是通过加权平均的方式完成的,公式如下: Igray=0.2989⋅R+0.5870⋅G+0.1140⋅BIgray=0.2989⋅R+0.5870⋅G+0.1140⋅B 这里 RR, GG, BB 分别是红、绿、蓝三个颜色通道的强度,IgrayIgray 是转换后的灰度值。
  2. 二值化

    • imbinarize 函数会将灰度图像转换成二值图像,通常基于一个阈值 TT,如果像素值大于 TT 则设置为 1(白色),否则设置为 0(黑色)。这个过程可以用以下伪代码表示:

      复制代码
      if I_gray(x, y) > T then
          binaryImage(x, y) = 1;
      else
          binaryImage(x, y) = 0;
      end
    • 阈值 TT 可以通过不同的算法自动计算,例如Otsu方法。

3.计算

代码示例

Matlab 复制代码
​​​​clc
clear
image = imread('1.png');
grayImage = rgb2gray(image);
binaryImage = imbinarize(grayImage);
binaryImage = ~binaryImage;
stats = regionprops('table', binaryImage, 'Centroid', 'Area');
centroids = stats.Centroid;
areas = stats.Area;
% 选择面积最大的轮廓
[~, largestIdx] = max(areas);
centroid = centroids(largestIdx, :);
% 显示结果
figure;
imshow(image); % 显示原始图像
hold on;
plot(centroid(1), centroid(2), 'r*', 'MarkerSize', 10, 'LineWidth', 2); % 绘制重心
title('Detected Centroid');
hold off;
% 输出重心坐标
disp(['重心坐标: (', num2str(centroid(1)), ', ', num2str(centroid(2)), ')']);

实验测试

相关推荐
bubiyoushang88832 分钟前
基于CLEAN算法的杂波抑制Matlab仿真实现
数据结构·算法·matlab
Evand J1 小时前
【MATLAB例程】雷达测距+测角的二维定位,基于CV运动的EKF和RTS平滑。滤波与平滑后的结果对比、误差分析。附例程
matlab·ekf·扩展卡尔曼滤波·rts平滑
guygg883 小时前
5G PDSCH信道吞吐量MATLAB仿真实现(含信道生成与解调)
开发语言·5g·matlab
yugi9878385 小时前
基于字典缩放的属性散射中心参数提取MATLAB仿真程序
开发语言·matlab
机器学习之心8 小时前
MATLAB基于近红外光谱检测的菠萝含水率预测(多种预处理+PLS)
人工智能·算法·matlab·近红外光谱检测
kaikaile19959 小时前
基于MATLAB的视频行人检测与跟踪系统实现
开发语言·matlab·音视频
ghie909010 小时前
基于MATLAB的多旋翼无人机多机编队仿真实现
开发语言·matlab·无人机
rit843249911 小时前
UVE算法提取光谱特征波长的MATLAB实现与应用
开发语言·算法·matlab
fie888912 小时前
基于MATLAB的时变Copula实现方案
开发语言·matlab
MESMarketing14 小时前
互动分享 | ISO 26262安全分析概览
功能测试·测试工具·安全·网络安全·matlab