【算法与数据结构】图像白平衡原理及Python-OpenCV简单实现

本文主要是介绍【算法与数据结构】图像白平衡原理及Python-OpenCV简单实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

色温与白平衡

从字面上理解,白平衡的意思是白色的平衡。白平衡是描述显示器中红、绿、蓝三基色混合生成后白色精确度的一项指标,可以解决色彩还原和色调处理的一系列问题。

色温,就是定量的以开尔文温度(K)来表示色彩。它是开尔文通过黑体这一理想光源,在不同温度下,所发出光线的颜色特性来定义的。

开尔文温度和摄氏度之间的关系: 
零下273.15摄氏度被称为绝对零度,就是0K。然后温度每上升一摄氏度,也就是上升1K。

将一个黑体加热之后,随着温度的升高,黑体会先发出红色,然后越来越亮,变成黄光,在变成白光,直至蓝光。

红色是暖色,色温低。
蓝色是冷色,色温高。

白平衡就涉及到了一个相对颜色的问题,比如一张纯白色的白纸,在白炽灯下拍出来颜色是白色的。但是在烛光下拍出来就是偏暖色,在晴朗的蓝天拍出来就偏冷色。那么这张纸到底是什么颜色?、

白平衡的初始技能就是将在不同环境色温中的白色物体都还原成真的白色

工作原理

摄像机内部有三个CCD电子耦合元件,他们分别感受蓝色、绿色、红色的光线,在预置情况下这三个感光电路电子放大比例是相同的,为1:1:1的关系,白平衡的调整就是根据被调校的景物改变了这种比例关系。

比如被调校景物(你认为的白色)的蓝、绿、红色光的比例关系是2:1:1(蓝光比例多,色温偏高),那么白平衡调整后的比例关系为1:2:2,调整后的电路放大比例中明显蓝的比例减少,增加了绿和红的比例,这样被调校景物通过白平衡调整电路到所拍摄的影像,蓝、绿、红的比例才会相同。


代码

import cv2
import numpy as npimg = cv2.imread('111.png',1)
cv2.imshow('111',img)
width = img.shape[1]
height = img.shape[0]
dst = np.zeros(img.shape,img.dtype)#1.计算三通道灰度平均值
imgB = img[:,:,0]
imgG = img[:,:,1]
imgR = img[:,:,2]
bAve = cv2.mean(imgB)[0]
gAve = cv2.mean(imgG)[0]
rAve = cv2.mean(imgR)[0]
aveGray = (int)(bAve + gAve + rAve)/3#2计算每个通道的增益系数
bCoef = aveGray / bAve
gCoef = aveGray / gAve
rCoef = aveGray / rAve#3使用增益系数
imgB = np.floor((imgB * bCoef)) #向下取整
imgG = np.floor((imgG * gCoef))
imgR = np.floor((imgR * rCoef))#4将数组元素后处理
maxB = np.max(imgB)
minB = np.min(imgB)
maxG = np.max(imgG)
minG = np.min(imgG)
maxR = np.max(imgR)
minR = np.min(imgR)
for i in range(0,height):for j in range(0,width):imgb = imgB[i, j]imgg = imgG[i, j]imgr = imgR[i, j]if imgb > 255:imgb = 255if imgg > 255:imgg = 255if imgr > 255:imgr = 255dst[i,j] = (imgb,imgg,imgr)
cv2.imshow('222',dst)
cv2.waitKey(0)

               

参考:

https://blog.csdn.net/helimin12345/article/details/78255669

https://blog.csdn.net/u010468553/article/details/79585447

这篇关于【算法与数据结构】图像白平衡原理及Python-OpenCV简单实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/214145

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形