python中颜色红色的表示_matplotlib中的绿色到红色的颜色映射,以d的中值为中心...

在我的应用程序中,我正在尽可能地从R转换为原生Python(scipy+matplotlib),最大的任务之一是从R heatmap转换为matplotlib heatmap。This post引导我进行移植。虽然大部分是无痛的,但我仍然不相信彩色地图。

在显示代码之前,有一个解释:在R代码中,我定义了“中断”,即从最低值到10的固定点数,理想情况下以数据的中值为中心。这里的等价物是numpy.linspace:# Matrix is a DataFrame object from pandas

import numpy as np

data_min = min(matrix.min(skipna=True))

data_max = max(matrix.max(skipna=True))

median_value = np.median(matrix.median(skipna=True))

range_min = np.linspace(0, median_value, 50)

range_max = np.linspace(median_value, data_max, 50)

breaks = np.concatenate((range_min, range_max))

这给了我们100分,将用于着色。但是,我不确定如何在Python中做完全相同的事情。目前我有:def red_black_green():

cdict = {

'red': ((0.0, 0.0, 0.0),

(0.5, 0.0, 0.0),

(1.0, 1.0, 1.0)),

'blue': ((0.0, 0.0, 0.0),

(1.0, 0.0, 0.0)),

'green': ((0.0, 0.0, 1.0),

(0.5, 0.0, 0.0),

(1.0, 0.0, 0.0))

}

my_cmap = mpl.colors.LinearSegmentedColormap(

'my_colormap', cdict, 100)

return my_cmap

再往下我会:# Note: vmin and vmax are the maximum and the minimum of the data

# Adjust the max and min to scale these colors

if vmin > 0:

norm = mpl.colors.Normalize(vmin=0, vmax=vmax / 1.08)

else:

norm = mpl.colors.Normalize(vmin / 2, vmax / 2)

这些数据完全是经验性的,所以我想把它改成更有力的数据。如何基于中值对颜色贴图进行规格化,或者是否需要进行规格化?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值