python+opencv:对比度拉伸/归一化,直方图绘制

在图像处理中,归一化是一个改变像素强度值范围的过程。归一化有时被称为对比度拉伸或直方图拉伸。在更普遍的数据处理领域,如数字信号处理,它被称为动态范围扩展。

在各种应用中,动态范围扩展的目的通常是将图像或其他类型的信号带入感官上更熟悉或正常的范围,因此称为归一化。通常情况下,其动机是为了使一组数据、信号或图像的动态范围达到一致,以避免精神上的分心或疲劳。例如,一份报纸会努力使一期的所有图像都有一个类似的灰度范围。

因此在这里,简单的对图片进行对比度拉伸并且展示拉伸前后的直方图,这样更直观的感受和理解归一化。

首先读入图片

imgSrc = "Kitten.png"
imgKitten = cv2.imread(imgSrc, 0)
plt.imshow(imgKitten, cmap='gray', vmin=0, vmax=255)

这里cv2.imread()的参数flag设置为0这样方便进行灰度图的拉伸。对于彩色图像,flag可以设置为1,这样解码后的图像将按BGR顺序存储信道。

接下来进行对比度拉伸,这里涉及到一个公式:

O = (I - min) \tfrac{255}{max-min}

其中O为最终的图片,I为原始图片,max和min分别为原始图片的最大强度和最小强度。

代码如下:

input_min, input_max = imgKitten.min(), imgKitten.max()

out_new = (imgKitten - input_min) * (255 / (input_max - input_min))
out_new = out_new.astype(np.uint8)

plt.imshow(out_new, cmap='gray', vmin=0, vmax=255)

这里可以检查一下输出图片的最大最小值是不是255和0,若为真,则可以继续绘制直方图

# histogram of low contrast image
gray_level = [0] * 256

for row in imgKitten:
    for col in row:
        gray_level[col] += 1

plt.plot(gray_level)

首先初始化一个size为256全为0的数组,接下来循环像素,填入每个像素的灰度后plt绘制出来,直方图如下:

同样的方法绘制输出图片的直方图,结果如下:

对比度拉伸完成,灰度范围扩大 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值