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));

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

相关推荐
BlockChain8881 小时前
AI+区块链深度探索:算法与账本的共生时代
人工智能·算法·区块链
生成论实验室1 小时前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》第一章 源:不可言说的生成之源
人工智能·科技·算法·生活·创业创新
jinglong.zha2 小时前
AI萌宠短剧实战:从0孵化动物IP,用AI制作爆款短视频
人工智能·ai·音视频·网赚教程·萌宠
AI医影跨模态组学2 小时前
如何将CT影像语义特征与肝癌术后辅助TACE获益相关的免疫抑制性肿瘤微环境建立关联,并进一步解释其与预后、PA-TACE治疗响应的机制联系
人工智能·深度学习·论文·医学·医学影像·影像组学
汤姆yu2 小时前
OpenAI GPT-5.5 全面详解与使用
人工智能·openai
xcbrand2 小时前
政府事业机构品牌策划公司哪家可靠
大数据·人工智能·python
逻辑君2 小时前
认知神经科学研究报告【20260020】
人工智能·神经网络·机器学习
2zcode2 小时前
基于低光照增强与轻量型CNN道路实时识别算法研究(UI界面+数据集+训练代码)
人工智能·算法·cnn·低光照增强·自动驾驶技术
萑澈2 小时前
Xiaomi MiMo Orbit 百亿 Token 计划申请保姆级教程
人工智能