前几天上课的时候,有位同学问了我关于热力图的问题。我之前没画过热力图,所以也没给出什么建设性的意见。这两天研究了一下,大概能画出来。写个例子在这里,希望对这位同学能有帮助1fe29c6747e6248215ae7d5b48187039.png

我先写了个简单的csv文件,文件名为:thermodynamic_data.csv,用来作为数据源:

bf994c43e6c089fea0a46c1213bdf51b.png

首先是比较简单的用matplotlib来解决:

import numpy as npimport Nglfrom matplotlib import pyplot as pltdelim = ','f     = open("thermodynamic_data.csv",'r')data  = f.readlines()vals = []for i in data:        line = i.strip()        cols = line.split(delim)        vals.append(cols[:])vals = np.array(vals).astype(float)nlines = vals[:,0]ncols  = vals[0,:]X = vals[1:,1:]plt.figure(figsize=(8, 6))plt.subplots_adjust(left=.2, right=0.95, bottom=0.15, top=0.95)plt.imshow(X, interpolation='nearest', cmap=plt.cm.hot)plt.xlabel('date')plt.ylabel('unit')plt.colorbar()plt.xticks(ncols[0:7],rotation=45)plt.yticks(nlines[0:8])plt.title('Thermodynamic Plot')plt.savefig("1.png")

58ce0311a9fb8e9f07f40694416fe662.png

用matplotlib绘制热力图有个问题,就是不好在这些格子里填数字。要解决这个问题,就要借助Seaborn包的帮助。Seaborn是基于matplotlib的图形可视化python包。它提供了一种高度交互式界面,便于用户能够做出各种有吸引力的统计图表。它在Linux下的安装方法如下:

pip install seaborn

同样地用上面的数据源,用前面的代码读出X后,用seaborn包绘制填值的热力图:

import seaborn as snsf,ax = plt.subplots(figsize = (6,4),nrows=1)sns.heatmap(X, linewidths = 0.05, annot=True, fmt='.1f', cmap='rainbow')ax.set_title('Thermodynamic Plot')ax.set_xlabel('date')ax.set_ylabel('unit')plt.ylim(0,8)plt.xticks(ncols[0:7]+0.5,ncols[0:7])plt.yticks(nlines[0:8]+0.5, nlines[0:8])plt.savefig('2.png')

画出来就是这样:

81c630c6a8a68ff36639f622d3294120.png

当然,如果要按照原样来复原文件表格,只要把ylim那句删掉就可以。出来的效果如下:

4999836d3764ba28cb4a258613685e79.png

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐