统计灰度图像的灰度值分布并绘制

1、numpy方法

函数:

numpy.histogram(a, bins=10, range=None, normed=None, weights=None, density=None)

参数说明:

  • a:输入数据数组;
  • bins:指定统计的区间个数,可以是一个整数,也可以是一个数组,默认值为10;
  • range:表示的是范围,范围仅为 (a.min(), a.max());表示统计范围的最小值和最大值,默认值None
  • weights:表示权重。为数组的每个元素指定了权值,histogram()会对区间中数组所对应的权值进行求和
  • density:为True时,返回每个区间的概率密度;为False,返回每个区间中元素的个数

返回:

  • hist 数组。直方图的值,有关可能语义的说明,请参见密度和权重。
  • bin_edges dtype 浮点数组。返回 bin 边 (length(hist)+1) 。

代码示例:

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

# 读取图像
image = cv2.imread(r"D:\Desktop\00aa\1.png", 0)

# 统计灰度值分布
hist, bins = np.histogram(image.flatten(), bins=range(256))

# 绘制直方图
plt.figure(figsize=(10, 6))
plt.bar(bins[:-1], hist, width=1, color='gray')
plt.xlabel('Gray Level')
plt.ylabel('Pixel Count')
plt.title('Gray Level Histogram')
plt.show()

2、OpenCv方法

我们也可以用OpenCv方法:

cv2.calcHist(images, channels, mask, histSize, ranges)

参数:

  • images:原图像。当传入函数时应该用中括号 [] 括起来,例如:[img]
  • channels:如果输入图像是灰度图,它的值就是[0];如果是彩色图像的话,传入的参数可以是[0],[1],[2]它们分别对应着通道B,G,R。
  • mask:掩模图像。要统计整幅图像的直方图就把它设为None。但是如果你想统计图像某一部分的直方图的话,你就需要制作一个掩模图像,并使用它。0为背景,1为需要统计区域。
  • histSize:bins的数目。也应该用中括号括起来,例如:[256]。
  • ranges:像素值范围。通常为[0,256]。

代码示例:

import cv2 as cv
import matplotlib.pyplot as plt

src = cv.imread(r"D:\Desktop\00aa\1.png", 0)  # 直接以灰度图方式读入
img = src.copy()

# 统计灰度图
greyScale_map = cv.calcHist([img], [0], None, [256], [0, 256]).squeeze()

# 绘制灰度图
plt.figure(figsize=(10, 6), dpi=100)
plt.bar(range(len(greyScale_map)), greyScale_map, color='gray')
plt.xlabel('Gray Level')
plt.ylabel('Pixel Count')
plt.title('Gray Level Histogram')
plt.show()

  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

清纯世纪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值