图像数据处理9

二、灰度变换

2.3 非线性灰度变换

以下式子中使用 f 表示输入图像的像素值,g 表示输出图像的像素值

2.3.1 伽马校正**(Gamma Correction)**

γ 是伽马值,通常大于0。调整 γ 的值可以改变图像的亮度。当 γ<1 时,图像会变亮;当 γ>1 时,图像会变暗。在使用 伽马矫正时需先将输入灰度值r从[0,255]归一化到[0,1],变换后再把输出灰度值g从[0,1]线性映射到[0,255]之间。

python 复制代码
import cv2  
import numpy as np  
  
def gamma_correction(image, gamma):  
    # 构建一个映射表  
    table = np.array([((i / 255.0) ** gamma) * 255 for i in np.arange(0, 256)]).astype("uint8")  
      
    # 应用映射表进行伽马矫正  
    return cv2.LUT(image, table)  
  
# 读取图像  
image = cv2.imread('.jpg')  
  
# 设置伽马值  
gamma = 2.2  
  
# 应用伽马矫正  
corrected_image = gamma_correction(image, gamma)  
  
# 显示原图和矫正后的图像  
cv2.imshow('Original Image', image)  
cv2.imshow('Gamma Corrected Image', corrected_image)  
  
# 等待按键操作后关闭窗口  
cv2.waitKey(0)  
cv2.destroyAllWindows()

2.3.2对数矫正**(Logarithmic Correction)**

其中,c 是一个常数,用于调整对数曲线的形状和位置。对数矫正可以扩展图像中较暗区域的细节,同时压缩较高灰度级的范围。

c值对图像的影响

  1. 亮度调整
    • 当 c 的值较小时,对数曲线的斜率较小,导致图像的整体亮度相对较低,暗部细节得到增强,但亮部可能显得过于暗淡。
    • 当 c 的值较大时,对数曲线的斜率增大,图像的整体亮度提高,亮部细节得到更好的保留,但暗部可能显得不够突出。
  2. 对比度调整
    • c 的值还影响着图像的对比度。较小的 c 值会增强图像的对比度,使暗部和亮部之间的差异更加明显。
    • 较大的 c 值则会降低对比度,使图像看起来更加柔和。
python 复制代码
import cv2
import numpy as np


def logarithmic_correction(image, c=40):
    # 创建一个对数变换的映射表
    table = np.array([c * np.log(1 + i) if i > 0 else 0 for i in np.arange(0, 256)]).astype("uint8")
    # 应用映射表执行对数矫正
    return cv2.LUT(image, table)


# 读取图像
image = cv2.imread('saved_image.jpg')

# 缩小图像(可选)
scale_percent = 50  # 缩小到原图的50%
width = int(image.shape[1] * scale_percent / 100)
height = int(image.shape[0] * scale_percent / 100)
dim = (width, height)
resized_image = cv2.resize(image, dim, interpolation=cv2.INTER_AREA)

# 应用对数矫正
corrected_image = logarithmic_correction(resized_image)

# 水平拼接原图和矫正后的图像
concatenated_image = cv2.hconcat([resized_image, corrected_image])

# 在一个窗口中展示拼接后的图像
cv2.imshow('Original and Logarithmic Corrected Image', concatenated_image)

# 等待按键操作后关闭窗口
cv2.waitKey(0)
cv2.destroyAllWindows()

c=1

c=10

c=40

2.3.3指数矫正**(Exponential Correction)**


其中,b和 k是常数,k的值通常略大于1。该函数能突出图像的亮区域,减弱图像的暗区域。

python 复制代码
import cv2
import numpy as np


def exponential_correction(image, b, k):
    # 将图像数据类型转换为float,以便进行数学运算
    float_image = image.astype(float) / 255.0
    # 应用指数矫正公式
    corrected_image = b * (k ** float_image - 1)
    # 将矫正后的图像值重新缩放到0到255之间,并转换为uint8类型
    corrected_image = np.clip(corrected_image * 255.0, 0, 255).astype(np.uint8)
    return corrected_image


# 读取图像
image = cv2.imread('slpn.jpg', cv2.IMREAD_GRAYSCALE)

# 设置b和k的值
k=1.01
b = 125

# 应用指数矫正
corrected_image = exponential_correction(image, b, k)

# 水平拼接原始图像和矫正后的图像
concatenated_image = cv2.hconcat([image, corrected_image])

# 缩小拼接后的图像
scale_percent = 50  # 缩小到原始尺寸的50%
width = int(concatenated_image.shape[1] * scale_percent / 100)
height = int(concatenated_image.shape[0] * scale_percent / 100)
dim = (width, height)
resized_concatenated_image = cv2.resize(concatenated_image, dim, interpolation=cv2.INTER_AREA)

# 显示拼接并缩小后的图像
cv2.imshow('Original and Corrected Image (Resized)', resized_concatenated_image)
cv2.waitKey(0)
cv2.destroyAllWindows()

总结一下:①伽马校正 常用于校正图像亮度的不均匀性,使图像更加符合人眼的视觉特性。②对数矫正 常用于增强图像的对比度,特别是在暗区域中。③指数矫正常用于改善图像的视觉效果,使图像更加清晰。

注,本人为在校学生,博客是边学边写的,主要是为了巩固知识,如有错误请积极指正。

"本文章中所使用的圣灵谱尼图片来源于网络,版权归属原作者所有。若您认为本文章/作品的使用侵犯了您的权益,请及时与我联系,我将尽快核实并删除相关内容。

相关推荐
xzzd_jokelin2 分钟前
Spring AI 接入 DeepSeek:开启智能应用的新篇章
java·人工智能·spring·ai·大模型·rag·deepseek
简简单单做算法3 分钟前
基于WOA鲸鱼优化的BiLSTM双向长短期记忆网络序列预测算法matlab仿真,对比BiLSTM和LSTM
人工智能·lstm·bilstm·woa-bilstm·双向长短期记忆网络·woa鲸鱼优化·序列预测
web_155342746563 分钟前
性能巅峰对决:Rust vs C++ —— 速度、安全与权衡的艺术
c++·算法·rust
星霜旅人10 分钟前
开源机器学习框架
人工智能·机器学习·开源
资源大全免费分享20 分钟前
清华大学第五版《DeepSeek与AI幻觉》附五版合集下载方法
人工智能
龚大龙33 分钟前
机器学习(李宏毅)——RL(强化学习)
人工智能·机器学习
LaughingZhu38 分钟前
PH热榜 | 2025-02-23
前端·人工智能·经验分享·搜索引擎·产品运营
java_heartLake2 小时前
基于deepseek的AI知识库系统搭建
人工智能·deepseek
阿里云云原生3 小时前
山石网科×阿里云通义灵码,开启研发“AI智造”新时代
网络·人工智能·阿里云·ai程序员·ai程序员体验官
diemeng11194 小时前
AI前端开发技能变革时代:效率与创新的新范式
前端·人工智能