Python 三维图表绘制指南

Python 三维图表绘制指南

在数据可视化中,三维图表可以更直观地展示数据之间的关系,尤其是当数据具有多个维度时。Python 提供了多个库来绘制三维图表,其中最常用的就是 Matplotlib。本文将介绍如何使用 Matplotlib 绘制三维图表,包括三维散点图、三维线图、三维表面图、三维直方图等。

在这里插入图片描述

1. 安装与导入 Matplotlib

在开始之前,请确保已经安装了 Matplotlib。如果未安装,可以使用以下命令进行安装:

pip install matplotlib

安装完成后,可以通过以下方式导入库:

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

2. 创建三维图表的基础知识

在 Matplotlib 中,绘制三维图表需要使用 mpl_toolkits.mplot3d 中的 Axes3D。首先,需要创建一个三维坐标系,然后才能在其上绘制图表。

2.1 创建三维坐标系

使用 plt.figure() 创建一个新的图形窗口,然后使用 fig.add_subplot() 添加一个三维坐标系:

fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')

这里 111 表示一个 1x1 的子图,并选择第一个图(即唯一的一个图)。projection='3d' 是关键,表示这是一个三维图。

3. 三维散点图

三维散点图用于展示数据点在三维空间中的分布情况。以下是绘制三维散点图的示例:

# 生成数据
n = 100
x = np.random.rand(n)
y = np.random.rand(n)
z = np.random.rand(n)

# 创建图形和三维坐标系
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')

# 绘制散点图
ax.scatter(x, y, z, c='r', marker='o')  # 'c' 设置颜色,'marker' 设置点的样式
ax.set_xlabel('X 轴')
ax.set_ylabel('Y 轴')
ax.set_zlabel('Z 轴')
ax.set_title('三维散点图示例')
plt.show()

3.1 散点图参数解释

  • c='r':设置点的颜色为红色。
  • marker='o':设置点的形状为圆形。
  • ax.set_xlabelax.set_ylabelax.set_zlabel:设置坐标轴的标签。

4. 三维线图

三维线图适合用来展示数据点之间的关系,可以显示随时间变化的趋势。以下是绘制三维线图的示例:

# 生成数据
x = np.linspace(0, 5, 100)
y = np.sin(x)
z = np.cos(x)

# 创建图形和三维坐标系
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')

# 绘制三维线图
ax.plot(x, y, z, color='b', linewidth=2)  # 'b' 设置线条颜色
ax.set_xlabel('X 轴')
ax.set_ylabel('Y 轴')
ax.set_zlabel('Z 轴')
ax.set_title('三维线图示例')
plt.show()

4.1 线图参数解释

  • ax.plot:用于绘制三维线图。
  • linewidth=2:设置线条宽度。

5. 三维表面图

三维表面图用于展示具有表面特征的数据,如地形图、热图等。以下是绘制三维表面图的示例:

# 生成数据
x = np.linspace(-5, 5, 100)
y = np.linspace(-5, 5, 100)
x, y = np.meshgrid(x, y)
z = np.sin(np.sqrt(x**2 + y**2))

# 创建图形和三维坐标系
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')

# 绘制三维表面图
ax.plot_surface(x, y, z, cmap='viridis')  # 使用 viridis 颜色映射
ax.set_xlabel('X 轴')
ax.set_ylabel('Y 轴')
ax.set_zlabel('Z 轴')
ax.set_title('三维表面图示例')
plt.show()

5.1 表面图参数解释

  • np.meshgrid:生成网格坐标。
  • ax.plot_surface:用于绘制三维表面图,cmap 参数设置颜色映射。

6. 三维直方图

三维直方图用于展示数据的分布情况,可以帮助我们分析数据的特征。以下是绘制三维直方图的示例:

# 生成数据
data = np.random.randn(1000)

# 创建图形和三维坐标系
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')

# 绘制三维直方图
hist, xedges, yedges = np.histogram2d(data, data, bins=30)

# 创建 X 和 Y 的网格
xpos, ypos = np.meshgrid(xedges[:-1], yedges[:-1], indexing="ij")
xpos = xpos.ravel()
ypos = ypos.ravel()
zpos = 0

# 设置柱子的高度
dx = dy = 0.5 * np.ones_like(zpos)
dz = hist.ravel()

# 绘制柱状图
ax.bar3d(xpos, ypos, zpos, dx, dy, dz, zsort='average')
ax.set_xlabel('X 轴')
ax.set_ylabel('Y 轴')
ax.set_zlabel('频率')
ax.set_title('三维直方图示例')
plt.show()

6.1 直方图参数解释

  • np.histogram2d:计算二维直方图。
  • ax.bar3d:用于绘制三维柱状图。

7. 自定义三维图表

7.1 设置图例

在三维图表中,我们同样可以添加图例,以帮助观众理解数据的含义:

fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')

# 绘制多个数据集
ax.scatter(x, y, z, c='r', marker='o', label='数据点1')
ax.scatter(x+1, y+1, z+1, c='g', marker='^', label='数据点2')
ax.legend()  # 添加图例
plt.show()

7.2 设置视角

可以通过 ax.view_init 方法来调整三维图的视角,以便更好地查看数据:

ax.view_init(elev=20, azim=30)  # 设置观察角度

7.3 保存图表

使用 plt.savefig() 方法可以将图表保存为文件:

plt.savefig('3d_plot.png')  # 保存为 PNG 格式

8. 结合其他库进行三维可视化

除了 Matplotlib,Python 还有其他库可以进行三维可视化,比如 MayaviPlotly。这两个库在交互性和效果上有更好的表现,可以根据具体需求选择使用。

8.1 使用 Plotly 绘制三维图

Plotly 是一个强大的图形库,可以轻松绘制交互式图表。以下是绘制三维散点图的示例:

import plotly.express as px
import pandas as pd

# 生成数据
n = 100
df = pd.DataFrame({
    'x': np.random.rand(n),
    'y': np.random.rand(n),
    'z': np.random.rand(n)
})

# 绘制三维散点图
fig = px.scatter_3d(df, x='x', y='y', z='z')
fig.show()

8.2 使用 Mayavi 绘制三维表面图

Mayavi 是一个用于 3D 数据可视化的库,尤其适合科学计算。以下是一个简单的示例:

from mayavi import mlab
import numpy as np

# 生成数据
x = np.linspace(-5, 5, 100)
y = np.linspace(-5, 5, 100)
x, y = np.meshgrid(x, y)
z = np.sin(np.sqrt(x**2 + y**2))

# 绘制三维表面图
mlab.surf(x, y, z)
mlab.show()

9. 总结

通过本文的介绍,相信您已经掌握了如何使用 Python 中的 Matplotlib 绘制三维图表。我们讨论了三维散点图、线图、表面图、直方图等的绘

制方法,并展示了如何自定义图表属性和设置图例。此外,还提到了一些其他库(如 Plotly 和 Mayavi)用于三维可视化的使用场景。

三维图表可以帮助我们更好地理解和分析数据,在实际应用中,我们可以根据具体的需求选择合适的图表类型和库。希望本文能为您的数据可视化之旅提供一些帮助!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Node.js:Express 服务 路由

Node.js:Express 服务 & 路由 创建服务处理请求req对象 静态资源托管托管多个资源挂载路径前缀 路由模块化 Express是Node.js上的一个第三方框架,可以快速开发一个web框架。本质是一个包,可以通过npm直接下载。 创建服务 Express创建一…

计算机网络-以太网小结

前导码与帧开始分界符有什么区别? 前导码--解决帧同步/时钟同步问题 帧开始分界符-解决帧对界问题 集线器 集线器通过双绞线连接终端, 学校机房的里面就有集线器 这种方式仍然属于共享式以太网, 传播方式依然是广播 网桥: 工作特点: 1.如果转发表中存在数据接收方的端口信息…

学生成绩查询系统设计与实现

学生成绩查询系统设计与实现 1. 系统概述 学生成绩查询系统是一个基于PHP和SQL的Web应用程序,旨在为学校提供一个高效的学生成绩管理和查询平台。该系统可以帮助教师录入成绩、学生查询成绩、管理员管理用户和成绩数据,提高教育管理的效率和透明度。 2…

Rust 力扣 - 2653. 滑动子数组的美丽值

文章目录 题目描述题解思路题解代码题目链接 题目描述 题解思路 我们遍历长度为k的的窗口 因为数据范围比较小,所以我们可以通过计数排序找到窗口中第k小的数 如果小于0,则该窗口的美丽值为第k小的数如果大于等于0,则该窗口的美丽值为0 题…

VisualStudio远程编译调试linux_c++程序(二)

前章讲述了gdb相关,这章主要讲述用VisualStudio调试编译linux_c程序 1:环境 win10 VisualStudio 2022 Community ubuntu22.04 2:安装 1>vs安装时,勾选 使用c进行linux 和嵌入式开发 (这里以vs2022为例) OR VS安装好了, 选择工…

音视频听译:助力多维度沟通与发展的大门

在全球经济一体化的大背景下,企业之间的跨国合作愈发频繁。在商务会议、谈判和产品演示等活动中,语言的多样性成为了一大挑战。而音视频听译服务能够将不同语言的音频准确转换为目标语言文字,确保信息的精准传达,避免因语言障碍引…

基于MATLAB人脸检测的汽车疲劳驾驶检测

课题介绍 疲劳驾驶导致汽车交通事故逐年增加,为了提升驾车的安全性,需对驾驶员疲劳状态实时监测并及时提醒. 为了提高疲劳驾驶判断效率及准确率,本文运用Viola-Jones 框架特征矩阵进行人脸预判断;预判断过程中为了减少Haar 值计算…

论文阅读(三十二):EGNet: Edge Guidance Network for Salient Object Detection

文章目录 1.Introduction2.Related Works3.Salient Edge Guidance Network3.1Complementary information modeling3.1.1Progressive salient object features extraction3.1.2Non-local salient edge features extraction 3.2One-to-one guidance module 4.Experiments4.1Imple…

MySQL超大分页怎么优化处理?limit 1000000,10 和 limit 10区别?覆盖索引、面试题

1. limit 100000,10 和 limit 10区别 LIMIT 100000, 10: 这个语句的意思是,从查询结果中跳过前100000条记录,然后返回接下来的10条记录。这通常用于分页查询中,当你需要跳过大量的记录以获取后续的记录时。例如,如果你…

源码侦探:理解 numpy 中的 tile 方法

文章目录 pre :先来一张源码的切片1. 参数和基本定义:2. 将 reps 转换为元组:3. 提升数组维度:4. 特殊情况检查:5. 处理数组维度的不同情况:6. 计算输出数组的形状:7. 通过重复构造数组&#xf…

单链表OJ题(3):合并两个有序链表、链表分割、链表的回文结构

目录 一、合并两个有序链表 二、链表分割 三、链表的回文结构 u解题的总体思路: 合并两个有序链表:首先创建新链表的头节点(哨兵位:本质上是占位子),为了减少一些判断情况,简化操作。然后我们…

Qt6 CMake 中引入 Qt Linguist 翻译功能

qt cmake 使用自带翻译工具配置步骤 创建Qt CMake 程序配置项目 CMake 及 代码使用流程最终CMake 如下最终工程链接为:参考 创建Qt CMake 程序 配置项目 CMake 及 代码 在CMake 中添加如下代码, 导入相关的翻译库 find_package(QT NAMES Qt6 Qt5 REQUIRED COMPON…

Android IPC机制(一)多进程模式

1. 什么是进程? 进程是操作系统分配资源(如 CPU、内存等)的基本单位。简单来说,进程是一个正在执行的程序的实例。每个进程都有自己的内存空间、数据栈和其他辅助数据,用于跟踪进程的执行状态。在 Android 中&#xff…

SQL,力扣题目1767,寻找没有被执行的任务对【递归】

一、力扣链接 LeetCode_1767 二、题目描述 表:Tasks ------------------------- | Column Name | Type | ------------------------- | task_id | int | | subtasks_count | int | ------------------------- task_id 具有唯一值的列。 ta…

《JVM第3课》运行时数据区

无痛快速学习入门JVM,欢迎订阅本免费专栏 运行时数据区结构图如下: 可分为 5 个区域,分别是方法区、堆区、虚拟机栈、本地方法栈、程序计数器。这里大概介绍一下各个模块的作用,会在后面的文章展开讲。 类加载子系统会把类信息…

[ 问题解决篇 ] 解决远程桌面安全登录框的问题

🍬 博主介绍 👨‍🎓 博主介绍:大家好,我是 _PowerShell ,很高兴认识大家~ ✨主攻领域:【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 🎉点赞➕评论➕收藏 养成习…

Vue+element-ui实现网页右侧快捷导航栏 Vue实现全局右侧快捷菜单功能组件

Vue+element-ui实现网页右侧快捷导航栏 Vue实现全局右侧快捷菜单功能组件 可视区域没超过当前屏幕高度时候只显示三个菜单效果 可视区域超过当前屏幕高度时,显示可回到顶部菜单的,当然这个菜单显示条件可以自定义,根据需求设置 然后将这个整体功能创建为一个全局组件 代…

苏州金龙新V系客车创新引领旅游出行未来

10月25日,为期三天的“2024第六届旅游出行大会”在风景秀丽的云南省丽江市落下帷幕。本次大会由中国旅游车船协会主办,全面展示了中国旅游出行行业最新发展动态和发展成就,为旅游行业带来全新发展动力。 在大会期间,备受瞩目的展车…

看门狗电路原理与应用

看门狗的原理与应用 看门狗基本原理 看门狗,英文简称为“Watchdog Timer ”或者“Watchdog”; 本质上就是一个定时器的作用,简单理解就是 MCU发出一个周期性的信号,这个信号是满足看门狗芯片内部计时器的时间限制,则…

Caché/IRIS file2Xml 一个将文件转换成Studio导出的xml格式的工具

file2Xml 一个将文件转换成Studio导出的xml格式的工具 通过此工具可以将本地文件转换成xml格式文件,然后通过Studio导入到服务器中,而不再需要其他工具将文件传至服务器。 下面以为ensemble2016自带的一个示例界面增加背景图为例。 http://localhos…