gamma变换

介绍

又叫幂律变换。伽马变换底层原理是基于光的物理特性,模拟人眼对不同光照条件下的亮度感知。在实际应用中,伽马变换常用于校正图像的亮度和对比度,使其更符合人眼的视觉感知。

形式

s=cr^{\gamma }

其中,c和\gamma是正常数,r为灰度图像的输入值(原来的灰度值),取值范围为[0,1]。s为经过伽马变换后的灰度输出值。c为灰度缩放系数,通常取1。γ为伽马因子大小。控制了整个变换的缩放程度

参数γ的影响

  • γ=1=c:为恒等变换。
  • γ>1:增加图像的对比度,使暗像素变得更亮,同时降低亮像素的亮度。
  • γ<1:降低图像的对比度,使亮像素变得更暗,同时增加暗像素的亮度

  • 伽马值从0.6到0.4时出现更多细节
  • 减少到0.3会增强背景更多细节,对比度开始下降
  • 伽马值等于0.4时,对比度和分辨细节的效果最好

代码实现

import numpy as np
from PIL import Image

def gamma_transform(image, gamma):
    # 将图像转换为NumPy数组
    image_array = np.array(image)

    # 归一化图像
    normalized_image = image_array / 255.0

    # Gamma变换
    transformed_image = np.power(normalized_image, gamma) * 255

    # 限制像素值在0-255之间
    transformed_image = np.clip(transformed_image, 0, 255)

    # 转换为整数类型
    transformed_image = transformed_image.astype(np.uint8)

    return transformed_image

# 加载图像
image_dark = Image.open("E:/dip/DIPshiyan3/dark.jpg").convert('L')
image_light = Image.open("E:/dip/DIPshiyan3/light.tif").convert('L')


# 进行Gamma变换
#gamma_light = gamma_transform(image_light, gamma1)
gamma_dark0_4 = gamma_transform(image_dark, 0.4)
gamma_dark0_5 = gamma_transform(image_dark, 0.5)
gamma_dark0_3 = gamma_transform(image_dark, 0.3)
#gamma_dark0_4_2_5 = gamma_transform(gamma_dark0_4, 2.5)
gamma_light3 = gamma_transform(image_light, 3.0)
gamma_light4 = gamma_transform(image_light, 4.0)
gamma_light5 = gamma_transform(image_light, 5.0)

结果展示

dark.jpg

dark.jpg​​
gamma_dark0_3.jpg
gamma_dark0_4.jpg​​​​
gamma_dark0_5.jpg​​​​​​

 

 light.tif

light.tif
gamma_light3_0.jpg
gamma_light4_0.jpg
gamma_light5_0.jpg
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值