MATLAB 纹理特征提取:一文读懂 graycomatrix 与 graycoprops

一、前言

在图像处理领域,纹理特征是描述图像像素灰度空间分布规律的核心特征之一,广泛应用于、图像分类、医学影像分析、工业检测等场景。

灰度共生矩阵(GLCM)是提取纹理特征的经典方法,通过统计图像中不同位置像素对的灰度出现规律,量化图像的纹理粗糙程度、均匀性等特性。MATLAB 提供了graycomatrix(生成 GLCM)和graycoprops(提取纹理特征)两个核心函数,零基础也能快速实现纹理特征提取。

本文结合完整可运行代码,讲解 GLCM 原理、函数用法、纹理特征含义,帮你掌握 MATLAB 纹理特征提取流程。

二、核心知识点铺垫

1. 什么是灰度共生矩阵(GLCM)?

灰度共生矩阵描述图像中两个像素的空间位置关系与灰度关系:

  • 定义两个像素的距离方向(0°、45°、90°、135°)
  • 统计满足条件的像素对,其灰度值(i,j)出现的次数 / 概率
  • 最终生成一个N×N矩阵(N 为灰度级数),矩阵值代表对应灰度像素对的共生频率

简单说:GLCM 就是图像纹理的 "数字指纹"

2. 四大核心纹理特征(graycoprops 输出)

graycoprops默认提取 4 个最常用的纹理特征,含义通俗易懂:

  1. 对比度(Contrast):衡量图像局部灰度差异,值越大,纹理越清晰、反差越大
  2. 相关性(Correlation):衡量像素间的线性相关程度,值越大,纹理越规律
  3. 能量(Energy):又称角二阶矩,衡量图像纹理均匀性,值越大,纹理越单一、均匀
  4. 同质性(Homogeneity):衡量纹理局部均匀程度,值越大,图像越平滑

graycomatrix和graycoprops详细用法在MATALB命令提示符下可以使用doc graycomatrix 和doc graycoprops进行获得。

三、程序代码和运行结果

clear all; %清除工作区中的所有变量、函数、MEX文件等

close all;%关闭所有打开的图形窗口(figure窗口)

clc; %清除命令窗口(Command Window)中的所有输出,使窗口变干净

I = imread('circuit.tif');

% 若图像为彩色,则转换为灰度图;若已是灰度则保持不变

if size(I, 3) == 3

I = rgb2gray(I);

end

% 显示原始图像

figure;

subplot(2,2,1);

imshow(I);

title('原始灰度图像');

%% 2. 计算灰度共生矩阵(GLCM)

% 参数说明:

% 'Offset':定义像素对的方向和距离。默认0 1表示水平向右,距离1像素。

% 为获取更全面的纹理,可计算多个方向,本例仅用一个方向演示。

% 'NumLevels':灰度级数,值越小计算越快,但可能损失细节。默认8,这里保持8。

% 'Symmetric':是否对称化GLCM(使矩阵对称),便于特征提取。

offsets = 0 1; % 0度方向,距离1

GLCM = graycomatrix(I, 'Offset', offsets, 'NumLevels', 8, 'Symmetric', true);

%% 3. 从GLCM中计算纹理特征

% graycoprops函数计算对比度、相关性、能量、同质性

stats = graycoprops(GLCM, {'Contrast', 'Correlation', 'Energy', 'Homogeneity'});

% 提取特征值(由于只有一个偏移,stats内各字段均为标量)

contrast = stats.Contrast;

correlation= stats.Correlation;

energy = stats.Energy;

homogeneity= stats.Homogeneity;

%% 4. 显示GLCM矩阵及纹理特征结果

subplot(2,2,2);

imagesc(GLCM);

title('灰度共生矩阵 (GLCM)');

colorbar;

axis square;

xlabel('灰度级 j');

ylabel('灰度级 i');

% 在文本框中显示特征值

subplot(2,2,3,4);

text_str = {

sprintf('对比度 (Contrast) : %.4f', contrast);

sprintf('相关性 (Correlation) : %.4f', correlation);

sprintf('能量 (Energy) : %.4f', energy);

sprintf('同质性 (Homogeneity) : %.4f', homogeneity);

};

text(0.1, 0.8, text_str, 'FontSize', 12, 'FontName', 'FixedWidth');

axis off;

title('纹理特征值 (Offset = 0 1, NumLevels = 8)');

%% 5. 补充:不同方向GLCM的特征对比(可选)

% 计算 0°, 45°, 90°, 135° 四个方向的GLCM,并观察纹理特征变化

offsets_multi = 0 1; -1 1; -1 0; -1 -1;

GLCM_multi = graycomatrix(I, 'Offset', offsets_multi, 'NumLevels', 8, 'Symmetric', true);

stats_multi = graycoprops(GLCM_multi, {'Contrast', 'Correlation', 'Energy', 'Homogeneity'});

% 显示多方向结果

fprintf('\n多方向纹理特征(四个方向取平均):\n');

fprintf('对比度平均: %.4f\n', mean(stats_multi.Contrast));

fprintf('相关性平均: %.4f\n', mean(stats_multi.Correlation));

fprintf('能量平均 : %.4f\n', mean(stats_multi.Energy));

fprintf('同质性平均: %.4f\n', mean(stats_multi.Homogeneity));

撰写博客不宜,如果你觉得本文对你的学习和研究有所帮助,请点赞、关注,欢迎转发!谢谢大家!

相关推荐
“码”力全开18 分钟前
AI视频分析飞书告警常见问题和排查清单
人工智能·音视频·飞书
leoZ23124 分钟前
AI 辅助开发工具链 2026 版深度技术报告:从单点插件到全流程协同的范式重构
人工智能
hy952327 分钟前
从零搭建生产级AI智能客服系统(七):基础优化与一键部署,打造开箱即用的生产级系统
人工智能
深度学习机器35 分钟前
Ghostty终端使用体验
人工智能·命令行
Token炼金师36 分钟前
幂律的预言:Kaplan 与 Chinchilla 的算力账本 —— Scaling Laws 与最优配比
人工智能·深度学习·大模型架构·kv cache·scaling laws
云烟成雨TD1 小时前
LangFlow 1.x 系列【5】可视化编辑页面功能说明
人工智能·python·agent
小宋10211 小时前
Dify 前后端联调踩坑记录:`/console/api/account/profile` 登录失败排查
人工智能·dify
幸福指北1 小时前
现代化智能终端AShell,是否能够替代你的古法终端?让服务器运维更加高效智能化,快来试试看!
人工智能·ai·终端
女神下凡2 小时前
office系列软件 激活破解(office 2019, 2021, 2024)
人工智能·microsoft
2503_931712482 小时前
京东裸眼3D展示——30分钟建模绒感褶皱光泽都能还原
人工智能