【100天精通Python】Day68:Python可视化_Matplotlib 绘制热力图,示例+代码

news2024/12/27 10:22:22

目录

1 值热力图(Value Heatmap):

2 密度热力图(Density Heatmap)

3 时间热力图(Time Heatmap):

4 空间热力图(Spatial Heatmap)

5 渐变热力图(Gradient Heatmap)

6 3D热力图


        Matplotlib 是一个Python数据可视化库,它提供了各种绘图工具和函数,用于创建多种类型的图表,包括热力图(Heatmap)。热力图是一种用颜色来表示数据值的分布和模式的可视化方式,通常用于研究数据的相关性、密度、趋势等。

1 Matplotlib绘制热力图步骤

  1. 导入库

    在开始之前,需要导入必要的库,包括Matplotlib和NumPy。NumPy通常用于生成或处理数据。

    import numpy as np
    
    import matplotlib.pyplot as plt

  2. 准备数据

    在绘制热力图之前,需要准备数据。数据可以是二维数组或矩阵,其中每个元素表示某个位置的数值。

    data = np.random.rand(10, 10) # 示例数据,可以根据需求替换为你的数据

  3. 创建热力图

    使用Matplotlib的imshow函数来创建热力图。你可以指定颜色映射(colormap),以及其他可选的参数,如图例、坐标轴标签等。

    ​plt.imshow(data, cmap='viridis')  # 使用'viridis'颜色映射,可以根据需求选择其他颜色映射
    plt.colorbar()  # 添加颜色条
    plt.title('Heatmap Example')
    plt.xlabel('X Axis')
    plt.ylabel('Y Axis')
    
    

    显示热力图

           使用plt.show()函数来显示生成的热力图。

        这些步骤将生成一个基本的热力图,其中颜色表示数据值的大小和密度。你可以根据需要自定义图表的外观,例如调整颜色映射、添加注释、更改标签等。

        此外,Matplotlib还提供了其他绘制热力图的方法,例如pcolormeshimshow之外,你还可以使用heatmap等其他方法,以适应不同类型的数据和需求。

2 常用热力图类型

        值热力图(Value Heatmap):用不同的颜色和亮度表示数值的大小和密度。较高的数值通常以鲜艳和明亮的颜色表示,而较低的数值则以暗淡的颜色表示。

        密度热力图(Density Heatmap):用颜色强度表示数据点的集中程度和分布密度。较高的密度区域会显示为较深的颜色,较低的密度区域则显示为较浅的颜色。

        时间热力图(Time Heatmap):将时间作为一个维度,用颜色的强度表示特定时间段内的某种事件或指标的变化趋势。较高的值通常以深色显示,较低的值则以浅色显示。

        空间热力图(Spatial Heatmap):用颜色强度表示地理区域内的数据分布情况。可以按地理位置和对应的数值来绘制颜色强度的差异。

        渐变热力图(Gradient Heatmap):通过平滑过渡的颜色渐变来表示数值或密度的变化程度。使用渐变热力图可以更好地展示数据的变化趋势和分布情况。 

3 值热力图(Value Heatmap):

        值热力图通常用于表示数值大小和密度。较高的数值使用鲜艳的颜色,而较低的数值使用暗淡的颜色。

import numpy as np
import matplotlib.pyplot as plt

# 创建示例数据
data = np.random.rand(10, 10)  # 生成一个10x10的随机数据矩阵

# 创建值热力图
plt.imshow(data, cmap='YlOrRd', aspect='auto')  # 使用YlOrRd颜色映射
plt.colorbar()  # 添加颜色条
plt.title('Value Heatmap Example')
plt.xlabel('X Axis')
plt.ylabel('Y Axis')
plt.show()

在这个示例中,我们执行了以下步骤:

  1. 导入必要的库,包括 NumPy 和 Matplotlib。
  2. 创建一个随机的 10x10 数据矩阵,你可以用自己的数据替代这个示例数据。
  3. 使用 imshow 函数来显示值热力图。参数 cmap 用于选择颜色映射,这里使用了 'YlOrRd' 颜色映射,但你可以根据需要选择其他颜色映射。aspect='auto' 参数用于自动调整图像的纵横比以适应数据。
  4. 使用 colorbar() 函数添加颜色条,以便查看颜色与数值之间的对应关系。
  5. 添加标题、坐标轴标签等可选的图形元素。
  6. 最后,使用 show() 函数来显示热力图。

4 密度热力图(Density Heatmap)

通常用来表示数据点的集中程度和分布密度,较高的密度区域会显示为较深的颜色,而较低的密度区域则显示为较浅的颜色。以下是一个使用 Matplotlib 创建密度热力图的示例和代码: 

import numpy as np
import matplotlib.pyplot as plt

# 创建示例数据
x = np.random.randn(1000)  # 随机生成1000个数据点
y = np.random.randn(1000)

# 创建密度热力图
plt.hist2d(x, y, bins=(50, 50), cmap='Blues')
plt.colorbar()  # 添加颜色条
plt.title('Density Heatmap Example')
plt.xlabel('X Axis')
plt.ylabel('Y Axis')
plt.show()

在这个示例中,我们执行了以下步骤:

  1. 导入必要的库,包括 NumPy 和 Matplotlib。
  2. 创建两个随机数据数组 xy,这些数据点将用于创建密度热力图。
  3. 使用 hist2d 函数来创建密度热力图。参数 xy 是数据点的坐标,bins 参数用于指定在 x 和 y 方向上的直方图箱的数量。颜色映射使用 'Blues',你可以选择其他颜色映射。
  4. 使用 colorbar() 函数添加颜色条,以便查看颜色与密度之间的对应关系。
  5. 添加标题、坐标轴标签等可选的图形元素。
  6. 最后,使用 show() 函数来显示密度热力图。

5 时间热力图(Time Heatmap):

时间热力图将时间作为一个维度,用颜色的强度表示特定时间段内的某种事件或指标的变化趋势。

import numpy as np
import matplotlib.pyplot as plt
import pandas as pd

# 创建示例数据
date_rng = pd.date_range(start='2023-01-01', end='2023-12-31', freq='D')
data = np.random.rand(len(date_rng), 24)  # 每天24小时的随机数据

# 创建时间热力图
plt.imshow(data, cmap='YlGnBu', aspect='auto')
plt.colorbar()  # 添加颜色条
plt.title('Time Heatmap Example')
plt.xlabel('Hour of the Day')
plt.ylabel('Date')
plt.show()

 

6 空间热力图(Spatial Heatmap)

通常用于表示地理区域内的数据分布情况,其中颜色的强度表示数据的集中程度。

在这里,展示如何使用 Matplotlib 创建一个基本的空间热力图示例,其中我们将使用随机生成的地理坐标和值来演示。 

import numpy as np
import matplotlib.pyplot as plt

# 创建示例数据
np.random.seed(0)  # 设置随机种子以确保结果可重复
num_points = 100  # 生成100个数据点
latitude = np.random.uniform(37.0, 42.0, num_points)  # 随机生成纬度坐标
longitude = np.random.uniform(-120.0, -115.0, num_points)  # 随机生成经度坐标
values = np.random.uniform(0, 1, num_points)  # 为每个点生成随机值

# 创建空间热力图
plt.scatter(longitude, latitude, c=values, cmap='viridis', s=100)
plt.colorbar(label='Value')
plt.title('Spatial Heatmap Example')
plt.xlabel('Longitude')
plt.ylabel('Latitude')
plt.show()

 

在这个示例中,我们执行了以下步骤:

  1. 我们使用 NumPy 生成了100个随机的地理坐标点,包括纬度(latitude)和经度(longitude)坐标。
  2. 对于每个点,我们生成了一个随机的值(在0到1之间),这将用于表示数据点的强度。
  3. 使用 plt.scatter 函数绘制散点图,其中 c 参数表示颜色,我们使用 'viridis' 颜色映射来表示数据值的不同强度。
  4. 我们添加了颜色条(colorbar)以解释颜色与数值之间的关系。
  5. 添加标题和坐标轴标签以增强图形的可读性。

7 渐变热力图(Gradient Heatmap)

        渐变热力图(Gradient Heatmap)用平滑的颜色过渡来表示数值或密度的变化程度。

        以下是使用 Matplotlib 创建一个简单的渐变热力图示例,其中我们将使用 NumPy 生成一个二维的数值数据并将其可视化。

import numpy as np
import matplotlib.pyplot as plt

# 创建示例数据
x = np.linspace(0, 10, 100)
y = np.linspace(0, 10, 100)
X, Y = np.meshgrid(x, y)
Z = np.sin(X) + np.cos(Y)  # 这里使用一个简单的二维函数作为示例数据

# 创建渐变热力图
plt.contourf(X, Y, Z, cmap='coolwarm', levels=20)
plt.colorbar(label='Value')
plt.title('Gradient Heatmap Example')
plt.xlabel('X')
plt.ylabel('Y')
plt.show()

在这个示例中,我们执行了以下步骤:

  1. 使用 NumPy 创建了一个网格点 (X, Y),其中 XY 分别是 xy 值的网格。
  2. 我们定义了一个简单的二维函数 Z,在这个示例中,我们使用了 sin(X) + cos(Y) 作为示例函数。
  3. 使用 plt.contourf 函数创建渐变热力图。我们使用 'coolwarm' 颜色映射来表示数值变化,levels 参数指定了渐变的级别数量。
  4. 我们添加了颜色条以解释颜色与数值之间的关系。
  5. 添加了标题和坐标轴标签以提高图形的可读性。

这个示例生成了一个渐变热力图,其中颜色的渐变表示数值的变化程度。你可以将示例数据替换为你自己的二维数据,以生成符合你需求的渐变热力图。

8 3D热力图

        通常使用密度分布来表示数据的三维分布。以下是一个使用Matplotlib创建3D密度热力图的示例,其中我们将使用NumPy生成数据并可视化它:

import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D

# 创建示例数据
np.random.seed(0)
x = np.random.randn(1000)
y = np.random.randn(1000)

# 创建3D图形
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')

# 创建3D密度热力图
hist, xedges, yedges = np.histogram2d(x, y, bins=40)
xpos, ypos = np.meshgrid(xedges[:-1] + 0.25, yedges[:-1] + 0.25, indexing="ij")
xpos = xpos.ravel()
ypos = ypos.ravel()
zpos = 0
dx = dy = 0.5
dz = hist.ravel()

ax.bar3d(xpos, ypos, zpos, dx, dy, dz, cmap='viridis')

# 设置坐标轴标签
ax.set_xlabel('X')
ax.set_ylabel('Y')
ax.set_zlabel('Density')

# 显示图形
plt.show()

 

在这个示例中,我们执行了以下步骤:

  1. 我们使用NumPy生成了两个随机数据数组xy,共1000个数据点,这些数据点将用于创建3D密度热力图。

  2. 创建了一个包含3D子图的图形fig

  3. 使用histogram2d函数生成xy的二维直方图,将数据点分成40个箱子。

  4. 使用bar3d函数在3D子图中绘制3D密度热力图。我们使用'viridis'颜色映射来表示密度的变化。

  5. 设置了坐标轴标签。

  6. 最后,使用plt.show()函数来显示3D密度热力图。

这个示例生成了一个3D密度热力图,其中颜色深度表示数据点的密度分布。你可以将示例数据替换为自己的数据,以生成符合你需求的3D密度热力图。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1034787.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C语言实现获取文件大小(字节数)

首先使用如下命令在当前文件夹,创建一个大小为1234578字节的空白文件: fsutil file createnew ./test.bin 12345678关于fsutil命令的介绍:Windows快速创建任意大小的空白文件 使用十六进制编辑器打开,可以看到内容全是0&#xf…

滴滴一面:线程池任务,如何设置优先级?

说在前面 在40岁老架构师 尼恩的读者交流群(50)中,最近有小伙伴拿到了一线互联网企业如滴滴、极兔、有赞、希音、百度、网易的面试资格,遇到很多很重要的面试题: 如何设计线程池?请手写一个简单线程池? 就在昨天&…

肖sir__mysql之综合题练习__013

数据库题(10*5) 下面是一个学生与课程的数据库,三个关系表为: 学生表S(Sid,SNAME,AGE,SEX) 成绩表SC(Sid,Cid,GRADE) 课程表C(Cid&…

linux进程杀不死

项目场景: 虚拟机 问题描述 linux进程杀不死 无反应 原因分析: 进程僵死zombie 解决方案: 进proc或者find命令找到进程所在地址 cat status查看进程杀死子进程

【AI视野·今日CV 计算机视觉论文速览 第252期】Fri, 22 Sep 2023

AI视野今日CS.CV 计算机视觉论文速览 Fri, 22 Sep 2023 Totally 90 papers 👉上期速览✈更多精彩请移步主页 Interesting: 📚SVGCustomization, 基于文本的矢量图生成定制(from 香港城市大学)。 website:https://intchous.github.io/SVGCustomization/ …

OVS-DPDK/虚拟化学习

用户/内核空间虚拟化 NFV和Middlebox的不同数据平面模型,具有不同的虚拟交换机选项、虚拟设备接口和虚拟化框架:(a)基于内核的vSwitch virtio-user/vhost-net和TUN/TAP VM;(b)基于内核的vSwitch virtio-user/vhost-net和TUN/TAP contain…

什么算泄露公司机密的行为(什么程度算公司泄密行为)

在当今的商业环境中,保护公司的核心竞争力和商业机密是至关重要的。然而,员工可能出于各种原因泄露这些信息,包括对竞争对手的追求、个人利益的驱动或者对工作的不满。在这种情况下,企业需要依赖专业的调查工具来揭示和证明员工的…

OpenGL之相机

OpenGL本身没有摄像机(Camera)的概念,但我们可以通过把场景中的所有物体往相反方向移动的方式来模拟出摄像机,产生一种我们在移动的感觉,而不是场景在移动。 本节我们将会讨论如何在OpenGL中配置一个摄像机,并且将会讨论FPS风格的…

Nginx使用指南

文章目录 前言一、源码编译1.1 编译1.2 第三方模块编译 二、配置文件2.1 配置语法2.2 location语法2.3 配置文件块2.4 全局变量 三、HTTP 服务器3.1 基本3.2 反向代理3.3 压缩3.4 负载均衡3.5 HTTPS 支持3.6 UrlRewrite3.7 防盗链配置3.8 跨域3.9 静态服务3.10 PC/手机端分离3.…

Web3 solidity编写fillorder填充订单函数 并梳理讲述逻辑

好 经过上文 Web3 solidity编写cancelorder取消订单函数 并梳理讲述逻辑 我们成功编写了 cancelorder 取消订单函数 其实 做了取消订单 填充订单 已经是非常简单的事了 我们还是先起来ganache 虚拟环境 这里 我们 模仿 orderCancel 在做一存储结构 //存储被填充订单 mapping…

追光者的梦

追光者的梦 鸿蒙中我茫然于世,你是钻入我心里的那束光 我所有的梦想都是和你热烈的拥抱 没有追到你时,我一直在路上 追到你时,我的人生就被你点燃 ——致所有的追光者 合肥先进光源国家重大科技基础设施项目及配套工程启动会刚开过&…

go学习之数组与Map

文章目录 一、数组1.为什么需要数组2.数组快速入门3、数组的定义和内存布局数组的使用数组的遍历数组的注意事项和细节数组的应用案例 4.slice切片1.基本介绍2.切片使用的三种方式way1way2way3 3.切片的注意事项4.string和slice 5.二维数组1.排序1)排序的基本介绍2&…

uni-app实现获取未来七天时间和星期几功能

例子如下&#xff1a; HTML&#xff1a; <viewstyle"margin-top: 3%;width: 100%;height: 10vh;display: flex;justify-content: space-around;"><div v-for"(item,index) in same_week" :class"[same_dayitem.date? activ :,dis]"cl…

在虚拟机上安装win10/ubuntu的教程

以下内容源于网络资源的学习与整理&#xff0c;如有侵权请告知删除。 一、下载软件资源 1、首先下载虚拟机Vmware_Pro17软件并正确安装&#xff1a;网盘链接 2、然后下载操作系统的镜像文件&#xff1a;MSDN, 我告诉你 - 做一个安静的工具站 二、在虚拟机上安装ubuntu系统 1…

EXP武器库编写

文章目录 pocsuite3工具SQL注入EXP布尔盲注优化最终优化 延时注入 phpstudy2016-2018-RCE利用DVWA文件上传metinfo_5.0.4EXPSQL-布尔盲注文件包含漏洞 定制SQLmaptamper脚本sqli-labs/less-26关卡分析 tamper脚本编写 python是黑客最喜欢的编程语言之一&#xff0c;但同时go语言…

基于AVR128单片机智能电风扇控制系统

一、系统方案 模拟的电风扇的工作状态有3种&#xff1a;自然风、常风及睡眠风。使用三个按键S1-S3设置自然风、常风及睡眠风。 再使用两个按键S4和S5&#xff0c;S4用于定时电风扇定时时间长短的设置&#xff0c;每按一次S4键&#xff0c;定时时间增加10秒&#xff0c;最长60秒…

C/C++程序员技术发展方向(强烈推荐!!)

大家好&#xff0c;我是阿Q。 今天这篇就是专门给现在还迷茫不知道自己到底要做什么方向C开发的同学们。 几年后回过头看的时候&#xff0c;你一定会感谢当初那个努力的自己&#xff01; C作为当下也非常流行的一个面向对象语言&#xff0c;有着非常多的应用&#xff0c;一定…

RHCSA 文件的上传下载(Linux-Windows)

目录 一、SCP 上传&#xff08;Windows--->Linux&#xff09;&#xff1a; 下载&#xff08;Linux--->Windows&#xff09;&#xff1a; 二、STFP 三、XFTP工具 一、SCP 上传&#xff08;Windows--->Linux&#xff09;&#xff1a; 在Windows本地端命令窗口中转…

基因组注释(Annotation)

基因组组装完成后&#xff0c;或者是完成了草图&#xff0c;就不可避免遇到一个问题&#xff0c;需要对基因组序列进行注释。注释之前首先得构建基因模型&#xff0c;有三种策略&#xff1a; 从头注释(de novo prediction)&#xff1a;通过已有的概率模型来预测基因结构&#…