文章目录

  • 介绍
  • PIL Image生成与读取伪彩色图像
  • 效果图

介绍

伪彩色(Pseudo-color)图像的每个像素的颜色不是由每个基本色分量的数值直接决定,实际上是把像素当成调色板(Palettes)或颜色查找表(Color Look-Up Table,CLUT)的表项入口地址,根据该地址可查找出包含实际R、G、B的强度值,如果图像中的颜色在调色板或彩色查找表中不存在,则调色板会用一个最为接近的颜色来匹配。通过查找出的R、G、B强度值产生的色彩不是图像本身真正的颜色,因此称为伪彩色。

伪彩色图像为位深度为8。

wiki百科:False_color

PIL Image生成与读取伪彩色图像

from PIL import Image
import torch
import numpy as np
import cv2
import matplotlib.pyplot as pltdef create_pseudo_color_image(src_filename, dst_filename):img = cv2.imread(src_filename, 0)num_classes = 21  # num_classes <= len(palette)# create a color pallette, selecting a color for each classpalette = np.array([2 ** 25 - 1, 2 ** 15 - 1, 2 ** 21 - 1])colors = np.array([i for i in range(num_classes)])colors = colors[:, None]colors = colors * palettecolors = (colors % 255).astype("uint8")r = Image.fromarray(img).convert("L")r.putpalette(colors)r.save(dst_filename)def create_pseudo_color_image2(src_filename, dst_filename):img = cv2.imread(src_filename, 0)# create a color pallette, selecting a color for each class# palette = np.array([2 ** 25 - 1, 2 ** 15 - 1, 2 ** 21 - 1])palette = [(0, 0, 0),  # 黑色, 背景(128, 128, 128),  # 灰色, 番茄(255, 255, 255),  # 白色, 黄芒果(255, 0, 0),  # 蓝色, 绿芒果(0, 255, 0),  # 绿色, 土豆(0, 0, 255),  # 红色, 苹果(255, 255, 0),  # 青色, 梨(0, 255, 255)  # 黄色, 猕猴桃]num_classes = len(palette)  # num_classes <= len(palette)colors = np.array([i for i in range(num_classes)])colors = colors[:, None]colors = colors * palettecolors = colors.astype("uint8")r = Image.fromarray(img).convert("L")r.putpalette(colors)r.save(dst_filename)def read_pseudo_color_image(filename):img = Image.open(filename).convert("P")palette = img.getpalette()# print("img.size:", img.size)# print("img.getpalette():", img.getpalette())np_img = np.array(img, dtype=np.int32)print("img.shape:", np_img.shape)label = list(set(np_img.flatten()))print("label:", label)plt.imshow(img)plt.show()if __name__ == '__main__':src_filename = "mask.png"dst_filename = "m.png"create_pseudo_color_image2(src_filename, dst_filename)read_pseudo_color_image(dst_filename)

效果图

PIL Image生成与读取伪彩色图像相关推荐

  1. 利用opencv中的类FileStorage生成和读取XML和YAML文件

    有时候程序中的变量值.字符串.数组等数据也需要独立于源代码本身保存,这个时候就需要用到XML和YAML文件进行保存. OpenCV4提供了用于生成和读取XML文件和YAML文件的类FileStorag ...

  2. qt中生成并读取配置文件Ini

    引言 做项目的时候需要将一些参数设置的更加灵活,通过用户修改来控制程序中一些参数,所以写到了配置文件中方便处理. 实现 下面是配置文件生成.读取的代码. configinfo.h #ifndef CO ...

  3. Python 利用pymupdf将pdf转换为图片并拆分,后通过PIL合并生成一张图片

    文章主要内容主要参考几篇文章并合并在一起的,文章链接依次如下,第二和第三的文章链接是从第一篇文章找到的: (1).https://blog.csdn.net/qq_25115281/article/d ...

  4. 个人用户永久免费,可自动升级版Excel插件,使用VSTO开发,Excel催化剂功能第12波-快速生成、读取、导出条形码二维码...

    根据指定的内容生成对应的条形码或二维码,在如今移动互联网时代,并不是一件什么新鲜事,随便百度一下,都能找到好多的软件或在线网站可以帮我们做到,但细想一下,如果很偶然地只是生成一个两这样的图形,百度一下 ...

  5. iOS开发 - 二维码的生成与读取

    二维码的生成 从iOS7開始集成了二维码的生成和读取功能 此前被广泛使用的zbarsdk眼下不支持64位处理器 生成二维码的步骤: 导入CoreImage框架 通过滤镜CIFilter生成二维码 二维 ...

  6. npz、npy文件生成与读取

    在Numpy中提供了多种文件操作函数,我们可以通过这些文件操作函数,快速地对numpy数组进行存取,十分方便.下面介绍如何生成和读取npz.npy文件 1.np.save()函数可以存储一个np.ar ...

  7. Tensorflow—TFRecord文件生成与读取

    Tensorflow-TFRecord文件生成与读取 微信公众号:幼儿园的学霸 个人的学习笔记,关于OpenCV,关于机器学习, -.问题或建议,请公众号留言; 目录 文章目录 Tensorflow- ...

  8. plist文件生成与读取

    废话不多说,这里简明扼要的介绍一下plist文件的生成与读取 1.创建plist文件 2.代码读取plist文件 NSString *plistPath = [[NSBundle mainBundle ...

  9. Python先生,你好!(4)——npz、npy文件生成与读取

    Python先生,你好!(4)--npz.npy文件生成与读取 (一)前 言 (二)np.save()函数 (1)生成一个数组 (2)储存数组 (三)np.savez()函数 (1)生成两个数组 (2 ...

最新文章

  1. IBM RSA(Rational Software Architect)试用版下载地址
  2. 8分钟学会Consul集群搭建及微服务概念
  3. python长整数相乘_python写的大整数相乘的方法
  4. tensorrt轻松部署高性能dnn推理_实战教程:TensorRT中递归神经网络的介绍(中文字幕)...
  5. [vue] vue性能的优化的方法有哪些?
  6. CString,int,string,char*之间的转换(转)
  7. 蔡司数码视疲劳测试软件_居家办公期间,频繁使用电子数码产品小心患上这种眼病...
  8. 中国最好的AI竞赛落幕,我们整理了一份夺宝攻略
  9. c#执行插入sql 时,报错:异常信息:超时时间已到。在操作完成之前超时时间已过或服务器未响应
  10. Java中的SoftReference和WeakReference有什么区别?
  11. access更新查询非汉族加分_计算机二级Access:如何创建更新查询
  12. No.11软件工程的过程管理
  13. ResNet网络结构详解(Tensorflow2.6.0实现网络结构)
  14. Strut2简单使用
  15. 编译器工具链初步解析
  16. linux下eeprom读写测试,本科毕业设计__基于linux的eeprom的读写控制.doc
  17. linux中shell的小括号、大括号的用法区别
  18. 【算法思想】数学归纳法在算法题中的应用(含例题举例)
  19. Gameloft正式宣布《地牢猎人4 Dungeon Hunter 4》
  20. 分布式协调器ZooKeeper3.4—程序员手册

热门文章

  1. dlg.DoModal()介绍
  2. Unity 光照阴影烘焙
  3. 大人孩子都值得一看的20本经典绘本
  4. 无监督 自监督---综述
  5. Seurat对象查看data错误
  6. 【记录】Mac 预览(Preview)丢失PDF标注恢复
  7. Win2003系统安装SQL Sever2000后1433端口未开放的解释
  8. 市场调研-全球与中国标准振荡器市场现状及未来发展趋势
  9. 用 Vue 改造 Bootstrap,渐进提升项目框架[转]
  10. STM32官方的一些参考手册资料