主頁 > 區塊鏈 > python可視化(4)色板(mpl.colors, colormap, plt.cm, palette)

python可視化(4)色板(mpl.colors, colormap, plt.cm, palette)

2020-09-16 14:43:31 區塊鏈

Excel中,顏色是通過界面展示及按鈕選擇確定的,在python代碼環境下,自然是沒有這種條件的,那么,matplotlib中顏色是如何構建與使用的呢?
matplotlib提供了強大的顏色介面,供使用者定制顏色、使用顏色、使用色板,主要包括以下幾個部分:
1、 matplotlib.colors 介面中定義的顏色空間,每一個顏色通過字典的形式進行保存,字典名為顏色名稱,字典值為顏色對應的RGB元組或十六進制字串,例如顏色名稱可以為 darkred,字典值為 #8B0000,凡是顏色命名空間中定義了的顏色,均可以通過顏色名字直接參考,
2、 命名空間解決了顏色怎么稱呼的問題,但并沒有建立好顏色與資料的映射關系,使用者往往希望序列(或資料)按照指定的顏色規則自動賦值,比如,我們希望較小的值被賦值為藍色,中間大小的值被賦值為白色,較大的值被賦值為黑色,但我們不可能為每一個數值一一指定顏色(1000個不唯一資料指定1000種顏色的難度可想而知),為此,開發者提出了色板colormap,通過plt.cm介面實作,主要通過兩種原理:一種是指定有限的N種顏色,回圈使用;另一種是將顏色映射到一個線性空間,將最大和最小的數值與顏色空間的兩端做對應,中間的資料采取差值的方法計算與之相對應的顏色,
本文將對上述部分做詳細介紹,

文章目錄

  • 顏色命名空間
    • mpl.colors
      • mpl.colors.BASE_COLORS
      • mpl.colors.TABLEAU_COLORS
      • mpl.colors.cnames
      • mpl.colors.CSS4_COLORS
      • mpl.colors.XKCD_COLORS
      • RGB元組與十六進制字符
      • 可視化CSS4_COLORS
      • 繪制N條漸變線
  • 自定義顏色空間
    • mpl.colors.ListedColormap
    • mpl.colors.LinearSegmentedColormap.from_list
  • 顏色地圖colormap
    • plt.cm
    • plt.cm — listed_cmap
      • 可視化listed_cmap
    • 可視化listed_Seg_cmap
  • 色板 palette
    • 色板命名空間
    • 定制色板
      • 基于plt.cm
      • 基于顏色串列
      • 基于HLS色彩空間生成的離散型色盤
      • 基于球形空間
      • 基于色系
  • 等高線
    • 等高線
    • 等高面
  • 熱力圖
  • 總結

本文的運行環境為 jupyter notebook
python版本為3.7

本文所用到的庫包括

%matplotlib inline
import numpy as np
import seaborn as sns
import matplotlib.pyplot as plt
import matplotlib as mpl

顏色命名空間

mpl.colors模塊下可以看到,matplotlib定制了5個大的顏色空間,有matplotlib默認采用的BASE_COLORS,包含了可視化軟體TableAu顏色命名空間的TABLEAU_COLORS等,各個顏色空間,命名的顏色個數如下,

mpl.colors

print(
    'mpl.colors.BASE_COLORS nums:', len(mpl.colors.BASE_COLORS), '\n',
    'mpl.colors.TABLEAU_COLORS nums:', len(mpl.colors.TABLEAU_COLORS), '\n',
    'mpl.colors.cnames nums:', len(mpl.colors.cnames), '\n',
    'mpl.colors.CSS4_COLORS nums:', len(mpl.colors.CSS4_COLORS), '\n',
    'mpl.colors.XKCD_COLORS nums:', len(mpl.colors.XKCD_COLORS))
顏色命名空間顏色個數
mpl.colors.BASE_COLORS8
mpl.colors.TABLEAU_COLORS10
mpl.colors.cnames148
mpl.colors.CSS4_COLORS148
mpl.colors.XKCD_COLORS949

sns.color_palette可以對包含N個顏色的串列進行可視化,以下對主要命名空間的顏色字典和顏色進行了展示和可視化,

mpl.colors.BASE_COLORS

colors = mpl.colors.BASE_COLORS
print(colors)

pal = [color for name, color in colors.items()]
pal = sns.color_palette(palette=pal)
sns.palplot(pal)

輸出

{'b': (0, 0, 1), 'g': (0, 0.5, 0), 'r': (1, 0, 0), 'c': (0, 0.75, 0.75), 'm': (0.75, 0, 0.75), 'y': (0.75, 0.75, 0), 'k': (0, 0, 0), 'w': (1, 1, 1)}

mpl.colors.TABLEAU_COLORS

colors = mpl.colors.TABLEAU_COLORS
print(colors)

pal = [color for name, color in colors.items()]
pal = sns.color_palette(palette=pal)
sns.palplot(pal)

輸出

OrderedDict([('tab:blue', '#1f77b4'), ('tab:orange', '#ff7f0e'), ('tab:green', '#2ca02c'), ('tab:red', '#d62728'), ('tab:purple', '#9467bd'), ('tab:brown', '#8c564b'), ('tab:pink', '#e377c2'), ('tab:gray', '#7f7f7f'), ('tab:olive', '#bcbd22'), ('tab:cyan', '#17becf')])

mpl.colors.cnames

colors = mpl.colors.cnames
print(list(colors.items())[:10])

pal = [color for name, color in colors.items()][:20]
pal = sns.color_palette(palette=pal)
sns.palplot(pal)

輸出

[('aliceblue', '#F0F8FF'), ('antiquewhite', '#FAEBD7'), ('aqua', '#00FFFF'), ('aquamarine', '#7FFFD4'), ('azure', '#F0FFFF'), ('beige', '#F5F5DC'), ('bisque', '#FFE4C4'), ('black', '#000000'), ('blanchedalmond', '#FFEBCD'), ('blue', '#0000FF')]

mpl.colors.CSS4_COLORS

colors = mpl.colors.CSS4_COLORS
print(list(colors.items())[:10])

pal = [color for name, color in colors.items()][:20]
pal = sns.color_palette(palette=pal)
sns.palplot(pal)

輸出

[('aliceblue', '#F0F8FF'), ('antiquewhite', '#FAEBD7'), ('aqua', '#00FFFF'), ('aquamarine', '#7FFFD4'), ('azure', '#F0FFFF'), ('beige', '#F5F5DC'), ('bisque', '#FFE4C4'), ('black', '#000000'), ('blanchedalmond', '#FFEBCD'), ('blue', '#0000FF')]

mpl.colors.XKCD_COLORS

colors = mpl.colors.XKCD_COLORS
print(list(colors.items())[:10])

pal = [color for name, color in colors.items()][:20]
pal = sns.color_palette(palette=pal)
sns.palplot(pal)

輸出

[('xkcd:cloudy blue', '#acc2d9'), ('xkcd:dark pastel green', '#56ae57'), ('xkcd:dust', '#b2996e'), ('xkcd:electric lime', '#a8ff04'), ('xkcd:fresh green', '#69d84f'), ('xkcd:light eggplant', '#894585'), ('xkcd:nasty green', '#70b23f'), ('xkcd:really light blue', '#d4ffff'), ('xkcd:tea', '#65ab7c'), ('xkcd:warm purple', '#952e8f')]

從以上案例可以看到,一些命名空間的顏色是通過十六進制字串形式表示的,另一些是通過0-1的長度為3的元組形式表示的,這兩種有什么區別呢?
本例展示了他們的數學原理,你會看到他們的本質并沒有什么不同,

RGB元組與十六進制字符

def color16_to_rgb(color16):
    # 分別獲得FF,63,47三個十六進制數字
    R16, G16, B16 = color16[1:3], color16[3:5], color16[5:7]
    # 將十六進制轉成十進制
    R10, G10, B10 = int(R16, 16), int(G16, 16), int(B16, 16)  
    # 將十進制轉成歸一化
    R, G, B = R10/255.0, G10/255.0, B10/255.0  
    return (R, G, B), (R10, G10, B10)

color16_to_rgb('#FF6347')

輸出

((1.0, 0.38823529411764707, 0.2784313725490196), (255, 99, 71))

函式color16_to_rgb決議:先將十六進制字串 # 符號后的6個字符分裂為3個,每兩個代表一個十六進制數字,通過int(num,16)可實作將其轉換為十進制,
從回傳值來看,’#FF6347’被轉換成十進制元組——(255, 99, 71),事實上,電腦顯示帶顏色的圖片就是通過三通道的陣列(寬×高×3)實作的,電腦螢屏在不同解析度下被劃分為M×N的小格,每個小格包含3個數字,分別代表紅色通道(R),綠色通道(G),藍色通道(B)的明暗,0表示最暗,255表示最亮,3通道排列組合一共將產生256×256×256=16777216種顏色組合,這便是理論上總的顏色個數,
matplotlib并沒有保存十進制RGB元組,保存的是十進制元組歸一化后的元組,即十進制元組/255.0后的浮點數,
十六進制和RGB元組都能表示顏色,不同的是前者是離散的,后者是連續的,在使用程序中,可充分利用離散資料的唯一性和連續資料的連續性進行相對應的配色,

可通過matplotlib自帶的mpl.colors.to_rgb 介面實作了上述功能,如下圖可知,兩種方式輸出的歸一化后元組完全相同,

mpl.colors.to_rgb('#FF6347')

輸出

(1.0, 0.38823529411764707, 0.2784313725490196)

以下代碼展示了’#FF6347’的顯色效果(左上角子圖)和分通道的顯色效果,

(R, G, B), (R10, G10, B10)=color16_to_rgb('#FF6347')
img=np.zeros(shape=[15,15,3],dtype=np.int)  # 均為0的3通道陣列
imgR,imgG,imgB=img.copy(),img.copy(),img.copy() # 復制為3個,后續分別用來給每個通道賦值

fig,axs=plt.subplots(2,2,figsize=(8,8))
axs=axs.ravel() # 將axs拉平成一維串列

# 去掉所有子圖坐標系
for ax in axs:
    ax.axis('off')

# R,G,B channels —— ax0
img[:,:,0]=R10
img[:,:,1]=G10
img[:,:,2]=B10
axs[0].imshow(img)
axs[0].set_title('img R,G,B channels\nvalues: %d,%d,%d '% (R10,G10,B10),fontsize=20)

# R channel —— ax1
imgR[:,:,0]=R10
axs[1].imshow(imgR)
axs[1].set_title('img R channel\nvalue: %d'%R10,fontsize=20)

# G channel —— ax2
imgG[:,:,1]=G10
axs[2].imshow(imgG)
axs[2].set_title('img G channel\nvalue: %d'%G10,fontsize=20)

# B channel —— ax3
imgB[:,:,2]=B10
axs[3].imshow(imgB)
axs[3].set_title('img B channel\nvalue: %d'%B10,fontsize=20)

可視化CSS4_COLORS

以下代碼可視化地展示了CSS4_COLORS命名空間各顏色的名稱及顯色效果,根據顯色效果,使用者可根據十六進制字串或顏色名稱進行相應呼叫,

fig, axs = plt.subplots(37, 8, figsize=(12, 20))
axs = axs.ravel()  # 將axs拉平成一維串列

colors = mpl.colors.CSS4_COLORS  # 字典,包含148個元素

for i, (name, color) in enumerate(colors.items()):
    ax_color = axs[2*i]  # 偶數子圖填充顏色并列印顏色十六進制字符
    ax_name = axs[2*i+1]  # 奇數子圖列印顏色名稱

    # 去除x,y軸標簽
    for ax in [ax_color, ax_name]:
        ax.set_xticks([])
        ax.set_yticks([])

    ax_color.set(facecolor=color)  # 顏色子圖填充該顏色

    # 將十六進制顏色字符列印至子圖ax_color
    ax_color.text(0.5, 0.5, color, va='center', ha='center',
                  fontsize=12, transform=ax_color.transAxes)
    # 將顏色名稱字符列印至子圖ax_name
    ax_name.text(0.5, 0.5, name, va='center', ha='center',
                 fontsize=12, transform=ax_name.transAxes)

plt.tight_layout(pad=0)
plt.subplots_adjust(wspace=0,hspace=0)  # 子圖水平與垂直方向間距均調成0

繪制N條漸變線

利用RGB元組的資料連續性,可以很快的繪制線性變化的顏色序列,本圖繪制了顏色在R通道上從150-255線性均勻的變化程序,

N = 6
x = np.linspace(-4, 4, 100)
ys = [i+np.sin(x) for i in range(N)]
cs = np.linspace(150, 255, N)

for i, y in enumerate(ys):
    plt.plot(x, y, c=(cs[i]/255.0, 0, 0), lw=10, label='R-%d' % int(cs[i]))
plt.legend(bbox_to_anchor=(1.02, 0.8), fontsize=15, frameon=False)
# plt.xticks([])
# plt.yticks([])

不難看出元組表示的顏色更適合連續資料的映射,十六進制表示的顏色更適合精確命名顏色,

自定義顏色空間

mpl.colors.ListedColormap

ListedColormap定制的是離散型色板,顏色會根據色板串列回圈,
本例在r,g,b三個通道上,線性地生成了20個資料,并通過串列推導式,生成了包含此20個顏色的串列,并將顏色與資料y的大小進行了映射,
從圖中可以看出,y值比較小的時候,顏色為翠綠色,當y值比較大的時候,顏色為亮紫色,

N=20
colors=[(r,g,b) for (r,g,b) in zip(np.linspace(0,1,N),np.linspace(1,0,N),np.linspace(0,1,N))]
my_cmap=mpl.colors.ListedColormap(colors)
plt.cm.register_cmap(name='mycmp',cmap=my_cmap)

x=np.linspace(-np.pi,np.pi,N)
y=np.sin(x)

plt.scatter(x,y,s=200,c=y,cmap=plt.cm.get_cmap('mycmp'))

輸出定制色板的前五種顏色,如下:

plt.cm.get_cmap('mycmp').colors[:5]

輸出

[(0.0, 1.0, 0.0),
 (0.05263157894736842, 0.9473684210526316, 0.05263157894736842),
 (0.10526315789473684, 0.8947368421052632, 0.10526315789473684),
 (0.15789473684210525, 0.8421052631578947, 0.15789473684210525),
 (0.21052631578947367, 0.7894736842105263, 0.21052631578947367)]

mpl.colors.LinearSegmentedColormap.from_list

LinearSegmentedColormap定制的是一個色板演算法,其原理是通過線性的給出3個顏色點,其余顏色通過插值的方式獲得,
本例將色板與y值大小進行了資料映射,從圖中可以看出y較小時為黑色,較大時為白色,中間為藍色,與我們傳入的startcolormidcolorendcolor實作了對應,

startcolor=(0.0,0.0,0.0)  # 全白
midcolor=(0.0,0.0,1.0)  # 全藍
endcolor=(1.0,1.0,1.0)  # 全黑
my_cmap1=mpl.colors.LinearSegmentedColormap.from_list(name='mycmp1',colors=[startcolor,midcolor,endcolor])
plt.cm.register_cmap(name='mycmp1',cmap=my_cmap1)

x=np.linspace(-np.pi,np.pi,N)
y=np.sin(x)

plt.scatter(x,y,s=200,c=y,cmap=plt.cm.get_cmap('mycmp1'))  

顏色地圖colormap

可通過plt.cm直接呼叫已在matplotlib中定制好的色板
以下兩個案例分別將y、x資料與色板進行了資料映射,效果如下,

plt.cm

N=40
np.random.seed(123)
x=np.random.randn(N)
y=np.random.randn(N)
s=np.linspace(100,1000,N)

fig=plt.figure()
ax=fig.add_subplot(111)

mappable=ax.scatter(x,y,c=y,s=s,alpha=0.6,cmap=plt.cm.RdBu)
# 添加顏色條
cb=plt.colorbar(mappable=mappable,ax=ax)

N=40
np.random.seed(123)
x=np.random.randn(N)
y=np.random.randn(N)
s=np.linspace(100,1000,N)

fig=plt.figure(figsize=(6,5))
ax=fig.add_subplot(111)

mappable=ax.scatter(x,y,c=x,s=s,alpha=0.6,cmap=plt.cm.RdBu)
# 添加水平方向顏色條
cb=plt.colorbar(mappable=mappable,ax=ax,orientation='horizontal')

plt.cm — listed_cmap

plt.cm包含很多默認色板,如下:

cmap_all='''Accent = <matplotlib.colors.ListedColormap object>
Accent_r = <matplotlib.colors.ListedColormap object>
Blues = <matplotlib.colors.LinearSegmentedColormap object>
………………
hot = <matplotlib.colors.LinearSegmentedColormap object>
hot_r = <matplotlib.colors.LinearSegmentedColormap object>
hsv = <matplotlib.colors.LinearSegmentedColormap object>
hsv_r = <matplotlib.colors.LinearSegmentedColormap object>
inferno = <matplotlib.colors.ListedColormap object>
inferno_r = <matplotlib.colors.ListedColormap object>
jet = <matplotlib.colors.LinearSegmentedColormap object>
…………………
winter = <matplotlib.colors.LinearSegmentedColormap object>
winter_r = <matplotlib.colors.LinearSegmentedColormap object>'''

提取資訊

def get_cmap_names(string):
    import re
    match=re.match(pattern=r'(.*) = <matplotlib.colors.(.*) object>',string=string)
    return match.group(1),match.group(2)
cmap_dict={}
for cmap_ in cmap_all.split('\n'):
    cmap_name,cmap_cat=get_cmap_names(cmap_)
    cmap_dict[cmap_name]=cmap_cat

listed_cmap_list=[k for k,v in cmap_dict.items() if v=='ListedColormap']
listed_Seg_cmap_list=[k for k,v in cmap_dict.items() if v=='LinearSegmentedColormap']

cmap_dict,listed_cmap_list,listed_Seg_cmap_list
len(listed_cmap_list),len(listed_Seg_cmap_list)

plt.cm共包含38個ListedColormap色板和126個LinearSegmentedColormap

(38, 126)

可視化listed_cmap

將38個ListedColormap色板可視化,如下:

from matplotlib.gridspec import GridSpec
nrows = len(listed_cmap_list)
gs = GridSpec(nrows=nrows, ncols=2, width_ratios=[
              6, 15], left=0, bottom=0, right=1, top=1, wspace=0, hspace=0)
fig = plt.figure(figsize=(8, 12))
plt.xticks([])
plt.yticks([])
x = np.linspace(0, 1, 20)
y = x.reshape(-1, 1)
xv, yv = np.meshgrid(x, y)
for i, listed_map in enumerate(listed_cmap_list):
    # 奇數子圖顯示colormap名稱
    ax = fig.add_subplot(gs[i, 0], frameon=True)
    ax.text(0.5, 0.5, listed_map, fontdict={
            'size': 17}, ha='center', va='center', transform=ax.transAxes)
    ax.set_xticks([])
    ax.set_yticks([])
    # 偶數子圖繪制colormap漸變顏色
    ax = fig.add_subplot(gs[i, 1], frameon=True)
    ax.imshow(xv, cmap=plt.cm.get_cmap(listed_map), aspect='auto'  # auto 自動調節以充滿整個ax
              , extent=(0, 1, 0, 1))  # 通過增加extent,從而充滿整個ax坐標軸
    ax.set_xticks([])
    ax.set_yticks([])

可視化listed_Seg_cmap

將126個LinearSegmentedColormap色板可視化,如下:

nrows = len(listed_Seg_cmap_list)
gs = GridSpec(nrows=nrows, ncols=2, width_ratios=[
              6, 15], left=0, bottom=0, right=1, top=1, wspace=0, hspace=0)
fig = plt.figure(figsize=(12, 35))
plt.xticks([])
plt.yticks([])
x = np.linspace(0, 1, 20)
y = x.reshape(-1, 1)
xv, yv = np.meshgrid(x, y)

for i, listed_map in enumerate(listed_Seg_cmap_list):
    index = i
    ax = fig.add_subplot(gs[index, 0], frameon=True)
    ax.set_xticks([])
    ax.set_yticks([])
    ax.text(0.5, 0.5, listed_map, fontdict={
            'size': 17}, ha='center', va='center', transform=ax.transAxes)

    ax = fig.add_subplot(gs[index, 1], frameon=True)
    ax.set_xticks([])
    ax.set_yticks([])
    ax.imshow(xv, cmap=plt.cm.get_cmap(listed_map), aspect='auto'  # auto 自動調節以充滿整個ax
              , extent=(0, 1, 0, 1))  # 通過增加extent,從而充滿整個ax坐標軸

色板 palette

seaborn是在matplolib基礎上封裝的高級可視化庫,其色板主要通過palette引數設定

色板命名空間

seaborn默認6種色板命名空間:deep,muted, pastel, bright, dark, colorblind
各色板顏色變化順序如下:

pal = sns.color_palette(palette='deep')
sns.palplot(pal)

pal = sns.color_palette(palette='muted')
sns.palplot(pal)

pal = sns.color_palette(palette='pastel')
sns.palplot(pal)

pal = sns.color_palette(palette='bright')
sns.palplot(pal)

pal = sns.color_palette(palette='dark')
sns.palplot(pal)

pal = sns.color_palette(palette='colorblind')
sns.palplot(pal)

定制色板

有多種方式定制seabornpalette

基于plt.cm

pal=pal_from_cmap=sns.color_palette('hot')
sns.palplot(pal)

基于顏色串列

colors=[(r,g,b) for r,g,b in zip(np.linspace(0,1,5),np.linspace(0.2,0.7,5),np.linspace(0,1,5))]
pal=pal_from_colors=sns.color_palette(colors)
sns.palplot(pal)

基于HLS色彩空間生成的離散型色盤

pal=sns.hls_palette(n_colors=10, h=0.5, l=0.6, s=0.3)
sns.palplot(pal)

基于球形空間

# 基于球形空間生成的線性色盤
pal=sns.cubehelix_palette(n_colors=10,
                            start=1,
                            rot=0.4,
                            gamma=1.0,
                            hue=0.8,
                            light=0.85,
                            dark=0.15,)
sns.palplot(pal)

基于色系

pal=sns.dark_palette(color='red',n_colors=10,)
sns.palplot(pal)

pal=sns.light_palette(color='red',n_colors=10,)
sns.palplot(pal)

色板最直接、最明顯的應用繪圖物件包括:散點圖、面積圖、填充圖、等高線圖、等高面圖、熱力圖等,前三個已經本系列第二部分做了詳細介紹,以下對剩下幾個繪圖物件做案例介紹,細節處請詳細閱讀代碼注釋:

等高線

等高線

N = 10
x = np.linspace(-10, 10, N)
y = np.linspace(-10, 10, N)
X, Y = np.meshgrid(x, y)  # return X,Y, shape 100*100,100*100
# 這里的X,Y可以這么理解,相當于把x軸上的點,和y軸上的點投影到了 2D平面

# 針對2D平面的每一個坐標點,計算Z的值, Z shape 100*100
Z = np.power(X/0.8, 2)+np.power(Y/0.6, 2)

fig = plt.figure()
ax = fig.add_subplot(111)
# levels 顯示指定的Z值 比如 x=0,y=-10,此時 Z=100
CS = ax.contour(X, Y, Z, levels=[20, 40, 70,
                                 100, 150], cmap=plt.cm.RdBu, linewidths=5)
ax.clabel(CS, fontsize=16, fmt='%.0f')

cb = plt.colorbar(mappable=CS)

等高面

N = 1000
x = np.linspace(0, 10, N)
y = np.linspace(-10, 10, N)
X, Y = np.meshgrid(x, y)  # return X,Y, shape 100*100,100*100
# 這里的X,Y可以這么理解,相當于把x軸上的點,和y軸上的點投影到了 2D平面

Z = np.power(X, 2)-np.power(Y, 2)  # 針對2D平面的每一個坐標點,計算Z的值, Z shape 100*100
fig = plt.figure()
ax = fig.add_subplot(111)
ax.set_xlim(-1, 11)
ax.set_ylim(-12, 12)

CS = ax.contourf(X, Y, Z  # ,levels=[-100,-50,50,100]
                 , cmap=plt.cm.Blues
                 )  # levels 顯示指定的Z值 比如 x=0,y=-10,此時 Z=100
ax.clabel(CS, fontsize=16, fmt='%.0f', inline=False, colors='black')

cb = plt.colorbar(mappable=CS)
ax.spines['top'].set_visible(False)
ax.spines['right'].set_visible(False)
ax.plot(x, x, c=(0.75, 0, 0), lw=4, ls='--')

熱力圖

grid_kws = {"height_ratios": (0.9, 0.1)}  # 熱力圖與顏色條高度比值為 0.9:0.1
fig, (ax, cbar_ax) = plt.subplots(
    2, 1, gridspec_kw=grid_kws)  # 2行1列,第一行為熱力圖,第二行為顏色條

data = np.random.randn(64).reshape(8, -1)
sns.heatmap(data,
            ax=ax,
            cbar_ax=cbar_ax,
            cbar=True,
            cbar_kws={"orientation": "horizontal"})  # 將顏色條方向調為水平方向

總結

顏色命名空間 mpl.colors 總結

命名空間型別顏色個數
BASE_COLORS字典顏色名稱RGB元組8
TABLEAU_COLORS字典顏色名稱十六進制10
cnames字典顏色名稱十六進制148
CSS4_COLORS字典顏色名稱十六進制148
XKCD_COLORS字典顏色名稱十六進制949

plt.cm 總結

顏色板型別色板個數創建/參考舉例
ListedColormap字典RGB元組38plt.cm.Accent
LinearSegmentedColormap字典RGB元組126plt.cm.hot

自定義
ListedColormap
串列RGB元組任意多
mpl.colors.ListedColormap(colors)
plt.cm.get_cmap(‘mycmap’)

自定義
LinearSegmentedColormap
串列
3個RGB元組數學運算得到
(start,mid,end)
任意多
mpl.colors.LinearSegmentedColormap.from_list(name,colors)
plt.cm.get_cmap(‘mycmap’)

希望對你有所幫助和啟發!

轉載請註明出處,本文鏈接:https://www.uj5u.com/qukuanlian/57852.html

標籤:區塊鏈

上一篇:【練習筆記(第一次)】2020年數學建模國賽C題:資料處理、源代碼

下一篇:python 實作文本自動翻譯功能

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • JAVA使用 web3j 進行token轉賬

    最近新學習了下區塊鏈這方面的知識,所學不多,給大家分享下。 # 1. 關于web3j web3j是一個高度模塊化,反應性,型別安全的Java和Android庫,用于與智能合約配合并與以太坊網路上的客戶端(節點)集成。 # 2. 準備作業 jdk版本1.8 引入maven <dependency> < ......

    uj5u.com 2020-09-10 03:03:06 more
  • 以太坊智能合約開發框架Truffle

    前言 部署智能合約有多種方式,命令列的瀏覽器的渠道都有,但往往跟我們程式員的風格不太相符,因為我們習慣了在IDE里寫了代碼然后打包運行看效果。 雖然現在IDE中已經存在了Solidity插件,可以撰寫智能合約,但是部署智能合約卻要另走他路,沒辦法進行一個快捷的部署與測驗。 如果團隊管理的區塊節點多、 ......

    uj5u.com 2020-09-10 03:03:12 more
  • 谷歌二次驗證碼成為區塊鏈專用安全碼,你怎么看?

    前言 谷歌身份驗證器,前些年大家都比較陌生,但隨著國內互聯網安全的加強,它越來越多地出現在大家的視野中。 比較廣泛接觸的人群是國際3A游戲愛好者,游戲盜號現象嚴重+國外賬號安全應用廣泛,這類游戲一般都會要求用戶系結名為“兩步驗證”、“雙重驗證”等,平臺一般都推薦用谷歌身份驗證器。 后來區塊鏈業務風靡 ......

    uj5u.com 2020-09-10 03:03:17 more
  • 密碼學DAY1

    目錄 ##1.1 密碼學基本概念 密碼在我們的生活中有著重要的作用,那么密碼究竟來自何方,為何會產生呢? 密碼學是網路安全、資訊安全、區塊鏈等產品的基礎,常見的非對稱加密、對稱加密、散列函式等,都屬于密碼學范疇。 密碼學有數千年的歷史,從最開始的替換法到如今的非對稱加密演算法,經歷了古典密碼學,近代密 ......

    uj5u.com 2020-09-10 03:03:50 more
  • 密碼學DAY1_02

    目錄 ##1.1 ASCII編碼 ASCII(American Standard Code for Information Interchange,美國資訊交換標準代碼)是基于拉丁字母的一套電腦編碼系統,主要用于顯示現代英語和其他西歐語言。它是現今最通用的單位元組編碼系統,并等同于國際標準ISO/IE ......

    uj5u.com 2020-09-10 03:04:50 more
  • 密碼學DAY2

    ##1.1 加密模式 加密模式:https://docs.oracle.com/javase/8/docs/api/javax/crypto/Cipher.html ECB ECB : Electronic codebook, 電子密碼本. 需要加密的訊息按照塊密碼的塊大小被分為數個塊,并對每個塊進 ......

    uj5u.com 2020-09-10 03:05:42 more
  • NTP時鐘服務器的特點(京準電子)

    NTP時鐘服務器的特點(京準電子) NTP時鐘服務器的特點(京準電子) 京準電子官V——ahjzsz 首先對時間同步進行了背景介紹,然后討論了不同的時間同步網路技術,最后指出了建立全球或區域時間同步網存在的問題。 一、概 述 在通信領域,“同步”概念是指頻率的同步,即網路各個節點的時鐘頻率和相位同步 ......

    uj5u.com 2020-09-10 03:05:47 more
  • 標準化考場時鐘同步系統推進智能化校園建設

    標準化考場時鐘同步系統推進智能化校園建設 標準化考場時鐘同步系統推進智能化校園建設 安徽京準電子科技官微——ahjzsz 一、背景概述隨著教育事業的快速發展,學校建設如雨后春筍,隨之而來的學校教育、管理、安全方面的問題成了學校管理人員面臨的最大的挑戰,這些問題同時也是學生家長所擔心的。為了讓學生有更 ......

    uj5u.com 2020-09-10 03:05:51 more
  • 位元幣入門

    引言 位元幣基本結構 位元幣基礎知識 1)哈希演算法 2)非對稱加密技術 3)數字簽名 4)MerkleTree 5)哪有位元幣,有的是UTXO 6)位元幣挖礦與共識 7)區塊驗證(共識) 總結 引言 上一篇我們已經知道了什么是區塊鏈,此篇說一下區塊鏈的第一個應用——位元幣。其實先有位元幣,后有的區塊 ......

    uj5u.com 2020-09-10 03:06:15 more
  • 北斗對時服務器(北斗對時設備)電力系統應用

    北斗對時服務器(北斗對時設備)電力系統應用 北斗對時服務器(北斗對時設備)電力系統應用 京準電子科技官微(ahjzsz) 中國北斗衛星導航系統(英文名稱:BeiDou Navigation Satellite System,簡稱BDS),因為是目前世界范圍內唯一可以大面積提供免費定位服務的系統,所以 ......

    uj5u.com 2020-09-10 03:06:20 more
最新发布
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:46:47 more
  • Hyperledger Fabric 使用 CouchDB 和復雜智能合約開發

    在上個實驗中,我們已經實作了簡單智能合約實作及客戶端開發,但該實驗中智能合約只有基礎的增刪改查功能,且其中的資料管理功能與傳統 MySQL 比相差甚遠。本文將在前面實驗的基礎上,將 Hyperledger Fabric 的默認資料庫支持 LevelDB 改為 CouchDB 模式,以實作更復雜的資料... ......

    uj5u.com 2023-04-16 07:28:31 more
  • .NET Core 波場鏈離線簽名、廣播交易(發送 TRX和USDT)筆記

    Get Started NuGet You can run the following command to install the Tron.Wallet.Net in your project. PM> Install-Package Tron.Wallet.Net 配置 public reco ......

    uj5u.com 2023-04-14 08:08:00 more
  • DKP 黑客分析——不正確的代幣對比率計算

    概述: 2023 年 2 月 8 日,針對 DKP 協議的閃電貸攻擊導致該協議的用戶損失了 8 萬美元,因為 execute() 函式取決于 USDT-DKP 對中兩種代幣的余額比率。 智能合約黑客概述: 攻擊者的交易:0x0c850f,0x2d31 攻擊者地址:0xF38 利用合同:0xf34ad ......

    uj5u.com 2023-04-07 07:46:09 more
  • Defi開發簡介

    Defi開發簡介 介紹 Defi是去中心化金融的縮寫, 是一項旨在利用區塊鏈技術和智能合約創建更加開放,可訪問和透明的金融體系的運動. 這與傳統金融形成鮮明對比,傳統金融通常由少數大型銀行和金融機構控制 在Defi的世界里,用戶可以直接從他們的電腦或移動設備上訪問廣泛的金融服務,而不需要像銀行或者信 ......

    uj5u.com 2023-04-05 08:01:34 more
  • solidity簡單的ERC20代幣實作

    // SPDX-License-Identifier: GPL-3.0 pragma solidity >=0.7.0 <0.9.0; import "hardhat/console.sol"; //ERC20 同質化代幣,每個代幣的本質或性質都是相同 //ETH 是原生代幣,它不是ERC20代幣, ......

    uj5u.com 2023-03-21 07:56:29 more
  • solidity 參考型別修飾符memory、calldata與storage 常量修飾符C

    在solidity語言中 參考型別修飾符(參考型別為存盤空間不固定的數值型別) memory、calldata與storage,它們只能修飾參考型別變數,比如字串、陣列、位元組等... memory 適用于方法傳參、返參或在方法體內使用,使用完就會清除掉,釋放記憶體 calldata 僅適用于方法傳參 ......

    uj5u.com 2023-03-08 07:57:54 more
  • solidity注解標簽

    在solidity語言中 注釋符為// 注解符為/* 內容*/ 或者 是 ///內容 注解中含有這幾個標簽給予我們使用 @title 一個應該描述合約/介面的標題 contract, library, interface @author 作者的名字 contract, library, interf ......

    uj5u.com 2023-03-08 07:57:49 more
  • 評價指標:相似度、GAS消耗

    【代碼注釋自動生成方法綜述】 這些評測指標主要來自機器翻譯和文本總結等研究領域,可以評估候選文本(即基于代碼注釋自動方法而生成)和參考文本(即基于手工方式而生成)的相似度. BLEU指標^[^?88^^?^]^:其全稱是bilingual evaluation understudy.該指標是最早用于 ......

    uj5u.com 2023-02-23 07:27:39 more
  • 基于NOSTR協議的“公有制”版本的Twitter,去中心化社交軟體Damus

    最近,一個幽靈,Web3的幽靈,在網路游蕩,它叫Damus,這玩意詮釋了什么叫做病毒式營銷,滑稽的是,一個Web3產品卻在Web2的產品鏈上瘋狂傳銷,各方大佬紛紛為其背書,到底發生了什么?Damus的葫蘆里,賣的是什么藥? 注冊和簡單實用 很少有什么產品在用戶注冊環節會有什么噱頭,但Damus確實出 ......

    uj5u.com 2023-02-05 06:48:39 more