GLCM提取纹理特征还是很厉害的!尤其是和LBP相结合来使用
GLCM中有很多属性可以选择,大家可以选择适合自己数据集的最优的属性组合。
第一步:获取图像的灰度图
"files[i]为输入的图像路径"
"as_grey = True表示转换为灰度图"
"返回图像数组,其中每个值的类型为float64,范围为[0,1],分布不均匀"
image = skimage.data.load(files[i], as_grey = True)
data:image/s3,"s3://crabby-images/7378d/7378d2a7e9e3cefdfde767cc58ec6f34b47fa212" alt=""
[图片上传中...(image-6d351-1589296727210-17)]
data:image/s3,"s3://crabby-images/15c29/15c2915ee8459855fc3b4e0d36a07fa83fc61939" alt=""
第二步:图像有可能相同像素值的点很多,为了增加图像的对比度和清晰度,需要直方图均衡化。
data:image/s3,"s3://crabby-images/422fe/422fef7379c173961aa19ab9cad00ad8efbe15f5" alt=""
"image 为输入的图像数组"
"nbins = 256表示像素值的柱数,可使得图形数组中的数值可在[0,1]之间有256个间隙可选"
"返回图像数组,其中每个值的类型为float64,范围为[0,1],分布均匀"
window = skimage.exposure.equalize_hist(image , nbins = 256)
data:image/s3,"s3://crabby-images/a7bfd/a7bfd4892bb65d469211d24485278880894d2117" alt=""
data:image/s3,"s3://crabby-images/b735d/b735df183a03292c638b22aba88d72492489d678" alt=""
data:image/s3,"s3://crabby-images/653a6/653a63525fd13de09fa1e1cd0de9c5283e8e78c4" alt=""
第三步:float转8位无符号整数,可表示的范围就是[0,255]
"输入:float类型的图像数组,范围为[0,1]"
"输出:图像数组,范围[0,255]"
window = skimage.util.img_as_ubyte(skimage.exposure.equalize_hist(window, 256))
data:image/s3,"s3://crabby-images/20ea1/20ea1288112c2cd4a35167fffa5251e0a252ddaf" alt=""
data:image/s3,"s3://crabby-images/8b257/8b257bfb0aba0c3ff8b889aeb9f7b1f067e1134b" alt=""
data:image/s3,"s3://crabby-images/0c3ca/0c3cabf2e2dc1c71d61ca4a096f85e2448063ba3" alt=""
第四步:转化到[1,8]
"window为输入的图像数组,范围[0,255]"
"bins = np.arange(0, 256, 32)为一维单调数组"
"返回值:x在bins中的位置"
np.digitize(window, bins = np.arange(0, 256, 32))
data:image/s3,"s3://crabby-images/5467e/5467e65c25b8723c873aec2b08f46feaf56753b4" alt=""
data:image/s3,"s3://crabby-images/a9771/a97712461721e67de7ccdc05526f69c6b9773a96" alt=""
data:image/s3,"s3://crabby-images/7340f/7340f8617cfd32e9042599c045babac048c6b981" alt=""
data:image/s3,"s3://crabby-images/a67f4/a67f43c70d0b60ab5cb4728b7592b054e703da1e" alt=""
data:image/s3,"s3://crabby-images/03b94/03b94a79f25232a930656e5258e66e1303f6e6f4" alt=""
第五步:转化到[0,7]即8位无符号整数
wt = (np.digitize(window, np.arange(0, 256, 32))) - 1
data:image/s3,"s3://crabby-images/f55a7/f55a7dac56315108365550d934dee4624419f7e0" alt=""
data:image/s3,"s3://crabby-images/2c1f8/2c1f8a2291dd736a47a5eefd7f8e2d0d682573ab" alt=""
data:image/s3,"s3://crabby-images/7296c/7296ce8e667cbcada49ae22ba6dce7d0f69e0cff" alt=""
网友评论