6-自动白平衡(灰度世界算法)

1- 算法核心思想

对于一幅有着大量色彩变化的物理场景,其图像的 R、G、B 三个通道的平均值应该趋于相等的灰度值。如果平均值不相等,说明光线导致了偏色,我们需要算出增益系数把它强行拉平。

2- 实现代码

python 复制代码
import  cv2
import numpy as np
'''
使用灰度世界算法进行自动白平衡
'''
def gray_world_white_balance(img):
    # 1. 计算 B, G, R 通道的平均值 (OpenCV 默认格式是 BGR)
    b_avg = np.mean(img[:, :,0])
    g_avg = np.mean(img[:, :,1])
    r_avg = np.mean(img[:, :,2])
    # 2. 计算全局的平均灰度值 (即三个通道均值的均值)
    k = (b_avg + g_avg + r_avg) /3
    # 3. 计算各个通道的增益系数
    kb = k / b_avg
    kg = k / g_avg
    kr = k / r_avg
    # 4. 对每个通道的像素值进行补偿调整
    balanced_img = np.zeros_like(img, dtype=np.float32)
    balanced_img[:, :,0] = img[:, :,0] *kb
    balanced_img[:, :,1] = img[:, :,1] *kg
    balanced_img[:, :,2] = img[:, :,2] *kr
    # 5. 防止数值溢出,将值限制在 0-255 之间,并转回 uint8 类型
    balanced_img = np.clip(balanced_img,0,255).astype(np.uint8)
    return  balanced_img

if __name__=="__main__":
# 读取一张可能会偏色的图片 (请替换为您本地对应的图片路径)   
    original_img = cv2.imread("test2.jpeg")

    # cv2.namedWindow('Original', cv2.WINDOW_AUTOSIZE)
    # cv2.namedWindow('White Balanced', cv2.WINDOW_AUTOSIZE)
    if original_img is not None:
        #执行白平衡处理
        wb_img = gray_world_white_balance(original_img)
        # 显示前后对比       
        cv2.imshow("Original", original_img)
        cv2.imshow("White Balanced", wb_img)
        cv2.waitKey(0)
        cv2.destroyAllWindows()
    else:
        print("图片读取失败,请检查路径。")

3-结果

相关推荐
JieE2128 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2121 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050733 天前
(一)小红的数组操作
算法·编程语言