python画图颜色代码_matplotlib中用于SciPy树状图(Python)的更大的颜色调色板

1586010002-jmsa.png

I'm trying to expand my color_palette in either matplotlib or seaborn for use in scipy's dendrogram so it colors each cluster differently.

Currently, the color_palette only has a few colors so multiple clusters are getting mapped to the same color. I know there's like 16 million RGB colors, so...

How can I use more colors from that huge palette in this type of figure?

#!/usr/bin/python

from __future__ import print_function

import pandas as pd

import matplotlib.pyplot as plt

import numpy as np

import colorsys

from scipy.cluster.hierarchy import dendrogram,linkage,fcluster

from scipy.spatial import distance

np.random.seed(0) #43984

#Dims

n,m = 10,1000

#DataFrame: rows = Samples, cols = Attributes

attributes = ["a" + str(j) for j in range(m)]

DF_data = pd.DataFrame(np.random.randn(n, m),#

columns = attributes)

A_dist = distance.cdist(DF_data.as_matrix().T, DF_data.as_matrix().T)

DF_dist = pd.DataFrame(A_dist, index = attributes, columns = attributes)

#Linkage Matrix

Z = linkage(squareform(DF_dist.as_matrix()),method="average") #metric="euclidead" necessary since the input is a dissimilarity measure?

#Create dendrogram

D_dendro = dendrogram(

Z,

labels=DF_dist.index,

no_plot=True,

color_threshold=3.5,

count_sort = "ascending",

#link_color_func=lambda k: colors[k]

)

#Display dendrogram

def plotTree(D_dendro):

fig,ax = plt.subplots(figsize=(25, 10))

icoord = np.array( D_dendro['icoord'] )

dcoord = np.array( D_dendro['dcoord'] )

color_list = np.array( D_dendro['color_list'] )

x_min, x_max = icoord.min(), icoord.max()

y_min, y_max = dcoord.min(), dcoord.max()

for xs, ys, color in zip(icoord, dcoord, color_list):

plt.plot(xs, ys, color)

plt.xlim( x_min-10, x_max + 0.1*abs(x_max) )

plt.ylim( y_min, y_max + 0.1*abs(y_max) )

plt.title("Dendrogram", fontsize=30)

plt.xlabel("Clusters", fontsize=25)

plt.ylabel("Distance", fontsize=25)

plt.yticks(fontsize = 20)

plt.show()

return(fig,ax)

fig,ax = plotTree(D_dendro) #wrapper I made

#Dims

print(

len(set(D_dendro["color_list"])), "^ # of colors from dendrogram",

len(D_dendro["ivl"]), "^ # of labels",sep="\n")

# 7

# ^ # of colors from dendrogram

# 1000

# ^ # of labels

wwJax.png

解决方案

Most matplotlib colormaps will give you a value given a value between 0 and 1. For example,

import matplotlib.pyplot as plt

import numpy as np

print [plt.cm.Greens(i) for i in np.linspace(0, 1, 5)]

will print

[(0.9686274528503418, 0.98823529481887817, 0.96078431606292725, 1.0),

(0.77922338878407194, 0.91323337695177864, 0.75180316742728737, 1.0),

(0.45176470875740049, 0.76708959481295413, 0.46120723030146432, 1.0),

(0.13402538141783546, 0.54232989970375511, 0.26828144368003398, 1.0),

(0.0, 0.26666668057441711, 0.10588235408067703, 1.0)]

So you no longer need to be restricted to values provided to you. Just choose a colormap, and get a color from that colormap depending upon some fraction. For example, in your code, you could consider,

for xs, ys in zip(icoord, dcoord):

color = plt.cm.Spectral( ys/6.0 )

plt.plot(xs, ys, color)

or something to that effect. I am unsure how exactly you want to display your colors, but I am sure you can modify your code very easily for achieving any color combinations you want ...

Another thing you can try is

N = D_dendro["color_list"]

colorList = [ plt.cm.Spectral( float(i)/(N-1) ) for i in range(N)]

and pass on that colorList.

Play around a bit ...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值