Python绘制3D曲面图

2024-04-29 11:20
文章标签 python 3d 曲面 绘制

本文主要是介绍Python绘制3D曲面图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

👽发现宝藏

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。【点击进入巨牛的人工智能学习网站】。

探索Python中绘制3D曲面图的艺术

在数据可视化的世界中,3D曲面图是一种强大的工具,能够将复杂的数据模式以清晰直观的方式展现出来。Python提供了多种库和工具,使得创建和定制3D曲面图变得简单而令人兴奋。本文将介绍如何使用Python中的Matplotlib和mpl_toolkits.mplot3d库绘制令人印象深刻的3D曲面图。

准备工作

首先,确保你的Python环境中安装了Matplotlib库。如果还没有安装,可以使用pip进行安装:

pip install matplotlib

导入必要的库

在开始之前,让我们先导入必要的库:

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

创建数据

在我们绘制3D曲面图之前,我们需要创建一些数据。我们可以使用NumPy库来生成一些数据集。这里我们以一个简单的函数为例:

def f(x, y):return np.sin(np.sqrt(x**2 + y**2))

创建网格点

接下来,我们需要定义我们要在曲面上显示的坐标点。我们可以使用numpy.meshgrid函数来生成这些点:

x = np.linspace(-5, 5, 100)
y = np.linspace(-5, 5, 100)
x, y = np.meshgrid(x, y)
z = f(x, y)

绘制3D曲面图

现在,我们已经准备好绘制我们的3D曲面图了。我们可以使用Matplotlib的plot_surface函数来实现:

fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
ax.plot_surface(x, y, z, cmap='viridis')
plt.show()

定制曲面图

我们可以通过一些可选参数来定制我们的曲面图,以使其更具吸引力。例如,我们可以添加轮廓线、更改颜色映射、更改视角等:

fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
ax.plot_surface(x, y, z, cmap='viridis', edgecolor='none')  # 添加轮廓线
ax.view_init(45, 60)  # 更改视角
plt.show()

添加标签和标题

在创建3D曲面图时,添加标签和标题是非常重要的,这样可以使图形更具可读性和易理解性。我们可以通过调用set_xlabelset_ylabelset_zlabel方法来添加坐标轴标签,以及使用set_title方法添加标题:

fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
ax.plot_surface(x, y, z, cmap='viridis', edgecolor='none')
ax.set_xlabel('X Label')
ax.set_ylabel('Y Label')
ax.set_zlabel('Z Label')
ax.set_title('3D Surface Plot')
plt.show()

添加色标

为了更清楚地理解曲面图中数值的含义,我们可以添加一个色标。色标可以显示颜色与数值之间的对应关系。我们可以使用colorbar方法添加色标:

fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
surf = ax.plot_surface(x, y, z, cmap='viridis', edgecolor='none')
fig.colorbar(surf, shrink=0.5, aspect=5)  # 添加色标
ax.set_xlabel('X Label')
ax.set_ylabel('Y Label')
ax.set_zlabel('Z Label')
ax.set_title('3D Surface Plot with Colorbar')
plt.show()

完整示例代码

下面是一个完整的示例代码,包括了所有的定制选项:

import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3Ddef f(x, y):return np.sin(np.sqrt(x**2 + y**2))x = np.linspace(-5, 5, 100)
y = np.linspace(-5, 5, 100)
x, y = np.meshgrid(x, y)
z = f(x, y)fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
surf = ax.plot_surface(x, y, z, cmap='viridis', edgecolor='none')
fig.colorbar(surf, shrink=0.5, aspect=5)  # 添加色标
ax.set_xlabel('X Label')
ax.set_ylabel('Y Label')
ax.set_zlabel('Z Label')
ax.set_title('3D Surface Plot with Colorbar')
plt.show()

通过这些定制选项,我们可以创建出更具信息量和美观度的3D曲面图。掌握这些技巧后,你将能够根据自己的需求创建出各种各样的3D可视化效果。

添加透明度和阴影

除了标签、标题和色标之外,我们还可以通过调整透明度和阴影效果来增强3D曲面图的视觉效果。透明度可以使得曲面图中的数据分布更加清晰,而阴影则可以增加立体感。

fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
surf = ax.plot_surface(x, y, z, cmap='viridis', edgecolor='none', alpha=0.7)  # 调整透明度
fig.colorbar(surf, shrink=0.5, aspect=5)  
ax.set_xlabel('X Label')
ax.set_ylabel('Y Label')
ax.set_zlabel('Z Label')
ax.set_title('3D Surface Plot with Colorbar and Transparency')
plt.show()

此外,我们还可以通过设置shade参数为True来添加阴影效果:

fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
surf = ax.plot_surface(x, y, z, cmap='viridis', edgecolor='none', shade=True)  # 添加阴影
fig.colorbar(surf, shrink=0.5, aspect=5)  
ax.set_xlabel('X Label')
ax.set_ylabel('Y Label')
ax.set_zlabel('Z Label')
ax.set_title('3D Surface Plot with Colorbar and Shadow')
plt.show()

其他定制选项

除了上述提到的定制选项外,Matplotlib还提供了许多其他参数和方法,用于进一步定制3D曲面图,如修改坐标轴范围、设置视角、更改颜色映射等。你可以根据具体的需求来选择合适的选项进行定制。

进一步定制颜色映射

在3D曲面图中,颜色映射是一种重要的视觉工具,它能够帮助我们更直观地理解数据的分布和变化。除了使用内置的颜色映射外,我们还可以自定义颜色映射以满足特定需求。

from matplotlib.colors import Normalizefig = plt.figure()
ax = fig.add_subplot(111, projection='3d')# 自定义颜色映射
norm = Normalize(vmin=np.min(z), vmax=np.max(z))
colors = plt.cm.cool(norm(z))surf = ax.plot_surface(x, y, z, facecolors=colors, shade=False)
ax.set_xlabel('X Label')
ax.set_ylabel('Y Label')
ax.set_zlabel('Z Label')
ax.set_title('Customized 3D Surface Plot with Color Mapping')
plt.show()

添加网格线

有时候,我们希望在3D曲面图中添加网格线以帮助更好地理解数据的分布和形状。我们可以通过设置grid参数为True来添加网格线:

fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
surf = ax.plot_surface(x, y, z, cmap='viridis', edgecolor='none')
fig.colorbar(surf, shrink=0.5, aspect=5)  
ax.set_xlabel('X Label')
ax.set_ylabel('Y Label')
ax.set_zlabel('Z Label')
ax.set_title('3D Surface Plot with Colorbar and Grid')
ax.grid(True)  # 添加网格线
plt.show()

总结

本文介绍了如何使用Python中的Matplotlib库创建令人印象深刻的3D曲面图,并展示了一系列定制选项,包括标签、标题、色标、透明度、阴影、颜色映射和网格线等。通过学习这些技巧,我们能够更好地展示和理解数据,从而为数据可视化工作提供了丰富的可能性。

通过创建3D曲面图,我们可以将复杂的数据模式以直观、清晰的方式呈现出来,帮助我们发现数据中的规律和趋势。定制选项使我们能够根据特定需求调整图形的外观和表现形式,从而更好地满足我们的分析和展示需求。

总而言之,掌握如何创建和定制3D曲面图是数据科学和数据可视化领域中的重要技能之一。希望本文能够为你提供一些启发和帮助,激发你对数据可视化的兴趣,并在实践中不断探索和创新。
在这里插入图片描述

这篇关于Python绘制3D曲面图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/945943

相关文章

Python进度条工具——tqdm

原文链接:http://www.juzicode.com/python-note-tqdm 在安装Python库文件的时候我们经常可以看到这种进度条: 其实Python库中就自带了现成的工具库——tqdm。 tqdm读起来比较拗口,它是从“进程”的阿拉伯语taqaddum简化而来。 安装tqdm 使用pip命令安装: pip install tqdm 基本功能

鼠标绘制的画面如何作为输入纹理

以下内容是笔迹草稿,不便于阅读! 一、鼠标绘制的画面如何作为输入纹理的数据      现在代码中将鼠标绘制的计算全部在CPU端进行计算,然后通过mesh的方式进行初始画面绘制,那么理想的情况是直接通过摄像机拍照的方式将当前的绘制的情况渲染到纹理A中,然后再在Update中将纹理A作为输入纹理传入GPU端,但是事实证明这种方法不可行。    (1)若直接将A作为输入纹理,GPU端无法获得正确的

python manage.py 命令大全

以下是常见的 Django 管理命令列表及其用途: startapp:创建一个新的 Django 应用程序。 startproject:创建一个新的 Django 项目。 runserver:启动开发服务器。 makemigrations:根据你对模型的更改创建迁移文件。 migrate:应用数据库迁移,将模型更改同步到数据库。 createsuperuser:创建超级用户(管理员)

2024OD机试卷-游戏分组 (java\python\c++)

题目:游戏分组 题目描述 部们准备举办一场 王者荣耀 表演赛,有 10 名游戏爱好者参与,分为两队,每队 5 人。 每位参与者都有一个评分,代表着他的游戏水平。为了表演赛尽可能精彩,我们需要把 10 名参赛者分为实力尽量相近的两队。 一队的实力可以表示为这一队 5 名队员的评分总和。 现在给你 10 名参与者的游戏水平评分,请你根据上述要求分队,最后输出这两组的实力差绝对值。 例:10 名参赛

python setup.py install 报错fatal error: Python.h: No such file or directory include Python.h

在Linux使用python3 setup.py install进行安装python包时,一开始是这个错误: py_Dameng.h:8:20: fatal error: Python.h: No such file or directory #include <Python.h> 按照惯例,应该是缺少gcc,python-dev等包; 所以就使用 yum install gccyum

【python量化交易】—— Alpha选股策略 - Qteasy自定义交易策略【附源码】

使用qteasy创建并回测Alpha选股交易策略 使用`qteasy`创建并回测Alpha选股交易策略策略思想第一种自定义策略设置方法,使用持仓数据和选股数据直接生成比例交易信号PS信号:第二种自定义策略设置方法,使用`PT`交易信号设置持仓目标:第三种自定义策略设置方法: 使用qteasy创建并回测Alpha选股交易策略 我们今天使用qteasy来回测一个alpha选股交易策

Python——Pandas的基本使用方法(1)

1.文件读写 图1-1 iris部分数据 图1-2 tips部分数据 图1-3 tips1部分数据 1.1 读取csv文件 —— read.csv() read.csv()部分参数的解释如下: 参数名称作用备注filepath_or_buffer要读取的文件路径或对象sep字段分隔符,默认为逗号delimiter字段分隔符与 sep 功能相似h

【Python大数据】PySpark

CSDN不支持多个资源绑定,另外两个数据文件下载: 订单数据-json.zip search-log.zip Apache Spark是用于大规模数据(large-scala data)处理的统一(unified)分析引擎 简单来说,Spark是一款分布式的计算框架,用于调度成百上千的服务器集群,计算TB、PB乃至EB级别的海量数据 而Python语言则是Spark重点支持的方向

Python中的exec()函数,动态执行代码的利器

简介 在Python编程中,exec()函数是一个强大的工具,它允许你执行存储在字符串或对象中的Python代码。这种动态执行代码的能力为脚本编写、自动化测试、以及快速原型开发提供了极大的便利。 exec()函数的基本用法 exec()函数可以执行作为字符串输入的Python代码。它是一个内置函数,其基本语法如下: exec(object, globals=None, locals=Non

Windows下python错误重定向

test.py代码示例如下: if __name__ == '__main__':try:init_result_file()# パラメータを読込parser = argparse.ArgumentParser()parser.add_argument('--amount', type=int, required=False)args = parser.parse_args()except Ex