zoukankan      html  css  js  c++  java
  • seaborn矩阵图组合图---热力图heatmap、聚类图clustermap

    1.热力图heatmap

    seaborn.heatmap(data, vmin=None, vmax=None, cmap=None, center=None, robust=False, annot=None, fmt='.2g', annot_kws=None, linewidths=0, linecolor='white', cbar=True, cbar_kws=None, cbar_ax=None, square=False, xticklabels='auto', yticklabels='auto', mask=None, ax=None, **kwargs)

    方法:用颜色矩阵去显示数据在两个维度下的度量值

    参数:

    • data : 要显示的数据
    ax = sns.heatmap(data)
    • vmin, vmax : 显示的数据值的最大和最小的范围
    ax = sns.heatmap(data,vmin=0, vmax=1)
    • cmap : matplotlib颜色表名称或对象,或颜色列表,可选从数据值到色彩空间的映射。如果没有提供,默认设置
    ax = sns.heatmap(data,vmin=0, vmax=1, cmap = 'GnBu')
    • center : 指定色彩的中心值
    ax = sns.heatmap(data,vmin=0, vmax=1, cmap = 'GnBu', center=0.7)
    • robust : 如果“Ture”和“ vmin或” vmax不存在,则使用强分位数计算颜色映射范围,而不是极值。
    ax = sns.heatmap(data,vmin=0, vmax=1, cmap = 'GnBu', center=0.5, 
                     robust=False) #Set1
    • annot : 如果为True,则将数据值写入每个单元格中
    ax = sns.heatmap(data,vmin=0, vmax=1, cmap = 'GnBu', center=0.5, 
                     robust=False,annot=True) #Set1
    • fmt : 表格里显示数据的类型
    fmt ='.0%'#显示百分比
    fmt ='f' 显示完整数字 = fmt ='g'
    fmt ='.3'显示小数的位数 = fmt ='.3f' = fmt ='.3g'
    
    • annot_kws : 键,值映射的dict,可选
    • linewidths : 划分每个单元格的线的宽度。
    • linecolor : 划分每个单元格的线的颜色。
    • cbar : 是否绘制颜色条:colorbar,默认绘制
    • cbar_kws : 未知 cbar_ax : 显示x-y坐标,而不是节点的编号
    • square : 为‘True’时,整个网格为一个正方形
    • xticklabels, yticklabels : 可以以字符串进行命名,也可以调节编号的间隔,也可以不显示坐标
    ax = sns.heatmap(uniform_data,cmap = 'RdBu', center=0,cbar = True, square = False,xticklabels =['12','22'])#字符串命名
    ax = sns.heatmap(uniform_data,cmap = 'RdBu', center=0,cbar = True, square = False,xticklabels =2)#编号间隔为2
    ax = sns.heatmap(uniform_data,cmap = 'RdBu', center=0,cbar = True, square = False,xticklabels =False)#不显示坐标
    

    举例:

    plt.figure(figsize = (12,6))
    corr_values = data.corr()
    sns.heatmap(corr_values, annot=True,vmax=1, square=True, cmap="Blues",fmt='.2f')
    plt.tight_layout()
    plt.savefig('heatmap.png',dpi=600) 
    plt.show()
    

    2.聚类图clustermap

    seaborn.clustermap(data, pivot_kws=None, method='average', metric='euclidean', z_score=None, standard_scale=None, figsize=None, cbar_kws=None, row_cluster=True, col_cluster=True, row_linkage=None, col_linkage=None, row_colors=None, col_colors=None, mask=None, **kwargs)
    • 除此之外,clustermap 支持绘制层次聚类结构图。如下所示,我们先去掉原数据集中最后一个目标列,传入特征数据即可。当然,你需要对层次聚类有所了解,否则很难看明白图像多表述的含义。
    • seaborn.clustermap

    举例:

    iris.pop("species")
    sns.clustermap(iris)

    参考文献:

    【1】python3.x-seaborn.heatmap随笔

    【2】中文官网

  • 相关阅读:
    RHEL6 搭建 keepalived + lvs/DR 集群
    LeetCode 104. Maximum Depth of Binary Tree
    JAVA面试精选【Java基础第二部分】
    xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!
    xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!
    xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!
    xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!
    xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!
    xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!
    为什么支付宝不怕你欠债?
  • 原文地址:https://www.cnblogs.com/nxf-rabbit75/p/11115494.html
Copyright © 2011-2022 走看看