如何使用 Python Matplotlib 绘制 3D 曲面图

news2025/7/18 10:49:04

在数据可视化中,3D 图表是一个非常有用的工具,特别是当想要展示复杂的三维数据时,如期权的波动率曲面。Python 的 matplotlib 库提供了生成各种类型图表,包括 3D 图表。

本文将介绍如何使用 Python 中的 matplotlib 绘制 3D 曲面图,适用于不同领域的数据可视化需求。

准备工作

安装 matplotlib,命令如下:

pip install matplotlib

绘制简单的 3D 曲面图

引入所需库:为了绘制 3D 图形,我们需要使用 matplotlib 中的 Axes3Dplot_surface 方法。为了演示,还要引入 numpy 生成绘图数据。

import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D # 显式导入Axes3D,确保版本兼容

生成演示数据:3D 曲面图通常是由一个三维网格点组成的,其中 X 轴和 Y 轴分别代表行和列,Z 轴表示每个网格点的高度值。我们可以使用 numpy 来生成 X 和 Y 轴的网格,同时基于 X 和 Y 生成 Z 的值。

# 使用 numpy 生成 X 和 Y 的数据
x = np.linspace(-5, 5, 100)  # 生成从 -5 到 5 的 100 个等间距的点
y = np.linspace(-5, 5, 100)  # 同样为 Y 轴生成相同范围的点

# 生成二维网格
X, Y = np.meshgrid(x, y)

# 定义 Z 轴数据,使用一个简单的函数 Z = f(X, Y)
Z = np.sin(np.sqrt(X**2 + Y**2))

在这个例子中,Z 轴数据是 XY 的平方和的平方根的正弦值,我将使用这个数据绘制曲面。

绘制 3D 曲面图

接下来使用 matplotlibplot_surface 方法来绘制曲面。

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

# 绘制 3D 曲面图
surf = ax.plot_surface(X, Y, Z, cmap='viridis')

# 为图表添加颜色条
fig.colorbar(surf)

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

# 显示图形
plt.show()

运行此代码后,您将看到一个 3D 曲面图。

了解了基本的 3D 曲面图绘制后,接下来开始探讨一些更高级的特性,如自定义颜色、设置透明度、添加线框等。

添加线框和透明度

有时,在 3D 曲面图上添加线框或调整透明度可以帮助我们更好地理解数据结构。以下代码展示了如何添加这些特性。

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

# 绘制带线框的 3D 曲面图,alpha 用于设置透明度
surf = ax.plot_surface(X, Y, Z, cmap='plasma', edgecolor='none', alpha=0.8)

# 添加网格线框(wireframe)
ax.plot_wireframe(X, Y, Z, color='black', linewidth=0.5)

# 为图表添加颜色条
fig.colorbar(surf)

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

# 显示图形
plt.show()

示例中,通过 plot_wireframe() 添加了网格线框,颜色映射使用了 plasma,通过 alpha=0.8 设置了透明度为 80%。

效果如下所示:

控制图形视角

matplotlib 提供了对 3D 图形视角的控制。可以通过 ax.view_init() 来设置视角(即观察图形的角度),elev 参数设置仰角,azim 参数设置方位角。

# 设置 60 仰角和 45 方位角
ax.view_init(elev=60, azim=45)

通过调整这些参数,您可以从不同的角度观察 3D 曲面图。

Matplotlib 中绘制 3D 曲面图要点

  1. 创建数据网格:使用 numpy.meshgrid 生成二维的 X 和 Y 网格,并根据需要定义 Z 轴的值。
  2. 绘制曲面图:使用 matplotlibplot_surface() 方法来绘制 3D 曲面,使用 cmap 来调整颜色映射。
  3. 自定义图形:可以添加透明度、线框,或者通过自定义函数来生成 Z 轴数据。同时,还可以通过 view_init() 调整视角。
  4. 可视化增强:为图形添加颜色条,调整坐标轴标签,使用不同的颜色映射函数来使数据更加清晰。

更多可用的颜色映射(colormap)

matplotlib 提供了丰富的颜色映射方案,您可以使用 cmap 参数来指定:

  • 'viridis':默认色彩映射,适用于一般数据
  • 'plasma':对比度较高的配色方案
  • 'inferno':适合视觉对比
  • 'coolwarm':常用于正负值数据

例如:

surf = ax.plot_surface(X, Y, Z, cmap='coolwarm')

总结

使用 matplotlib 绘制 3D 曲面图帮助我们可视化复杂的三维数据。通过掌握基础的网格生成和绘图函数,以及对图形的进一步自定义和优化,就可轻松创建适合您需求的 3D 可视化图表。

本文介绍了从基础的 3D 曲面图绘制方法,希望对你有所帮助。

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

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

相关文章

分公司=一部门——组合模式

文章目录 分公司一部门——组合模式分公司不就是一部门吗?组合模式透明方式与安全方式何时使用组合模式公司管理系统组合模式好处 分公司一部门——组合模式 分公司不就是一部门吗? 时间:5月10日19点  地点:小菜、大鸟住所的客…

开放的数据时代:Web3和个人隐私的未来

在数字化和信息化的时代,数据隐私成为了公众关注的焦点。随着Web3技术的兴起,个人隐私保护进入了一个新的阶段。Web3作为去中心化的互联网架构,提出了对数据控制和隐私保护的新方案。本文将探讨Web3如何影响个人隐私的未来,并分析…

[附源码]SpringBoot+VUE+Java实现人脸识别系统

今天带来一款优秀的项目:java人脸识别系统源码 。 系统采用的流行的前后端分离结构,内含功能包括 “人脸数数据录入”,“人脸管理”,“摄像头识别” 如果您有任何问题,也请联系小编,小编是经验丰富的程序员…

编写程序,在一行上显示1-5数字,每个相邻的数字要求用空格进行分开

目录 前言 一、一行输出(使用一个System语句输出) 二、多行输出(使用多(N)个System语句输出) 三、循环输出(使用for语句循环在通过System语句输出) 四、完整代码 前言 1.本文所…

只会Python编程,做量化交易策略用QMT怎么样?听说QMT是支持Python的!

QMT是专门为机构、活跃投资者、高净值客户等专业投资者研发的智能量化交易终端,拥有高速行情、极速交易、策略交易、多维度风控等专业功能,满足专业投资者的特殊交易需求。覆盖业务范围广:沪深A股、港股通、两融、期权、期货。 适合用QMT的投资者&#x…

使用 UWA Gears 定位游戏内存问题

UWA Gears 是UWA最新发布的无SDK性能分析工具。针对移动平台,提供了实时监测和截帧分析功能,帮助您精准定位性能热点,提升应用的整体表现。 内存不足、内存泄漏和过度使用等问题,常常导致游戏出现卡顿、崩溃,甚至影响…

偷偷告诉你,学会使用这几样测试用例管理工具就够啦!

在软件开发过程中,测试是必不可少的一环,而测试用例则是测试的重要依据。如何有效地管理测试用例,提高测试效率,是每一个测试人员都需要面对的问题。本文将为你介绍几款实用的测试用例管理工具,帮助你更好地进行测试工…

2024年双十一不容错过的好物分享,最值得买的五款单品

双十一购物狂欢节将至,这是一场属于“剁手党”的年度盛宴。每年的11月11日,各大电商平台纷纷推出海量优惠活动,吸引无数消费者积极参与。对于热衷于寻找好物的人来说,双十一无疑是一个不容错过的机会,双十一好物不间断…

基于JavaWeb开发的java+Springboot操作系统教学交流平台详细设计实现

基于JavaWeb开发的javaSpringboot操作系统教学交流平台详细设计实现 🍅 作者主页 网顺技术团队 🍅 欢迎点赞 👍 收藏 ⭐留言 📝 🍅 文末获取源码联系方式 📝 🍅 查看下方微信号获取联系方式 承接…

零基础制作一个ST-LINK V2 附PCB文件原理图 AD格式

资料下载地址:零基础制作一个ST-LINK V2 附PCB文件原理图 AD格式 ST-LINK/V2是一款可以在线仿真以及下载STM8以及STM32的开发工具。支持所有带SWIM接口的STM8系列单片机;支持所有带JTAG / SWD接口的STM32系列单片机。 基本属性 ST-LINK/V2是ST意法半导体为评估、开…

【我的 PWN 学习手札】劫持 tcache_perthread_struct

目录 前言 一、tcache perthread struct 二、劫持 tcache_perthread_struct 三、测试与模板 前言 tcache 是 glibc 2.26 (ubuntu 17.10) 之后引入的一种技术,目的是提升堆管理的性能,与 fast bin 类似。 tcache 引入了两个新的结构体, tc…

idear导入他人项目如何快速运行

最近idear经常导入别人的项目,结果永远在加载依赖项。网上查了一堆资料,什么jdk问题,环境变量问题,maven仓库路径问题,总之就是没啥用。那有没有什么简单粗暴的办法,能够导入项目后快速运行呢。 解决方法&a…

独立站技能树之建站33项自检清单 1.0丨出海笔记

很多时候大家建好站之后很嗨,但过一会就开始担忧各种纠结我是不是还有什么点没做好,或者我的站漏了什么东西,那么接下来以下这个独立站自检清单能很好的帮到你。其实对于新手我还是建议大家直接用一些模板,因为模板上面基本该有的…

Gitee丝滑版本:成功在新电脑添加新文件

git 关键步骤 1.首先在新电脑建一个文件夹,然后打开这个文件夹里面右键打开OPEN BASH GIT HERE。 2.然后输入git init,会在文件夹生成一个git.文件,接着把复制的get clone命令克隆过去就可以下载了,如果遇到403问题&#xff0c…

【机器学习】从数据到决策——完整的机器学习项目实战解析

【机器学习】从数据到决策——完整的机器学习项目实战解析 1. 引言 机器学习项目不仅仅是训练一个模型,它涉及从数据预处理到模型评估的完整流程。本文将通过一个完整的机器学习项目,展示从数据准备到最终决策的关键步骤。这将帮助你理解如何系统地构建…

9-----MTK专用工具 MTKpro解锁 读取分区 备份nv 檫除nv 工具预览与步骤解析

以上工具包含原版与汉化版工具。根据上面图示 可以看到此工具可以刷写mtk机型,包含有刷机的各个加载选项以及刷写方式。其中动画界面演示了无需加载任何引导。联机就可以读取到当前机型分区的演示。 工具功能选项 ★★★★★不需要任何引导直接读取mtk分区 备份 檫除 写入分…

shinyproxy部署R语言shiny APP

shinyproxy部署shiny APP经验谈 shinyAPP 是成熟的web APP框架,依靠R语言的数据分析功能可以构建功能丰富的,外表美观的web APP,但是APP部署是shiny APP最大的瓶颈,免费部署途径有诸多的限制,收费的部署方式价格昂贵。…

解析碳化硅MOSFET B2M030120Z的卓越性能与应用前景

碳化硅MOSFET具有优秀的高频、高压、高温性能,是目前电力电子领域最受关注的宽禁带功率半导体器件。在电力电子系统中应用碳化硅MOSFET器件替代传统硅IGBT器件,可提高功率回路开关频率,提升系统效率及功率密度,降低系统综合成本。…

【数据结构】排序算法---归并排序

文章目录 1. 定义2. 算法步骤3. 动图演示4. 性质5. 算法分析6. 代码实现C语言——迭代版C语言——递归版PythonJavaC——迭代版C——递归版Go 结语 1. 定义 归并排序(Merge sort)是建立在归并操作上的一种有效的排序算法。该算法是采用分治法&#xff0…

Java语言程序设计基础篇_编程练习题*18.28 (非递归目录大小)

目录 题目:*18.28 (非递归目录大小) 习题思路 代码示例 输出结果 题目:*18.28 (非递归目录大小) 不使用递归改写程序清单18-7 习题思路 ( getSize方法) 创建一个变量表示总共的大小。传入路径,创建File文件。创建A…