【OpenCV 例程200篇】206. Photoshop 色阶调整算法

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


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

本例程实现 Photoshop 的色阶调整算法,包括输入动态线性拉伸、伽马变换和输出线性拉伸。

色彩平衡是通过对颜色的调整使图像达到颜色平衡,可以用于调节颜色缺陷或表现效果。

Photoshop 的色阶调整分为输入色阶调整和输出色阶调整。

输入色阶调整有 3 个调节参数:黑场阈值、白场阈值和灰场值:

  • SinS_{in}Sin,输入图像的黑场阈值,input shadows
  • HinH_{in}Hin,输入图像的白场阈值,input hithlight
  • MMM,中间调,灰场调节值,midtone

输入图像中低于黑场阈值的像素置 0 (黑色),高于白场阈值的像素置 255(白色)。灰场调节值默认值 1.0,调节范围 [0.01, 9.99]。灰场调节值增大的效果是加灰降对比度,减小的效果是减灰加对比度。

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

在进行色阶调整时,Photoshop 显示图像的灰度直方图,为用户设置调节参数提供参考。

在这里插入图片描述

输入色阶调整算法,先根据黑场阈值和白场阈值对 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

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

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

对彩色图像的各个颜色通道可以设置统一的白场、黑场和灰场参数;也可以对 R/G/B 各颜色通道分别设置白场、黑场和灰场参数,对各通道进行独立的色阶调节。但这会导致各通道的拉伸曲线不同,因此可能导致偏色。


例程 14.13:Photoshop 色阶调整算法

本例程实现 Photoshop 的色阶调整算法,包括输入动态线性拉伸、伽马变换和输出线性拉伸。

    # 14.13 Photoshop 色阶调整算法def levelAdjust(img, Sin=0, Hin=255, Mt=1.0, Sout=0, Hout=255):Sin = min(max(Sin, 0), Hin-2)  # Sin, 黑场阈值, 0<=Sin<HinHin = min(Hin, 255)  # Hin, 白场阈值, Sin<Hin<=255Mt  = min(max(Mt, 0.01), 9.99)  # Mt, 灰场调节值, 0.01~9.99Sout = min(max(Sout, 0), Hout-2)  # Sout, 输出黑场阈值, 0<=Sout<HoutHout = min(Hout, 255)  # Hout, 输出白场阈值, Sout<Hout<=255difIn = Hin - SindifOut = Hout - Souttable = np.zeros(256, np.uint16)for i in range(256):V1 = min(max(255 * (i-Sin)/difIn,0), 255)  # 输入动态线性拉伸V2 = 255 * np.power(V1/255, 1/Mt)  # 灰场伽马调节table[i] = min(max(Sout+difOut*V2/255, 0), 255)  # 输出线性拉伸imgTone = cv.LUT(img, table)return imgToneimg = cv.imread("../images/buddha01.png", flags=1)  # 读取彩色equ1 = levelAdjust(img, 10, 225, 1.0, 10, 245)equ2 = levelAdjust(img, 10, 225, 1.2, 10, 245)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("colorEqu1"), plt.axis('off')plt.imshow(cv.cvtColor(equ1, cv.COLOR_BGR2RGB))plt.subplot(133), plt.title("colorEqu2"), plt.axis('off')plt.imshow(cv.cvtColor(equ2, cv.COLOR_BGR2RGB))plt.tight_layout()plt.show()

在这里插入图片描述



【本节完】

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

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

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

相关文章

php动态页面加载慢,通过动态加载JS文件提升网站访问速度

相对与HTML,CSS&#xff0c;javascript是最影响浏览器性能的&#xff0c;因为浏览器在遇到《script》标签时&#xff0c;必须等待js代码下载和执行完毕后再执行后面的内容&#xff0c;因此当页面中js文件过多时&#xff0c;网站访问速度明显下降。然而&#xff0c;现在的web应用…

Jsoup解析body片段

假如我们现在有一个HTML片断 (比如. 一个 div 包含一对 p 标签; 一个不完整的HTML文档) 想对它进行解析。这个HTML片断可以是用户提交的一条评论或在一个CMS页面中编辑body部分。 使用Jsoup.parseBodyFragment(String html)方法。 String html "<div><p>Lo…

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

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

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…