OpenCV 灰度直方图及熵的计算

目录

一、概述

1.1灰度直方图

1.1.1灰度直方图的原理

1.1.2灰度直方图的应用

1.1.3直方图的评判标准

1.2熵

二、代码实现

三、实现效果

3.1直方图显示

3.2 熵的计算


一、概述

        OpenCV中的灰度直方图是一个关键的工具,用于分析和理解图像的灰度分布情况。直方图的熵是图像分析中的一个重要概念,它用于量化图像中信息的复杂性和不确定性。熵的概念源自信息论,表示系统的不确定性或混乱程度。对于图像直方图而言,熵的高低反映了图像灰度分布的复杂性和信息量。

1.1灰度直方图

        灰度直方图是图像中每个像素灰度值出现的次数或频数的统计结果。它是图像空间域内像素值分布的图形表示,用于描述图像中每种灰度级像素的个数或频率。在灰度直方图中,横坐标表示灰度级(通常范围从0到255,对于8位灰度图像),纵坐标表示该灰度级出现的频率或像素数量。

1.1.1灰度直方图的原理

1.灰度级统计:
        - 灰度直方图通过统计图像中每个灰度级出现的次数来构建。对于一幅8位灰度图像,其灰度级范围为0到255,共256个灰度级。
        - 通过遍历图像的每一个像素,并记录下每个像素的灰度值,然后统计每个灰度值出现的次数,即可得到灰度直方图。
2.反映灰度分布:
        - 灰度直方图直观地反映了图像中灰度的分布情况。如果图像的直方图集中在低灰度值区域,则说明图像比较暗;如果直方图集中在高灰度值区域,则说明图像比较亮。
        - 通过观察灰度直方图,可以了解图像的亮度、对比度以及灰度分布的均匀性等特性。
3.不反映像素位置:
        - 需要注意的是,灰度直方图只反映了图像中灰度值出现的频率,而并未反映这些灰度值像素在图像中的具体位置。也就是说,灰度直方图丢失了像素的空间位置信息。
4.唯一性与非唯一性:
        - 任何一幅图像都可以唯一地对应一幅灰度直方图。但是,不同的图像可能具有相同的灰度直方图。这是因为灰度直方图只关注灰度值的频率分布,而不考虑像素的空间位置。
5.区域直方图:
        - 如果将图像划分为多个区域,并分别计算这些区域的灰度直方图,然后将这些直方图相加,其和将等于原图像的灰度直方图。这一性质有助于对图像进行局部分析。

1.1.2灰度直方图的应用

1.图像分析:
        - 灰度直方图可用于分析图像的对比度、亮度和灰度分布等特性。例如,通过观察直方图的分布范围可以判断图像的亮度;通过直方图的峰值可以判断图像中的主要灰度级。
2.图像增强:
        - 灰度直方图可用于图像增强处理,如直方图均衡化。直方图均衡化的目的是提高图像的对比度,通过拉伸图像的直方图使其分布更加均匀,从而改善图像的视觉效果。
3.图像分割:
        - 灰度直方图还可用于图像分割任务中。例如,可以利用灰度直方图的阈值化方法进行图像的二值化处理;或者通过直方图反投影来查找图像中具有特定灰度值的区域。
        综上所述,OpenCV中的灰度直方图是图像分析、处理和增强中不可或缺的工具之一。通过灰度直方图,我们可以直观地了解图像的灰度分布情况,进而对图像进行更深入的分析和处理。

1.1.3直方图的评判标准

        评判灰度直方图的标准可以帮助我们了解图像的对比度、亮度、动态范围等特性。以下是一些常见的评判标准:
1.对比度:
        - 高对比度图像:灰度直方图会显示在整个灰度范围内的分布,具有较宽的分布区域。
        - 低对比度图像:灰度直方图会集中在较小的灰度范围内,具有较窄的分布区域。
2.亮度:
        - 亮图像:灰度直方图主要集中在高灰度值(右侧)。
        - 暗图像:灰度直方图主要集中在低灰度值(左侧)。
3.动态范围:
        - 宽动态范围:灰度直方图分布在0到255的全灰度范围内。
        - 窄动态范围:灰度直方图分布在较小的灰度范围内,可能只有一部分灰度级别。
4.峰值:
        - 单峰:表示图像中有一个主要亮度区域。
        - 多峰:表示图像中有多个不同的亮度区域,例如图像包含多个不同的物体。
5.均匀性:
        - 均匀分布:灰度直方图较为平坦,表示图像中各个灰度值的像素数量相对均匀。
        - 非均匀分布:灰度直方图具有显著的高峰和低谷,表示图像中某些灰度值的像素数量较多或较少。
6.图像质量:
        - 高质量图像:灰度直方图在整个灰度范围内均匀分布,没有明显的噪声或失真。
        - 低质量图像:灰度直方图可能集中在某些特定区域,显示出噪声、失真或压缩伪影。

1.2熵


        在OpenCV中,直方图的熵是图像分析中的一个重要概念,它用于量化图像中信息的复杂性和不确定性。熵的概念源自信息论,表示系统的不确定性或混乱程度。对于图像直方图而言,熵的高低反映了图像灰度分布的复杂性和信息量。
1.熵值较高:
        - 当图像的直方图熵值较高时,意味着图像中灰度级的分布较为均匀或离散,即图像包含较多的细节和复杂度。这种情况下,图像中的像素值变化较大,信息内容丰富,不易被压缩或简化。
        - 较高的熵值通常与图像的高清晰度和高信息量相关联,表明图像在视觉上可能更加“繁忙”或具有更多的细节。
2.熵值较低:
        - 相反,当图像的直方图熵值较低时,表明图像中灰度级的分布较为集中或单一,即图像包含的细节和复杂度较少。这种情况下,图像中的像素值变化较小,信息内容相对简单。
        - 较低的熵值可能意味着图像较为简单、模糊或缺乏细节,视觉上可能显得较为单调或“空旷”。


二、代码实现

import cv2
import numpy as np
from matplotlib import pyplot as plt


def calculate_histogram(image, point, radius=10):
    # 确定ROI的范围
    x, y = point
    roi = image[max(0, y - radius):min(image.shape[0], y + radius + 1),
          max(0, x - radius):min(image.shape[1], x + radius + 1)]

    # 计算灰度直方图
    histogram = cv2.calcHist([roi], [0], None, [256], [0, 256])
    return histogram


def calculate_entropy(histogram):
    # 归一化直方图
    histogram = histogram / histogram.sum()

    # 计算熵
    entropy = -np.sum(histogram * np.log2(histogram + 1e-9))  # 加1e-9以避免对0取对数
    return entropy


# 读取图像
image_path = "Gray.tiff"  # 确保图像路径正确
image = cv2.imread(image_path, cv2.IMREAD_GRAYSCALE)  # 灰度模式读取

# 指定点
point = (435,671)

# 计算指定点周围半径为10的区域的灰度直方图
histogram = calculate_histogram(image, point,20)

# 计算直方图的熵(均匀性)
entropy = calculate_entropy(histogram)



# 绘制灰度直方图
plt.figure()
plt.title(f"Grayscale Histogram around point {point}")
plt.xlabel("Grayscale value")
plt.ylabel("Frequency")
plt.plot(histogram)
plt.xlim([0, 256])
plt.show()

print(f"Entropy (Uniformity) of the histogram: {entropy}")

# 指定点
point2 = (541,1163)

# 计算指定点周围半径为10的区域的灰度直方图
histogram2 = calculate_histogram(image, point2,20)

# 计算直方图的熵(均匀性)
entropy2 = calculate_entropy(histogram2)

plt.figure()
plt.title(f"Grayscale Histogram around point {point2}")
plt.xlabel("Grayscale value")
plt.ylabel("Frequency")
plt.plot(histogram2)
plt.xlim([0, 256])
plt.show()

print(f"Entropy (Uniformity) of the histogram: {entropy2}")

三、实现效果

3.1直方图显示

两个点位的显示效果

3.2 熵的计算

point = (435,671):Entropy (Uniformity) of the histogram: 0.9858561754226685
point2 = (541,1163):Entropy (Uniformity) of the histogram: 1.9892882108688354

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/774912.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Excel多表格合并

我这里一共有25张表格: 所有表的表头和格式都一样,但是内容不一样: 现在我要做的是把所有表格的内容合并到一起,研究了一下发现WPS的这项功能要开会员的,本来想用代码撸出来的,但是后来想想还是找其他办法,后来找到"易用宝"这个插件,这个插件可以从如下地址下载:ht…

图像处理中的二维傅里叶变换

图像处理中的二维傅里叶变换 问题来源是对彩色图像进行压缩时得出的傅里叶系数的图像如何解释,导入图片,转化为灰度图片: #彩色图片一般是由RGB组成,其实就是3个二维数组叠加而成,当RGB时,彩色图片就会变成…

【线性代数的本质】矩阵与线性变换

线性变化要满足两点性质: 直线(连续的点)在变换后还是直线。原点不变。 假设有坐标轴(基底) i ^ \widehat{i} i 和 j ^ \widehat{j} j ​: i ^ [ 1 0 ] , j ^ [ 0 1 ] \widehat{i}\begin{bmatrix} 1 \…

【leetcode】双指针算法题

文章目录 1.算法思想2.移动零3.复写零方法一方法二 4.快乐数5.盛水最多的容器方法一(暴力求解)方法二(左右指针) 6.有效三角形的个数方法一(暴力求解)方法二(左右指针) 7.两数之和8.…

ONLYOFFICE 8.1版本震撼来袭,让办公更高效、更智能

官网链接: 在线PDF查看器和转换器 | ONLYOFFICE 在线办公套件 | ONLYOFFICE 随着科技的不断发展,办公软件已经成为现代企业提高工作效率、实现信息共享的重要工具。在我国,一款名为ONLYOFFICE的在线办公套件受到了越来越多企业的青睐。今天…

Prompt-Free Diffusion: Taking “Text” out of Text-to-Image Diffusion Models

CVPR2024 SHI Labshttps://arxiv.org/pdf/2305.16223https://github.com/SHI-Labs/Prompt-Free-Diffusion 问题引入 在SD模型的基础之上,去掉text prompt,使用reference image作为生成图片语义的指导,optional structure image作为生成图片…

深入理解【 String类】

目录 1、String类的重要性 2、常用方法 2、1 字符串构造 2、2 String对象的比较 2、3 字符串查找 2、4字符转换 数值和字符串转换: 大小写转化: 字符串转数组: 格式转化: 2、5 字符串替换 2、6字符串拆分 2、7 字符串…

知名品牌因商标痛失市场:114家直营店山寨店7000多家!

奶茶知名品牌“鹿角巷”当年红遍大江南北,是最早的新茶饮品牌,但是当年商标注册存在问题,被同行奶茶品牌抢占了先机,发声明“对大陆商标注册细则不详,在商标注册过程中让假店钻了法律空档”,最夸张的时候全…

python如何不保留小数

1、int() 向下取整(内置函数) n 3.75 print(int(n)) >>> 3 n 3.25 print(int(n)) >>> 3 2、round() 四舍五入(内置函数) n 3.75 print(round(n)) >>> 4 n 3.25 print(round(n)) >>> 3 …

JavaScript(5)——数据类型和类型检测

字符串类型String 通过单引号( )、双引号(" ")或反引号( )都叫字符串,单引号和双引号本质上没有区别,一般使用单引号。 注意: 无论单引号或是双引号必须成对使用单引号和…

人工智能系列-NumPy(二)

🌈个人主页:羽晨同学 💫个人格言:“成为自己未来的主人~” 链接数组 anp.array([[1,2],[3,4]]) print(第一个数组:) print(a) print(\n) bnp.array([[5,6],[7,8]]) print(第二个数组:) print(b) print(\n) print…

PHP智慧门店微信小程序系统源码

🔍【引领未来零售新风尚】🔍 🚀升级启航,智慧零售新篇章🚀 告别传统门店的束缚,智慧门店v3微信小程序携带着前沿科技与人性化设计,正式启航!这个版本不仅是对过往功能的全面优化&a…

【trition-server】运行一个pytorch的ngc镜像

ngc 提供了pytorch容器 号称是做了gpu加速的 我装的系统版本是3.8的python,但是pytorch似乎是用conda安装的3.5的: torch的python库是ls支持gpu加速是真的 英伟达的pytorch的说明书 root@a79bc3874b9d:/opt/pytorch# cat NVREADME.md PyTorch ======= PyTorch is a python …

【C++航海王:追寻罗杰的编程之路】关联式容器的底层结构——AVL树

目录 1 -> 底层结构 2 -> AVL树 2.1 -> AVL树的概念 2.2 -> AVL树节点的定义 2.3 -> AVL树的插入 2.4 -> AVL树的旋转 2.5 -> AVL树的验证 2.6 -> AVL树的性能 1 -> 底层结构 在上文中对对map/multimap/set/multiset进行了简单的介绍&…

C++基础21 二维数组及相关问题详解

这是《C算法宝典》C基础篇的第21节文章啦~ 如果你之前没有太多C基础,请点击👉C基础,如果你C语法基础已经炉火纯青,则可以进阶算法👉专栏:算法知识和数据结构👉专栏:数据结构啦 ​ 目…

短视频父亲:成都柏煜文化传媒有限公司

短视频父亲:镜头背后的温情与力量 在这个信息爆炸的时代,短视频以其短小精悍、直观生动的特点,迅速占据了人们碎片化的时间,成为情感交流与文化传播的重要平台。而在这些纷繁复杂的短视频中,有一类内容尤为触动人心—…

如何让自动化测试更加灵活简洁?

简化的架构对于自动化测试和主代码一样重要。冗余和不灵活性可能会导致一些问题:比如 UI 中的任何更改都需要更新多个文件,测试可能在功能上相互重复,并且支持新功能可能会变成一项耗时且有挑战性的工作来适应现有测试。 页面对象模式如何理…

ELK日志系统和Filebeat采集器的学习总结

ELK是ElasticSerach、Logstash、Kina Logstash负责采集数据,Logstash有三个插件,input、filter、output,filter插件作用是对采集的数据进行处理,过滤的,因此filter插件可以选,可以不用配置。 ElasticSear…

ASUS/华硕枪神5 G533Q G733Q系列 原厂win10系统 工厂文件 带F12 ASUS Recovery恢复

华硕工厂文件恢复系统 ,安装结束后带隐藏分区,一键恢复,以及机器所有驱动软件。 系统版本:Windows10 原厂系统下载网址:http://www.bioxt.cn 需准备一个20G以上u盘进行恢复 请注意:仅支持以上型号专用…

Facebook广告被拒:常见原因以及避免屏蔽的方法

大多数情况下,广告被屏蔽是因为违反了规则,这不仅仅是因为审核因素。有些规则并不明显,也没有在任何地方指定。例如,在广告中使用广告政策中未列出的停用词;审核算法确定照片描绘的模特过于暴露。下面小编将为你介绍Fa…