【OpenCV 例程200篇】203. 伪彩色图像处理

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

文章目录

  • 【youcans 的 OpenCV 例程200篇】203. 伪彩色图像处理
      • 什么是伪彩色图像?
      • 函数原型
      • 例程 14.5:灰度图像转换为伪彩色图像
      • 例程 14.7:多光谱合成的伪彩色图像

【youcans 的 OpenCV 例程200篇】203. 伪彩色图像处理


NASA 公布了蟹状星云 (Crab Nebula )的观测图像。茫茫太空,距离我们几亿光年的宇宙真是这样绚丽迷人吗?

NASA 专家撰文指出,蟹状星云彩色照片实际上人工合成的图像,这是不是暗示照片中的彩色是伪造的?

什么是伪彩色图像?

伪彩色图像是指对单色图像进行处理,结果转换得到颜色分量,构造为彩色效果的图像。伪彩色图像在形式和视觉表现为彩色图像,但其所呈现的颜色并非图像的真实色彩重现,仅仅是各颜色分量的像素值合成的结果。

  • (1)一类伪彩色图像是对灰度图像的增强,形成彩色效果。

伪彩色图像增强是指按照特定的准则对灰度图像进行处理,将不同的灰度级按照某种映射关系变换为不同的颜色分量。例如,天气预报中的气象云图,红外测温图像,一般都是伪彩色图像。

人眼的视觉特性,只能分辨 20 级左右的灰度,但可以分辨几千种色调和亮度。通过伪彩色图像增强,可以让灰度图像看起来更清楚,更容易分辨。

将灰度图像进行伪彩色增强,通常是基于一个设定的颜色查找表,将图像像素的灰度值替换为颜色查找表中对应的颜色值。这显然是典型的 LUT 应用场景。

  • (2)另一类伪彩色图像,是多光谱图像的编码合成图像。

光谱图像可以是可见光谱,也可以是红外、紫外、X光或其它信号。这些非可见光谱图像实际上既不是彩色图像,也不是灰度图像,“像素值”往往反映某种检测信号的强度。合成为彩色图像进行显示,只是为了便于观察和分析。

这在天文学观测中十分常用。NASA 公布的绚烂迷人的太空照片,并不是真实世界的色彩还原,而是将多种光谱信号图像进行编码组合和特效处理后,构造出的彩色图像。


函数原型

函数 cv.applyColorMap() 根据色彩映射表,将灰度图像变换为伪彩色图像。

cv.applyColorMap(src, colormap[, dst]) → dst
cv.applyColorMap(src, userColor[, dst]) → dst

参数说明:

  • src:输入图像,8 位灰度图像或彩色图像,cv_8U
  • dst:输出图像,大小和通道数与 src 相同
  • colormap:色彩映射表,OpenCV 自带色彩风格类型的颜色查找表
  • userColor:用户自定义的色彩映射表, 256个元素

注意事项:

  1. 输入图像可以是彩色图像。根据作者的测试,先将输入彩色图像转换为灰度图像,再按色彩映射表进行变换。
  2. 用户自定义的色彩映射表,是 256*3 数组。系统提供的 22种色彩映射表一般已经够用,就别折腾了。
  3. 例程中没有出现 cv.LUT 查表替换,在 cv.applyColorMap 内核中已经应用了查表替换方法。

色彩映射表:

  • OpenCV 提供了 22 种色彩风格类型,类型描述关键字与色彩效果如下图所示。

在这里插入图片描述

  • OpenCV 提供的色彩风格类型与 Matlab、Matplotlib 热图的颜色映射是类似的,描述关键字也是一致的。
    参见:http://matplotlib.org/examples/color/colormaps_reference.html

例程 14.5:灰度图像转换为伪彩色图像

    # 14.5 灰度图像转换为伪彩色图像    gray = cv.imread("../images/Fig0525a.tif", flags=0)  # 读取灰度图像h, w = gray.shape[:2]  # 图片的高度, 宽度# 伪彩色处理pseudo1 = cv.applyColorMap(gray, colormap=cv.COLORMAP_HOT)pseudo2 = cv.applyColorMap(gray, colormap=cv.COLORMAP_PINK)pseudo3 = cv.applyColorMap(gray, colormap=cv.COLORMAP_RAINBOW)pseudo4 = cv.applyColorMap(gray, colormap=cv.COLORMAP_HSV)pseudo5 = cv.applyColorMap(gray, colormap=cv.COLORMAP_TURBO)plt.figure(figsize=(9, 6))plt.subplot(231), plt.axis('off'), plt.title("GRAY"), plt.imshow(gray, cmap='gray')plt.subplot(232), plt.axis('off'), plt.title("cv.COLORMAP_HOT")plt.imshow(cv.cvtColor(pseudo1, cv.COLOR_BGR2RGB))plt.subplot(233), plt.axis('off'), plt.title("cv.COLORMAP_PINK")plt.imshow(cv.cvtColor(pseudo2, cv.COLOR_BGR2RGB))plt.subplot(234), plt.axis('off'), plt.title("cv.COLORMAP_RAINBOW")plt.imshow(cv.cvtColor(pseudo3, cv.COLOR_BGR2RGB))plt.subplot(235), plt.axis('off'), plt.title("cv.COLORMAP_HSV")plt.imshow(cv.cvtColor(pseudo4, cv.COLOR_BGR2RGB))plt.subplot(236), plt.axis('off'), plt.title("cv.COLORMAP_TURBO")plt.imshow(cv.cvtColor(pseudo5, cv.COLOR_BGR2RGB))plt.tight_layout()plt.show()

在这里插入图片描述


例程 14.7:多光谱合成的伪彩色图像

蟹状星云 (Crab Nebula )的观测图像,是由钱德拉 X 射线天文台数据所形成的X射线图、哈勃太空望远镜拍摄的光学图像,和斯必泽空间望远镜拍摄的红外图像合成得到的。

例程结果图中,第一行是 3 种天文观测图像的观测数据图像,图像中的灰度都只是观测的信号强度,而不是实际的物理世界的亮度或灰度。

第二行是分别对 3 种观测图像进行伪彩色变换的结果,如果选择不同的色彩风格可以获得不同的效果。

第三行是将 3 种观测信号合成得到的伪彩色图像,其中左图、中图是简单地将 3 种观测信号分别作为 RGB 的一个色彩通道得到的伪彩色图像,右图是 NASA 公布的多光谱合成伪彩色图像。

虽然 NASA 图像的视觉效果更好,但仍然可以明显地看出,该图也是由第一行 3 种观测数据图像合成的。

在这里插入图片描述

    # 14.7 多光谱编码合成的伪彩色图像# 蟹状星云 (Crab Nebula), 图片来源:# https://www.nasa.gov/mission_pages/chandra/multimedia/photo09-096.htmlcomposite = cv.imread("../images/CrabNebula.png", flags=1)  # 读取多光谱合成图像nebulaOpti = cv.imread("../images/CrabNebula_Optical.jpg", flags=1)  # 读取 OpticalnebulaXray = cv.imread("../images/CrabNebula_Xray.jpg", flags=1)  # 读取 XraynebulaInfr = cv.imread("../images/CrabNebula_Infrared.jpg", flags=1)  # 读取 Infraredh, w = nebulaOpti.shape[:2]  # 图片的高度, 宽度grayOpti = cv.cvtColor(nebulaOpti, cv.COLOR_BGR2GRAY)grayXray = cv.cvtColor(nebulaXray, cv.COLOR_BGR2GRAY)grayInfr = cv.cvtColor(nebulaInfr, cv.COLOR_BGR2GRAY)# 伪彩色处理pseudoXray = cv.applyColorMap(nebulaXray, colormap=cv.COLORMAP_TURBO)pseudoOpti = cv.applyColorMap(nebulaOpti, colormap=cv.COLORMAP_MAGMA)pseudoInfr = cv.applyColorMap(nebulaInfr, colormap=cv.COLORMAP_HOT)# 多光谱编码合成compose1 = np.zeros((h, w, 3), np.uint8)  # 创建黑色图像 BGR=0compose1[:, :, 0] = grayOpti  # Optical -> Bcompose1[:, :, 1] = grayXray  # Xray -> Gcompose1[:, :, 2] = grayInfr  # Infrared -> Rcompose2 = np.zeros((h, w, 3), np.uint8)  # 创建黑色图像 BGR=0compose2[:, :, 0] = grayXray  # Xray -> Bcompose2[:, :, 1] = grayOpti  # Optical -> Gcompose2[:, :, 2] = grayInfr  # Infrared -> R# composite = cv.normalize(nebulaInfr + nebulaOpti, None, 0, 255, cv.NORM_MINMAX)  # 归一化为 [0,255]plt.figure(figsize=(9, 9))plt.subplot(331), plt.axis('off'), plt.title("CrabNebula-Xray")plt.imshow(grayXray, cmap='gray')plt.subplot(332), plt.axis('off'), plt.title("CrabNebula-Optical")plt.imshow(grayOpti, cmap='gray')plt.subplot(333), plt.axis('off'), plt.title("CrabNebula-Infrared")plt.imshow(grayInfr, cmap='gray')plt.subplot(334), plt.axis('off'), plt.title("Xray Pseudo")plt.imshow(cv.cvtColor(pseudoXray, cv.COLOR_BGR2RGB))plt.subplot(335), plt.axis('off'), plt.title("Optical Pseudo")plt.imshow(cv.cvtColor(pseudoOpti, cv.COLOR_BGR2RGB))plt.subplot(336), plt.axis('off'), plt.title("Infrared Pseudo")plt.imshow(cv.cvtColor(pseudoInfr, cv.COLOR_BGR2RGB))plt.subplot(337), plt.axis('off'), plt.title("Spectral composited")plt.imshow(cv.cvtColor(compose1, cv.COLOR_BGR2RGB))plt.subplot(338), plt.axis('off'), plt.title("Spectral composited")plt.imshow(cv.cvtColor(compose2, cv.COLOR_BGR2RGB))plt.subplot(339), plt.axis('off'), plt.title("Composite image")plt.imshow(cv.cvtColor(composite, cv.COLOR_BGR2RGB))plt.tight_layout()plt.show()


【本节完】

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

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

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

相关文章

php post 丢失,php post大量数据时发现数据丢失问题解决方法,post数据丢失_PHP教程...

php post大量数据时发现数据丢失问题解决方法,post数据丢失解决办法:在php.ini中将max_input_vars调大改为5000就可以了原因追查:from的enctype”multipart/form-data”php版本5.6.6问题:部分POST数据接收不到追源代码发现是php中…

Jquery鼠标点击出现文字

点击鼠标左键出现文字效果。 原理解说 1.首先确定你是不是点的鼠标左键&#xff1b; 2.文字效果要出现在你鼠标点击的地方&#xff1b; 3.点击后文字出现一个由下往上的显示效果&#xff1b; 4.点击完成后固定时间内还得消失 效果演示 代码演示 <!DOCTYPE html> <h…

【OpenCV 例程200篇】204. 图像的色彩风格滤镜

OpenCV 例程200篇 总目录 201. 图像的颜色空间转换 202. 查表快速替换&#xff08;cv.LUT&#xff09; 203. 伪彩色图像处理 204. 图像的色彩风格滤镜 205. 调节色彩平衡/饱和度/明度 文章目录【youcans 的 OpenCV 例程200篇】204. 图像的色彩风格滤镜4. 图像的色彩风格滤镜4.1…

php文件夹重命名,PHP重命名和移动目录

PHP重命名目录使用PHP的rename()函数可以重命名目录。如果rename()函数执行成功&#xff0c;则返回true&#xff0c;否则返回false。复制代码PHP重命名目录示例-www.baike369.com$state rename(folder,folder2); // 将folder文件夹重命名为folder2文件夹if($state){echo 重命名…

【OpenCV 例程200篇】205. 调节色彩平衡/饱和度/明度

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

自定义U盘图标

现在几乎人手一个U盘&#xff0c;作为很隐私的东西&#xff0c;U盘的使用场景却非常复杂&#xff0c;经常需要插入各种各样的设备… 那么如何让自己的U盘与众不同&#xff0c;在插入后给人留下深刻的印象呢&#xff1f; 今天就教给大家如何DIY自己的U盘图标。 1. 下载ico图标…

linux opendir php,PHP遍历目录函数opendir()、readdir()、closedir()、rewinddir()总结

在进行PHP编程时&#xff0c;需要对服务器某个目录下面的文件进行浏览&#xff0c;通常成为遍历目录。取得一个目录下的文件和子目录&#xff0c;就需要用到opendir()函数、readdir()函数、closedir()函数和rewinddir()函数。①函数opendir()函数opendir()用于打开指定目录&…

C站 APP 搜索工具使用体验与对比

文章目录0. 对比的 APP1. APP 首页布局2. 搜索页面的设计3. 关键词输入的过程4. 搜索结果的页面5. 搜索内容的展现6. 搜索结果的内容质量6.1 搜索内容质量评分6.2 对搜索内容评价的分析7. 小结0. 对比的 APP 垂直行业 APP&#xff1a;CSDN&#xff0c;稀土掘金&#xff0c;极客…

Jsoup解析HTML字符串

在处理一个html字符串。我们可能需要对其进行解析&#xff0c;修改内容或者提取内容等&#xff0c;那麽我们应该解决这一系列的问题呢&#xff1f;Jsoup可以帮助我们轻松的解决这些问题。 我们可以使用静态Jsoup.parse(String html) 方法或 Jsoup.parse(String html, String b…

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

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

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 个问题点…