【OpenCV 例程200篇】207. Photoshop 色阶自动调整算法

OpenCV 例程200篇 总目录
201. 图像的颜色空间转换
202. 查表快速替换(cv.LUT)
203. 伪彩色图像处理
204. 图像的色彩风格滤镜
205. 调节色彩平衡/饱和度/明度
206. Photoshop 色阶调整算法
207. Photoshop 色阶自动调整算法


【youcans 的 OpenCV 例程200篇】207. Photoshop 色阶自动调整算法

Photoshop 还提供了自动色阶(Auto Levels)功能。

系统可以根据图像的曝光程度、明暗程度自动调节色彩平衡以达到最佳状态。自动色阶和自动对比度功能算法简单,对于一些图像的处理效果非常显著,具有很强的实用性。

Enhance Per Channel Contrast
Maximizes the tonal range in each channel to produce a more dramatic correction. Because each channel is adjusted individually, Enhance Per Channel Contrast may remove or introduce color casts. The Auto Tone command uses this algorithm.

参考文献: Set Auto adjustment options (adobe.com)

在这里插入图片描述

自动色阶调整的实现方法是,系统基于灰度直方图统计结果,自动设置色阶调整所需的参数。

首先设置修剪比例,白场截断比 ClowC_{low}Clow 和黑场截断比 ChighC_{high}Chigh 。默认值 0.1%,通常取 0.1~1.0%。修剪比例的作用是剔除一定比例的最小、最大灰度的像素,以排除个别异常噪声点的干扰。排除异常干扰后的最小、最大灰度值被设为图像中的黑场、白场基准。

具体地,将图像中灰度值最小的、比例为 ClowC_{low}Clow 的像素剔除后的最小灰度值作为黑场阈值,将图像中灰度值最大的、比例为 ChighC_{high}Chigh 的像素剔除后的最大灰度值作为白场阈值。

例如,一个尺寸 100*100 的图像的像素灰度值从小到大排序的结果是:{75, 77,…,240,241},按 0.1%的修剪比例分别剔除最小、最大灰度值后的结果是:{77, …, 240},则设黑场阈值为 77,白场阈值为 240。

为了提高算法效率,可以先将图像转为灰度图像后计算得到灰度直方图,然后按修剪比例查找得到黑场阈值、白场阈值。

灰场调节值 midtone 实际上是实现 Gamma 变换,可以由灰度均值或中间值得到。

具体地,输入色阶调整有 3 个调节参数:黑场阈值 SinS_{in}Sin、白场阈值 HinH_{in}Hin和灰场值MMM

输入色阶调整算法,先根据黑场阈值和白场阈值对 RGB 颜色通道的动态范围进行线性拉伸,再根据灰场调节值进行幂律变换(伽马变换),对发白(曝光过度)或过暗(曝光不足)的图片进行矫正。

V1={0,Vin<Sin255,Vin>Hin255∗(Vin−Sin)/(Hin−Sin),elseV2=255∗(V1/255)1/M\begin{aligned} & V_1 = \begin{cases} 0 &, V_{in}<S_{in} \\ 255 &, V_{in}>H_{in} \\ 255 * {(V_{in}-S_{in})}/{(H_{in}-S_{in})} &, else \end{cases} \\ \\ & V_2 = 255 * (V_1 / 255)^{1/M} \end{aligned} V1=0255255(VinSin)/(HinSin),Vin<Sin,Vin>Hin,elseV2=255(V1/255)1/M

输出色阶调整有 2个调节参数:黑场阈值 SoutS_{out}Sout、白场阈值 HoutH_{out}Hout ,分别对应着输出图像的最小像素值、最大像素值。

输出色阶调整方法是基于动态范围进行线性拉伸:

Vout={0,V2<0255,V2>255Sout+(Hout−Sout)∗V2∗/255,elseV_{out} = \begin{cases} 0 &, V_{2}<0 \\ 255 &, V_{2}>255 \\ S_{out} + {(H_{out}-S_{out})} * V_2 */255 &, else \end{cases} Vout=0255Sout+(HoutSout)V2/255,V2<0,V2>255,else


例程 14.14:Photoshop 色阶自动调整算法

本例程实现 Photoshop 的色阶调整算法,自动设置色阶调整参数,对 R/G/B 各通道的动态范围分别进行拉伸。

    # 14.14 Photoshop 自动色阶调整算法def autoLevels(img, cutoff=0.1):channels = img.shape[2]  # h,w,chtable = np.zeros((1,256,3), np.uint8)for ch in range(channels):# cutoff=0.1, 计算 0.1%, 99.9% 分位的灰度值low = np.percentile(img[:,:,ch], q=cutoff)  # ch 通道, cutoff=0.1, 0.1 分位的灰度值high = np.percentile(img[:,:,ch], q=100 - cutoff)  # 99.9 分位的灰度值, [0, high] 占比99.9%# 输入动态线性拉伸Sin = min(max(low, 0), high - 2)  # Sin, 黑场阈值, 0<=Sin<HinHin = min(high, 255)  # Hin, 白场阈值, Sin<Hin<=255difIn = Hin - SinV1 = np.array([(min(max(255*(i-Sin)/difIn, 0), 255)) for i in range(256)])# 灰场伽马调节gradMed = np.median(img[:,:,ch])  # 拉伸前的中值Mt = V1[int(gradMed)] / 128.  # 拉伸后的映射值V2 = 255 * np.power(V1/255, 1/Mt)  # 伽马调节# 输出线性拉伸Sout, Hout = 5, 250  # Sout 输出黑场阈值, Hout 输出白场阈值difOut = Hout - Souttable[0, :, ch] = np.array([(min(max(Sout + difOut*V2[i]/255, 0), 255)) for i in range(256)])return cv.LUT(img, table)# Photoshop 自动色阶调整算法img = cv.imread("../images/Fig0310b.tif", flags=1)  # 读取彩色图像gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)  # 转换为灰度图像print("cutoff={}, minG={}, maxG={}".format(0.0, gray.min(), gray.min()))# 色阶手动调整equManual = levelsAdjust(img, 63, 205, 0.8, 10, 245)  # 手动调节# 色阶自动调整cutoff = 0.1  # 截断比例, 建议范围 [0.0,1.0]equAuto = autoLevels(img, cutoff)plt.figure(figsize=(9, 6))plt.subplot(131), plt.title("Origin"), plt.axis('off')plt.imshow(cv.cvtColor(img, cv.COLOR_BGR2RGB))plt.subplot(132), plt.title("ManualTuned"), plt.axis('off')plt.imshow(cv.cvtColor(equManual, cv.COLOR_BGR2RGB))plt.subplot(133), plt.title("AutoLevels"), plt.axis('off')plt.imshow(cv.cvtColor(equAuto, cv.COLOR_BGR2RGB))plt.tight_layout()plt.show()

在这里插入图片描述

在这里插入图片描述
从本图可以看出,由于 R,G,B 三个通道单独进行调整,出现了明显的色偏问题。



【本节完】

版权声明:
参考文献: Use the Photoshop Levels adjustment (adobe.com)
youcans@xupt 原创作品,转载必须标注原文链接:(https://blog.csdn.net/youcans/article/details/125373625)
Copyright 2022 youcans, XUPT
Crated:2022-6-20
欢迎关注 『youcans 的 OpenCV 例程 200 篇』 系列,持续更新中
欢迎关注 『youcans 的 OpenCV学习课』 系列,持续更新中

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php 图片不让下载,php简单实现文件或图片强制下载的方法

本文实例讲述了php简单实现文件或图片强制下载的方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;//下载function downregcaseAction() { $file"upload/regcase.jpg"; if(isfile($file)) { header("Content-Type: application/force-download"…

【OpenCV 例程200篇】208. Photoshop 对比度自动调整算法

OpenCV 例程200篇 总目录 【youcans 的 OpenCV 例程200篇】208. Photoshop 对比度自动调整算法 对比度是指图像中明暗区域最亮的白和最暗的黑之间不同亮度层级的测量&#xff0c;差异范围越大代表对比越大。 当对比率达到 120:1 就可以容易地显示生动、丰富的色彩&#xff0c;…

Jsoup根据URL加载一个Document

有时候我们可能希望通过一个url地址&#xff0c;然后提取里面的内容&#xff0c;转换成document对象。 用 Jsoup.connect(String url)方法: Document doc Jsoup.connect("http://baidu.com/").get(); String title doc.title();解说 connect(String url) 方法创建…

java设计模式 外观,精掌握Java设计模式之外观模式(10)

定义通俗地解释&#xff0c;当你打开灯的时候&#xff0c;你只需要嗯一下开关就好了&#xff0c;不需要关心灯泡亮起来的这个流程&#xff0c;同理&#xff0c;打开电脑的时候&#xff0c;嗯一下开机键就好了&#xff0c;也不需要关心电脑是先运行cpu还是内核之类的。这样能让用…

【OpenCV 例程200篇】209. HSV 颜色空间的彩色图像分割

OpenCV 例程200篇 总目录 【youcans 的 OpenCV 例程200篇】209. HSV 颜色空间的彩色图像分割 5.1 HSV 颜色空间的彩色图像分割 HSV 模型是针对用户观感的一种颜色模型。 HSV 颜色空间的各通道分别表示色调&#xff08;Hue&#xff09;、饱和度&#xff08;Saturation&#x…

Jsoup从一个文件加载一个文档

在我们的磁盘里有一个HTML文件&#xff0c;我们需要对它进行解析从中抽取数据或进行修改。 使用静态 Jsoup.parse(File in, String charsetName, String baseUri) 方法&#xff1a; File input new File("/file/input.html"); Document doc Jsoup.parse(input, &…

【OpenCV 例程200篇】210. 绘制直线也会有这么多坑?

OpenCV 例程200篇 总目录 【youcans 的 OpenCV 例程200篇】210. 绘制直线也会有这么多坑&#xff1f; 我不是标题党。 绘制直线当然是最简单的绘图&#xff0c;能有什么坑呢&#xff1f;不信的同学可以直接跳到注意事项。就算你是 OpenCV 大神&#xff0c;如果这 10 个问题点…

PHP配置微信测试号,关于微信开发模式和测试账号

自己刚开始学习微信开发&#xff0c;请帮忙解惑1.微信公众号使用模式分为编辑模式和开发者模式 &#xff0c;两个是互斥的&#xff0c;也就是开启一个另一个就不能用现在我的理解 上边两个模式是由服务器的开启停用区分的&#xff0c;启用即为开发者模式另外&#xff0c;我想知…

Jsoup使用DOM方法来遍历一个文档

要从一个HTML文档要从中提取数据&#xff0c;并了解这个HTML文档的结构需要先将HTML解析成一个Document之后&#xff0c;然后使用类似于DOM的方法进行操作。 File input new File("/file/input.html"); Document doc Jsoup.parse(input, "UTF-8", "…

【OpenCV 例程200篇】211. 绘制垂直矩形

OpenCV 例程200篇 总目录 【youcans 的 OpenCV 例程200篇】211. 绘制垂直矩形 7.1 绘图函数基本参数 OpenCV提供了绘图功能&#xff0c;可以在图像上绘制直线、矩形、圆、椭圆等各种几何图形。 函数 cv.line()、cv.rectangle()、cv.circle()、cv.polylines() 等分别用来在图…

php自动采集入库,Phpcms v9自动采集入库自动发布组件

Phpcms v9自动采集入库自动发布组件是思优CMSYOU技术团队在实际SEO运维运用总结研究出的自动采集入库自动发布文章的组件&#xff0c;实现自动通过Phpcms后台采集模块的采集规则采集文章、并自动入库到对应栏目、入口后自动更新生成内容页自身HTML、栏目页HTML、首页HTML&#…

Jsoup使用选择器语法来查找元素

如果你想使用类似于CSS或jQuery的语法来查找和操作元素&#xff0c;我们可以使用Element.select(String selector) 和 Elements.select(String selector) 方法实现&#xff1a; File input new File("html path"); Document document Jsoup.parser(input, "U…

【OpenCV 例程200篇】212. 绘制倾斜的矩形

OpenCV 例程200篇 总目录 【youcans 的 OpenCV 例程200篇】212. 绘制倾斜的矩形 7.1 绘图函数基本参数 OpenCV提供了绘图功能&#xff0c;可以在图像上绘制直线、矩形、圆、椭圆等各种几何图形。 函数原型&#xff1a; 函数 cv.rectangle() 用来在图像上绘制垂直于图像边界的…

java注释的理解,java注解原理——记录一下自己的理解

最近因为系统可能要更换成java语言&#xff0c;于是每天都在拼命的研究java的相关知识和框架。之前学习注解的时候&#xff0c;没有太深入的去理解它&#xff0c;只是觉得标注一下挺好用&#xff0c;但是现在在学到spring aop的时候&#xff0c;突然发现注解的功能是如此强大。…

Jsoup从元素中抽取属性 文本和HTML

在解析获得一个Document实例对象&#xff0c;并查找到一些元素之后&#xff0c;我们如何取得在这些元素中的数据呢&#xff1f;&#xff1f;&#xff1f; 使用Jsoup抽取属性&#xff0c;一般方法如下&#xff1a; 1.要取得一个属性的值&#xff0c;可以使用Node.attr(String k…

CSDN 技能树使用体验与产品分析(1)

文章目录1. 什么是技能树2. 技能树的产品结构3. 技能树的使用3.1 产品入口3.2 知识点的模块设置3.3 『练习题』模块3.4 『参考资料』模块3.5 『讨论区』与『笔记』模块4. 结束语C 站近期隆重推出了一个新产品『技能树』&#xff0c;这是一个很好的方向。 很早就想写一篇介绍和…

【OpenCV 例程200篇】213. 绘制圆形

OpenCV 例程200篇 总目录 【youcans 的 OpenCV 例程200篇】213. 绘制圆形 7.1 绘图函数基本参数 OpenCV提供了绘图功能&#xff0c;可以在图像上绘制直线、矩形、圆、椭圆等各种几何图形。 7.3 绘制圆形 函数原型&#xff1a; 函数 cv.circle() 用来在图像上绘制圆形。 cv…

Jsoup处理URLs

我们在处理HTML内容时&#xff0c;可能经常会遇到这种问题&#xff0c;需要将html页面里面的链接地址从相对地址转换成绝对地址&#xff0c;如何使用Jsoup来解决这个问题呢&#xff1f; 方法 在你解析文档时确保有指定base URI&#xff0c;然后 使用 abs: 属性前缀来取得包含b…

matlab的fft点数,matlab fft的点数问题

看完下面的&#xff0c;也许你会明白点The FFT functions (fft, fft2, fftn, ifft, ifft2, ifftn) are based on a library called FFTW [3],[4]. To compute an N-point DFT when N is composite (that is, when NN1N2), the FFTW library decomposes the problem using the C…

【OpenCV 例程200篇】214. 绘制椭圆的参数详解

OpenCV 例程200篇 总目录 【youcans 的 OpenCV 例程200篇】214. 绘制椭圆的参数详解 OpenCV提供了绘图功能&#xff0c;可以在图像上绘制直线、矩形、圆、椭圆等各种几何图形。 7.4 绘制椭圆 函数原型&#xff1a; 函数 cv.ellipse() 用来在图像上绘制椭圆轮廓、填充椭圆、椭…