【OpenCV实现图像:用OpenCV图像处理技巧之白平衡算法2】

文章目录

    • 概要
    • Gray-world Algotithm
    • Ground Truth Algorithm
    • 结论:

概要

随着数字图像处理技术的不断发展,白平衡算法成为了图像处理中一个关键的环节。白平衡的目标是校正图像中的颜色偏差,使得白色在图像中呈现真实的白色,从而提高图像的质量。
常用的白平衡算法:White Patch、Gray World、和 Ground Truth 算法

White Patch算法:
White Patch算法基于假设:图像中存在一个最亮的区域,该区域应该是白色的。该算法通过检测图像中最亮的区域并调整整个图像的色调来实现白平衡。White Patch算法适用于通用颜色校正,因为它相对简单且在许多情况下表现良好。

Gray World算法:
Gray World算法假设图像中的平均颜色应该是灰色的,通过调整图像的色调来使平均颜色趋近于灰色。这种算法对于一些场景中的光照条件变化较大的图像表现较好,适用于通用颜色校正。它在实现上相对简单,计算量也较小。

Ground Truth算法:
Ground Truth算法是一种专业应用的白平衡算法,它依赖于图像中有参考白色补丁的信息。通过分析这些参考白色补丁的颜色信息,算法可以更准确地进行白平衡校正。这种算法适用于对颜色要求较高、有参考标准的专业应用,例如医学影像、卫星图像等领域。

Gray-world Algotithm

灰色世界算法是一种白平衡算法,其原理基于假设图像的平均颜色应该是灰色的。在实现中,算法首先计算图像的平均亮度以及每个颜色通道的平均亮度。然后,通过计算亮度比例,对每个颜色通道进行相应的调整,以校正颜色映射关系。最终,通过灰色世界校正,图像呈现更为真实和自然的颜色。

该算法对于一些场景中光照条件变化较大的图像表现较好,是一种简单而有效的白平衡方法。通过调整图像的颜色映射关系,灰色世界算法能够提高图像的色彩准确性,使得图像更符合人眼感知的自然色彩。

import cv2
import matplotlib.pyplot as plt

def gray_world(image_path):
    # 读取图像
    image = cv2.imread(image_path)

    # 转换图像颜色通道顺序(OpenCV使用BGR,而matplotlib使用RGB)
    image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)

    # 计算图像的平均亮度
    avg_brightness = image.mean()

    # 计算每个颜色通道的平均亮度
    avg_channel_brightness = image.mean(axis=(0, 1))

    # 计算亮度比例,并相应地调整每个颜色通道
    image_grayworld = ((image * (avg_brightness / avg_channel_brightness)).clip(0, 255).astype(int))

    # 绘制原始图像和灰色世界校正后的对比图
    fig, ax = plt.subplots(1, 2, figsize=(14, 10))
    ax[0].imshow(image)
    ax[0].set_title('原始图像')
    ax[0].axis('off')

    ax[1].imshow(image_grayworld)
    ax[1].set_title('灰色世界校正后的图像')
    ax[1].axis('off')

    plt.show()

# 调用函数应用灰色世界算法
# Use a raw string for the file path
gray_world('4444.png')


在这里插入图片描述
对于灰色世界算法,以下是其优缺点的总结:

优点:

简单且计算高效: 灰色世界算法是一种简单直观的颜色校正方法,计算过程相对高效。

合理性假设: 算法基于图像的平均颜色应该是灰色的合理性假设。在许多场景中,这个假设是成立的,因为在典型的场景中,整体色调趋于中性。

缺点:

对单一主色敏感: 该算法可能对大面积存在的单一主色较为敏感,导致颜色平衡算法无法正常工作。如果图像中存在大块的单一颜色,算法可能会偏向调整其他颜色,而对这个主色不敏感。

不总是正确的假设: 灰色世界算法的核心假设是图像的平均颜色应该是灰色的,然而,在某些场景中,这个假设并不总是正确的。例如,如果图像中有很强的色调偏移或特殊照明条件,灰色世界算法可能产生不理想的结果。

Ground Truth Algorithm

接着我们来介绍最后一种白平衡常用的算法 Ground Truth Algorithm,该算法需要图像中已知对象的颜色作为参考色。它根据此参考色来调整颜色通道以更正颜色投射关系

import cv2
import matplotlib.pyplot as plt
from matplotlib.patches import Rectangle

def ground_truth(image, img_patch, mode='mean'):
    # 使用均值或最大值来进行颜色校正
    if mode == 'mean':
        image_gt = ((image * (img_patch.mean() / image.mean(axis=(0, 1)))).clip(0, 255).astype(int))
    elif mode == 'max':
        image_gt = ((image * 1.0 / img_patch.max(axis=(0, 1))).clip(0, 1))
    else:
        raise ValueError("Invalid mode. Use 'mean' or 'max'.")

    # 绘制原始图像和Ground Truth校正后的对比图
    fig, ax = plt.subplots(1, 2, figsize=(14, 10))
    ax[0].imshow(image)
    ax[0].set_title('原始图像')
    ax[0].axis('off')

    ax[1].imshow(image_gt)
    ax[1].set_title('Ground Truth校正后的图像')
    ax[1].axis('off')

    plt.show()

# 读取图像
image = cv2.imread('4444.png')
image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)

# 选择参考色块的区域
img_patch = image[800:850, 1800:1850, :]

# 显示图像和参考色块的矩形框
fig, ax = plt.subplots(figsize=(10, 10))
ax.set_title('参考块在红色矩形框内')
ax.imshow(image)
ax.add_patch(Rectangle((1800, 800), 50, 50, edgecolor='r', facecolor='none'))

# 调用 Ground Truth Algorithm
ground_truth(image, img_patch, mode='mean')

在这里插入图片描述

结论:

三种白平衡算法各有优劣,选择适当的算法取决于应用场景的具体需求和假设。White Patch和Gray World算法适用于通用颜色校正,而Ground Truth算法更适合专业领域,特别是需要高精度白平衡的场景。在实际应用中,根据图像的特性和应用要求选择合适的白平衡算法,有助于提高图像质量和信息准确性

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/136434.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

transfomer模型——简介,代码实现,重要模块解读,源码,官方

一、什么是transfomer Transformer是一种基于注意力机制(attention mechanism)的神经网络架构,最初由Vaswani等人在论文《Attention Is All You Need》中提出。它在自然语言处理(NLP)领域取得了巨大成功,特…

虚拟机CentOS 8 重启后不能上网

情况说明:原本虚拟机是可以上网的,然后嘚一下,重启后,连接不上网络,完了,上网查找一堆质料,我的连接方式是桥接模式(复制物理网络连接状态)。 好,有人说是vmn…

Git基本概念和使用方式

Git 是一种版本控制系统,用于管理文件版本的变化。以下是其基本概念和使用方式: 仓库(repository):Git 存储代码的地方,可以理解为一个项目的文件夹。提交(commit):Git …

【Go入门】struct类型

【Go入门】struct类型 struct Go语言中,也和C或者其他语言一样,我们可以声明新的类型,作为其它类型的属性或字段的容器。例如,我们可以创建一个自定义类型person代表一个人的实体。这个实体拥有属性:姓名和年龄。这样…

前端开发引入element plus与windi css

背景 前端开发有很多流行框架,像React 、angular、vue等等,本文主要讲vue 给新手用的教程,其实官网已经写的很清楚,这里再啰嗦只是为了给新手提供一个更加简单明了的参考手册。 一、打开element plus官网选则如图所示模块安装命令…

c语言练习第11周(1~5)

数列 1 1 2 3 5 8 13 21 ... 被称为斐波纳数列。 输入若干个正整数N,输出这个序列的前 N 项的和。 题干数列 1 1 2 3 5 8 13 21 ... 被称为斐波纳数列。 输入若干个正整数N,输出这个序列的前 N 项的和。输入样例3 5 4 1输出样例…

【第七章】软件设计师 之 程序设计语言与语言程序处理程序基础

文章底部有个人公众号:热爱技术的小郑。主要分享开发知识、学习资料、毕业设计指导等。有兴趣的可以关注一下。为何分享? 踩过的坑没必要让别人在再踩,自己复盘也能加深记忆。利己利人、所谓双赢。 1、前言 正规式 2、编译过程 编译型&…

【操作系统】4.2 文件系统

📢:如果你也对机器人、人工智能感兴趣,看来我们志同道合✨ 📢:不妨浏览一下我的博客主页【https://blog.csdn.net/weixin_51244852】 📢:文章若有幸对你有帮助,可点赞 👍…

如何有效的保护Windows登录 安当加密

为了有效保护Windows安全登录,以下是一些建议: 使用强密码:强密码是保护Windows登录安全的重要措施之一。确保密码包含大写字母、小写字母、数字和特殊字符,长度至少为8位,并且不要使用容易猜到的单词或短语。启用多因…

pointnetgpd复现

参考: Installation Instructions — Dex-Net 0.2.0 documentation Install git clone https://github.com/lianghongzhuo/PointNetGPD.git 添加环境变量 gedit ~/.bashrc #添加下面这一行 export PointNetGPD_FOLDER$HOME/code/PointNetGPD #然后source source…

SLAM从入门到精通(SLAM落地的难点)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 在所有的slam算法中,基于反光柱的激光slam和基于二维码的视觉slam是落地最彻底的两种slam方法。和磁条、色带等传统导航方式相比较&…

U-Mail邮件系统三大安全措施,防止信息泄露!

在当信息化高速发展的今天,国内很多企业业务流程对OA系统、CRM系统、ERP系统、邮件系统等办公应用依赖度越来越高。这些办公应用给企业带来便利的同时也伴随着越来越多的信息安全问题,而在日常的办公场景中,由于内部员工非法泄漏或黑客入侵导…

Flowable 外部表单

内置表单需要在每个节点中去配置,当如果多个节点使用同一套表单属性就要配置多次比较麻烦,修改的时候也要修改多次,外部表单可以定义一次,然后其它节点都去引用同一个表单属性。 外部表单需要定义一个.form后缀的文件。 外部表单…

运行pytest时,给出警告 PytestConfigWarning: Unknown config option: result_log

问题:在ini中配置了一些选项后运行pytest,会出现下面的警告信息 解决:在ini中增加配置:addopts -p no:warnings

【Git】的分支与版本

前言 Git 的分支是指将代码库从某一个特定的提交记录开始的一个独立的开发线,也可以理解为是一种代码开发的并行方式。分支在 Git 中的使用非常广泛,它可以让多人在同一个代码库中并行开发,同时也能够很方便地进行代码版本控制和管理。 Git …

Python 多进程多线程

多任务 并发:在一段时间内交替执行多个任务 并行:在一段时间内同事一起执行多个任务 进程 Process 进程:一个程序运行在系统之上, 便称这个程序喂一个运行进程,并分配进程ID方便系统管理。操作系统进行资源分配和调…

【多线程】

文章目录 概念一、线程的生命周期图二、线程的创建方式一方式二线程API线程优先级sleep阻塞守护线程多线程并发安全问题 总结 概念 线程:一个顺序的单一的程序执行流程就是一个线程。代码一句一句的有先后顺序的执行。多线程:多个单一顺序执行的流程并发运行。造成"感官上…

JavaWeb Day10 案例 准备工作

目录 一、需求说明 二、环境搭建 (一)数据库 (二)后端 ①controller层 1.DeptController.java 2.EmpController.java ②mapper层 1.DeptMapper.java 2.EmpMapper.java ③pojo层 1.Dept.java 2.Emp.java 3.Result.ja…

Python之函数进阶-生成器函数

Python之函数进阶-生成器函数 生成器函数 Python中有2种方式构造生成器对象: 生成器表达式生成器函数 函数体代码中包含yield语句的函数与普通函数调用不同,生成器函数调用返回的是生成器对象 普通函数调用,函数会立即执行直到执行完毕。 生成器函数…

linux gdb 调试 常见调试命令介绍+总结

1.调试前准备 -g gcc arcg.c -g -oO -o app //必须添加-g 2.调试 gdb gdb app 3.常见调试命令 set args 1 2 3 4 5 6 //设置参数 show args //查看参数 3.1执行程序 1.start2. run gdb app set args 1 2 3 4 5 start //执行一行 c //继续执行 q…