首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >根据值/数据类型(和保留范围)在matplotlib颜色映射上设置特定的像素颜色

根据值/数据类型(和保留范围)在matplotlib颜色映射上设置特定的像素颜色
EN

Stack Overflow用户
提问于 2021-05-25 22:31:55
回答 1查看 136关注 0票数 0

我有一个CSV数据文件,其中包含(简化)形式的数据:

代码语言:javascript
复制
1.2, 2.2,   o,   s
1.7,   s, 2.4, 2.9
  o, 0.9, 0.1, NaN
1.4,   s, 0.5, 0.9

注意:这包含字符'o',而不是数字零(0)。此文件混合了指示不同类型的“失败”测量的字符。这些矩阵通常比4x4网格大得多。

我想使用matplotlib将这些矩阵绘制在颜色图上,但每个失败的测量值都会在图上分配其自己的颜色,同时保留合法数据的颜色范围。

具有逻辑的东西,例如`

代码语言:javascript
复制
if data == 'o':
   pixel_colour = 'red'

if data == 's':
   pixel_colour = 'black'

if data == 'NaN':
   pixel_colour = 'white'

“我已经看过这个有用的帖子(Changing colours of pixels of plt.imshow() image.)了,但我想不出如何让它来处理异构数据类型。”

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-05-26 01:33:52

要正确回答您的问题,您可以屏蔽不正确的值、规范、映射到RGBA,然后根据需要填充其他颜色

代码语言:javascript
复制
import matplotlib as mpl
import matplotlib.pyplot as plt
import numpy as np

data = np.array([[1.2, 2.2,   'o',   's', 2.5],
                 [1.7,   's', 2.4, 2.9, 1.7],
                 ['o', 0.9, 0.1, 'NaN', 0.4]])
data[data == 'NaN'] = -4000           
data[data == 'o'] = -5000           
data[data == 's'] = -6000
data = data.astype(np.float64)

norm = mpl.colors.Normalize(vmin=0, vmax=3)
cmap = plt.get_cmap('viridis')

# convert from 0-1:
datan = norm(data)
# convert to rgba:
rgba = cmap(datan)
# Fill in colours for the out of range data:
rgba[data==-4000, :] = [1, 1, 1, 1]
rgba[data==-5000, :] = [1, 0, 0, 1]
rgba[data==-6000, :] = [0, 1, 1, 1]

# plot:
fig, ax = plt.subplots()
ax.imshow(rgba)
plt.show()

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67690106

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档