当前位置: 首页 > news >正文

图像白平衡

目录

效果

背景

什么是白平衡?

实现原理

将指定图色调调整为参考图色调主要流程

示例代码


效果

将图一效果转换为图二效果色调:

调整后,可实现色调对换

背景

现有两张图像,色调不一致,对于模型重建会有影响。因此需要将不符合需求的image进行白平衡,色调统一。

什么是白平衡?

图像信号处理算法(Image Signal Process,ISP),对图像传感器输出的原始图像进行处理,得到较好的场景还原效果。

其中,3A算法包括:AWB(自动白平衡)、AE(自动曝光)、AF(自动对焦)。

白平衡White Balance,简称WB,是一种相机设置,用于校正照片或视频中的色彩。

白平衡通过调整红、绿、蓝三种颜色的比例,补偿光源的色片,使得图像中白色看起来是真正的白色,从而使整个图像的色彩更加自然准确。

将图像A转换为图像B的色调,这是一个色彩迁移(Color Transfer的问题。色彩迁移旨在将源图像的颜色风格应用到目标图像中,使得目标图像看起来像是通过类似的光线或色调条件拍摄的。

实现原理

色彩迁移的基本原理是通过分析和调整图像的颜色分布,使源图像的颜色特征(如均值和方差)与目标图像匹配。通常,色彩迁移通过以下几个步骤实现:

  • 颜色空间转换:将RGB图像转换到一种颜色空间,如LAB或LUV。这些颜色空间更适合进行色彩调整,因为它们将亮度与颜色信息分离。
  • 统计特征匹配:计算源图像和目标图像在新颜色空间中的统计特征(如均值和方差)。然后,将源图像的颜色分布调整为与目标图像匹配。
  • 颜色映射:将调整后的颜色分布映射回原始颜色空间,生成最终的图像。
  • 颜色空间逆变换:将图像从LAB或LUV颜色空间转换回RGB,以获得最终结果。

将指定图色调调整为参考图色调主要流程

(1)图像从BGR转换到LAB颜色空间(因为LAB空间更适合进行颜色调整操作)

(2)分别计算参考图和源图 的 均值和标准差

(3)对源图进行标准化,并将参考图的均值和标准差 应用到源图

(4)将调整后的LAB图像转换回BGR颜色空间

示例代码

import cv2import numpy as npdef match_color(source, reference):# 将图像从BGR转换为LAB颜色空间source_lab = cv2.cvtColor(source, cv2.COLOR_BGR2Lab)reference_lab = cv2.cvtColor(reference, cv2.COLOR_BGR2Lab)# 计算参考图像的均值和标准差ref_mean, ref_std = cv2.meanStdDev(reference_lab)ref_mean = ref_mean.reshape((1, 1, 3))ref_std = ref_std.reshape((1, 1, 3))# 计算源图像的均值和标准差src_mean, src_std = cv2.meanStdDev(source_lab)src_mean = src_mean.reshape((1, 1, 3))src_std = src_std.reshape((1, 1, 3))# 对源图像进行标准化,并应用参考图像的均值和标准差lab_adjusted = (source_lab - src_mean) * (ref_std / src_std) + ref_mean# 将调整后的LAB图像转换回BGR颜色空间lab_adjusted = np.clip(lab_adjusted, 0, 255).astype(np.uint8)result = cv2.cvtColor(lab_adjusted, cv2.COLOR_Lab2BGR)return result# 读取源图像和参考图像,将image_B色调调整为image_A色调source_image = cv2.imread('image_B.png')reference_image = cv2.imread('image_A.png')# 调整色调result_image = match_color(source_image, reference_image)# 保存结果cv2.imwrite('result_1.jpg', result_image)

http://www.lryc.cn/news/432254.html

相关文章:

  • SAP Business One 与无锡哲讯:携手共创企业数字化未来
  • Unity Adressables 使用说明(五)在运行时使用 Addressables(Use Addressables at Runtime)
  • 什么是死锁,如何解决?
  • 借助ChatGPT三步,完成课题申报书中研究价值部分写作全攻略指南
  • IDEA取消自动选择光标所在行
  • VUE2.0 elementUI el-input-number 数据更新,视图不更新——基础积累
  • JS中this指向问题
  • 大厂面试:小米嵌入式面试题大全及参考答案(130+道 12万长文)
  • React 更新界面
  • JavaSE-易错题集-001
  • 【人工智能学习笔记】1_人工智能基础
  • 【前端】animation动画以及利用vue制作简单的透明度改变动画,包含vue生命周期实现
  • mysql优化案例分享
  • C语言中结构体struct和联合体union的区别
  • Verilog:【8】基于FPGA实现SD NAND FLASH的SPI协议读写
  • 目标检测-RT-DETR
  • 业务资源管理模式语言09
  • Spring Boot + Vue 多级目录的构建详解
  • Android的Launch
  • Deep Ocr
  • 图片验证码
  • 004: VTK读入数据---vtkImageData详细说明
  • 分割千万级,将大文件分割为小件 csv
  • SQL COUNT() 函数深入解析
  • vue3和vue2的双向绑定原理
  • [C++]刷题
  • 职称评审中,论文发表要求?
  • 连续信号的matlab表示
  • centos7.9搭建mysql5.6主从
  • C#通过ACE OLEDB驱动程序访问 Access和 Excel