基于PS自动对比度、自动色阶算法

PS中选择曲线或色阶命令,然后在弹出的界面中点击选项按钮,会出现如下界面:

注意其中的裁剪(C)/裁剪(P)中的变量,这两个参数是影响自动色阶效果的重要数据,我们以变量LowCut和HighCut来记录它。

步骤:

  1. 分别统计各通道(红/绿/蓝)的直方图
  2. 分别计算各通道按照给定的参数所确定的上下限值。比如对于蓝色通道,我们从色阶0开始向上累加统计直方图,当累加值大于LowCut*所有像素数时,以此时的色阶值计为MinBlue。然后从色阶255开始向下累计直方图,如果累加值大于HighCut*所有像素时,以此时的色阶值计为MaxBlue。绿色通道和红色通道类似。
  3. 判断下MaxBlue是否等于MinBlue,两者相等,则无需校正。
  4. 自动色阶:按照我们刚刚计算出的MinBlue/MaxBlue构建一个映射表,映射表的规则是,对于小于MinBlue的值,则映射为0(实际为阴影所设定的颜色,默认情况下是黑色,对应的RGB分量都为0),对于大于MaxBlue的值,则映射为255(和高光的颜色设置有关),对于介于MinBlue和MaxBlue之间的值,则进行线性映射,默认是映射为0到255之间(为了简便,用线性替代Gamma校正效果也没太大的问题)。用同样的道理,计算出绿色和红色通道的映射表GreenMap和RedMap。
  5. 对各通道图像数据进行映射

自动对比度不同在于:在计算完各通道对应的上下限值后,自动对比度算法首先获取三个通道下限值的最小值,以及上限值的最大值;然后以此为新的上下限,计算映射表; 最后,以这个映射表分别对红绿蓝通道进行处理。

                                           原始图

                                     自动色阶处理后

参考:

【1】https://www.cnblogs.com/Imageshop/archive/2011/11/13/2247614.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
图像自动色阶算法是一种常见的图像处理算法,可以自动调整图像的亮度和对比度,使图像看起来更加清晰和鲜明。下面是一个简单的 C++ 实现: ```c++ #include <iostream> #include <opencv2/opencv.hpp> using namespace std; using namespace cv; int main(int argc, char** argv) { if (argc != 2) { cout << "Usage: ./auto_levels <image_path>" << endl; return -1; } Mat image = imread(argv[1]); if (image.empty()) { cout << "Could not open or find the image" << endl; return -1; } Mat hsv_image; cvtColor(image, hsv_image, COLOR_BGR2HSV); vector<Mat> hsv_channels; split(hsv_image, hsv_channels); // 计算直方图 int hist_size = 256; float range[] = { 0, 256 }; const float* hist_range = { range }; Mat hist; calcHist(&hsv_channels[2], 1, 0, Mat(), hist, 1, &hist_size, &hist_range, true, false); // 计算积分直方图 Mat cum_hist = hist.clone(); for (int i = 1; i < hist_size; i++) { cum_hist.at<float>(i) += cum_hist.at<float>(i - 1); } // 计算最小和最大灰度级 float min_value = cum_hist.at<float>(0); float max_value = cum_hist.at<float>(hist_size - 1); float alpha = 255.0 / (max_value - min_value); // 调整亮度和对比度 Mat lut(1, hist_size, CV_8U); for (int i = 0; i < hist_size; i++) { float value = (cum_hist.at<float>(i) - min_value) * alpha; value = max(0.0f, min(value, 255.0f)); lut.at<uchar>(i) = static_cast<uchar>(value); } Mat equalized_image; LUT(hsv_channels[2], lut, equalized_image); hsv_channels[2] = equalized_image; Mat equalized_hsv_image; merge(hsv_channels, equalized_hsv_image); Mat result_image; cvtColor(equalized_hsv_image, result_image, COLOR_HSV2BGR); imshow("Original Image", image); imshow("Equalized Image", result_image); waitKey(0); return 0; } ``` 这个实现使用了 OpenCV 库,首先将输入图像转换为 HSV 颜色空间,然后计算亮度通道的直方图和积分直方图,调整亮度和对比度,最后将调整后的亮度通道与其他通道合并,将结果转换回 BGR 颜色空间并显示。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值