opencv 白平衡

目录

python 随机白平衡增强:


这个可以参考:

python opencv白平衡算法_基于图像分析的偏色检测及颜色校正方法 :param img: cv2.imread读取的图片数据 :-CSDN博客


OpenCV 图像白平衡算法(相机自动白平衡)

彩色相机内部有三个CCD电子耦合元件,分别用来感受红绿蓝三中颜色的光线,默认情况下,三个颜色的感光电路信号的放大比例是1:1:1的。在理想的拍摄环境下,纯白色的RGB分量按照1:1:1的比例放大之后,得到的是没有偏色的白色,当在非理想的环境光条件下,白色成像出来的效果会偏向环境光的颜色,而不是纯白色。

相机的自动白平衡就是要通过改变RGB感光电路信号的放大比例,让受环境光影响的白色还原成纯白色,保证在各种光线条件下,成像色彩跟物体真实的色彩保持一致

常用的一种自动白平衡算法是灰度世界法,它假设对于一副色彩丰富的图像,图像上RGB三个分量的平均值趋于同一个灰度值,一般取这个灰度值的大小为RGB三分量的平均值。

python 随机白平衡增强:



import cv2
import numpy as np


def random_color_augmentation(image):
    # 将图像从BGR颜色空间转换为HSV颜色空间
    hsv_image = cv2.cvtColor(image, cv2.COLOR_BGR2HSV)

    # 随机生成色调、饱和度和亮度的增强系数
    hue_shift = np.random.randint(-10, 10)
    saturation_scale = np.random.uniform(0.8, 1.2)
    value_scale = np.random.uniform(0.8, 1.2)

    # 调整色调
    hsv_image[:, :, 0] = (hsv_image[:, :, 0] + hue_shift) % 180

    # 调整饱和度和亮度
    hsv_image[:, :, 1] = np.clip(hsv_image[:, :, 1] * saturation_scale, 0, 255)
    hsv_image[:, :, 2] = np.clip(hsv_image[:, :, 2] * value_scale, 0, 255)

    # 将图像从HSV颜色空间转换回BGR颜色空间
    enhanced_image = cv2.cvtColor(hsv_image, cv2.COLOR_HSV2BGR)

    return enhanced_image

# 读取图像
image = cv2.imread('aaa.png')

while True:
# 进行白平衡处理
    balanced_image = random_color_augmentation(image)

    # 显示原始图像和处理后的图像
    cv2.imshow('Original Image', image)
    cv2.imshow('Balanced Image', balanced_image)
    cv2.waitKey(0)

以下是OpenCV实现的灰度世界法:

python:

import cv2 as cv

# import numpy as np


# 读取图像

img = cv.imread(r'F:\images\11.jpg')

r, g, b = cv.split(img)

r_avg = cv.mean(r)[0]

g_avg = cv.mean(g)[0]

b_avg = cv.mean(b)[0]


# 求各个通道所占增益

k = (r_avg + g_avg + b_avg) / 3

kr = k / r_avg

kg = k / g_avg

kb = k / b_avg


r = cv.addWeighted(src1=r, alpha=kr, src2=0, beta=0, gamma=0)

g = cv.addWeighted(src1=g, alpha=kg, src2=0, beta=0, gamma=0)

b = cv.addWeighted(src1=b, alpha=kb, src2=0, beta=0, gamma=0)


balance_img = cv.merge([b, g, r])

c++

#include <highgui/highgui.hpp>

#include <imgproc/imgproc.hpp>


using namespace cv;


int main()

{

Mat imageSource = imread("02.jpg");

imshow("原始图像", imageSource);

vector<Mat> imageRGB;


//RGB三通道分离

split(imageSource, imageRGB);


//求原始图像的RGB分量的均值

double R, G, B;

B = mean(imageRGB[0])[0];

G = mean(imageRGB[1])[0];

R = mean(imageRGB[2])[0];


//需要调整的RGB分量的增益

double KR, KG, KB;

KB = (R + G + B) / (3 * B);

KG = (R + G + B) / (3 * G);

KR = (R + G + B) / (3 * R);


//调整RGB三个通道各自的值

imageRGB[0] = imageRGB[0] * KB;

imageRGB[1] = imageRGB[1] * KG;

imageRGB[2] = imageRGB[2] * KR;


//RGB三通道图像合并

merge(imageRGB, imageSource);

imshow("白平衡调整后", imageSource);

waitKey();

return 0;

}

原始图像一,整体图像偏绿色:

白平衡校正后,天空的蓝色和树叶的绿色都得到了很好的还原:

原始图像二,整体偏黄色:

白平衡校正后效果:

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
OpenCV提供了两种方法来进行图像的色彩白平衡。 1. 直方图均衡化法 直方图均衡化法是一种常用的图像增强方法,可以通过增强图像的对比度来改善图像的视觉效果。在进行白平衡处理时,可以使用直方图均衡化法来处理图像的R、G、B三个通道,从而使图像的色彩更加均衡。 具体实现方法如下: ```cpp #include <opencv2/opencv.hpp> using namespace cv; int main() { Mat img = imread("image.jpg"); // 将BGR图像转换为YCrCb图像 Mat img_yuv; cvtColor(img, img_yuv, COLOR_BGR2YCrCb); // 对图像的Y通道进行直方图均衡化 vector<Mat> channels; split(img_yuv, channels); equalizeHist(channels[0], channels[0]); // 将YCrCb图像转换为BGR图像 merge(channels, img_yuv); Mat img_bgr; cvtColor(img_yuv, img_bgr, COLOR_YCrCb2BGR); imshow("Before White Balance", img); imshow("After White Balance", img_bgr); waitKey(0); return 0; } ``` 2. 灰度世界法 灰度世界法是一种常用的白平衡算法,其基本思想是假设整个图像中所有像素的R、G、B三个通道的平均值相等,利用这个假设来进行白平衡处理。具体实现方法如下: ```cpp #include <opencv2/opencv.hpp> using namespace cv; int main() { Mat img = imread("image.jpg"); // 计算图像的R、G、B三个通道的平均值 Scalar avg_bgr = mean(img); // 计算平均值的灰度值 double avg_gray = (avg_bgr[0] + avg_bgr[1] + avg_bgr[2]) / 3; // 计算每个通道需要增加的值 double add_b = avg_gray - avg_bgr[0]; double add_g = avg_gray - avg_bgr[1]; double add_r = avg_gray - avg_bgr[2]; // 将每个通道的像素值加上需要增加的值 Mat img_bgr; Mat channels[3]; split(img, channels); add(channels[0], add_b, channels[0]); add(channels[1], add_g, channels[1]); add(channels[2], add_r, channels[2]); merge(channels, 3, img_bgr); imshow("Before White Balance", img); imshow("After White Balance", img_bgr); waitKey(0); return 0; } ``` 以上两种方法都可以实现图像的白平衡,具体使用哪种方法可以根据实际情况选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AI视觉网奇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值