前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >局部熵

局部熵

作者头像
裴来凡
发布2022-05-29 09:49:11
7860
发布2022-05-29 09:49:11
举报
代码语言:javascript
复制
from PIL import Image
import numpy as np
from matplotlib import pyplot as plt
plt.rcParams['font.sans-serif']=['SimHei']
plt.rcParams['axes.unicode_minus']=False
def entropy(signal):
        lensig=signal.size
        symset=list(set(signal))
        propab=[np.size(signal[signal==i])/(1.0*lensig) for i in symset]#每个值的概率
        ent=np.sum([p*np.log2(1.0/p) for p in propab])
        return ent
colorIm=Image.open('C:/Users/xpp/Desktop/Lena.png')#读取图像
colorIm=np.array(colorIm)
colorIm=Image.fromarray(colorIm)
greyIm=colorIm.convert('L')
greyIm=np.array(greyIm)
N=3
S=greyIm.shape
E=np.array(greyIm)
#以图像左上角为坐标0点
for row in range(S[0]):
    for col in range(S[1]):
        Left_x=np.max([0,col-N])
        Right_x=np.min([S[1],col+N])
        up_y=np.max([0,row-N])
        down_y=np.min([S[0],row+N])
        region=greyIm[up_y:down_y,Left_x:Right_x].flatten()#返回一维数组
        E[row,col]=entropy(region)
plt.subplot(1,3,1)
plt.imshow(colorIm)
plt.subplot(1,3,3)
plt.imshow(greyIm,cmap=plt.cm.gray)
plt.subplot(1,3,3)
plt.imshow(E,cmap=plt.cm.jet)
plt.xlabel('6x6 邻域熵')
plt.colorbar()
plt.show()

算法:局部熵是将图分成一个个区域,分别计算再融合成信息分布图,有点类似heatmap。熵是体系的混乱的程度,越乱越大。图像熵是图像特征的一种统计形式,反映了图像中平均信息量的多少,能够反映图像各像素点的分布复杂程度。熵越大,图像越清晰。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-11-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 图像处理与模式识别研究所 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档