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)), ')']);

实验测试

相关推荐
简简单单做算法1 天前
基于DNA算法的遥感图像加解密matlab仿真
计算机视觉·matlab·dna算法·遥感图像加解密
Naiva1 天前
【数学+MATLAB实验室】第一阶段_函数和图像(一次、二次、指数、对数、正弦、余弦、平移、缩放、叠加)
开发语言·matlab
简简单单做算法2 天前
基于Logistic-Map混沌序列的数字信息加解密算法matlab仿真
matlab·混沌序列·logistic-map·数字信息加解密
简简单单做算法2 天前
基于混沌加密的遥感图像加密算法matlab仿真
图像处理·计算机视觉·matlab·混沌加密·遥感图像加密
fengfuyao9853 天前
基于MATLAB的HHT变换完整实现(含EMD分解与三维时频谱生成)
开发语言·算法·matlab
Deep-w3 天前
【MATLAB】基于 MATLAB 的直流电动机双闭环调速系统建模与仿真
开发语言·算法·matlab
T.i.s4 天前
论文复现8
matlab·fmcw
海神之光4 天前
【语音识别】基于matlab语音MFCC特征提取CNN深度学习语音识别【含Matlab源码 14470期】
matlab
Evand J4 天前
【自适应滤波】基于新息协方差匹配的自适应CKF目标跟踪 MATLAB 实战——在目标跟踪、雷达定位、组合导航和传感器融合等问题
人工智能·matlab·目标跟踪
三行数学4 天前
Matlab之父克利夫·莫勒尔逝世
开发语言·matlab