绘制三维图入门:Z=X^2 + Y^2
步骤:
1.先绘制出三维坐标
2.定义函数表达式
3.绘制三维图像

1.先绘制出三维坐标

from matplotlib import pyplot as plt
from mpl_toolkits.mplot3d import Axes3D  #此模块并非不没有作用,如果缺少了会/
#引起三维坐标的创建报出异常: ValueError: Unknown projection '3d

fig = plt.figure()
ax1 = plt.axes(projection="3d")

plt.show()

在这里插入图片描述

2.定义函数表达式

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

fig = plt.figure()
ax1 = plt.axes(projection="3d")

x = np.arange(-5,5,0.1)
y = np.arange(-5,5,0.1)
Z = x**2+y**2

ax1.plot3D(x,y,Z,"gray")
plt.show()

在这里插入图片描述
3.绘制三维图像

问题:我想绘制的是三维图像,而不是一条曲线,因此我查找原因,发现三维图像是需要网格数据,而我只定义了一个二维数据,因此只显示的为一条曲线,于是我在代码中添加网络数据采集函数(X,Y = np.meshgrid(x,y)),最终得以解决。
meshgrid函数介绍: meshgrid函数生成绘制3D图形所需的网格数据。在计算机中进行绘图操作时, 需要一些采样点,然后根据这些采样点来绘制出整个图形。在进行3D绘图操作时,涉及到x、y、z三组数据,而x、y这两组数据可以看做是在Oxy平面内对坐标进行采样得到的坐标对(x, y)

功能:绘制z=x^2 + y^2 三维图像
时间:2019/10/1
"""
from matplotlib import pyplot as plt
from mpl_toolkits.mplot3d import Axes3D   
import numpy as np


plt.figure()
ax = plt.axes(projection="3d")

x = np.arange(-5,5,0.1)
y = np.arange(-5,5,0.1)
X,Y = np.meshgrid(x,y)    # 2生成绘制3D图形所需的网络数据
Z = X**2+Y**2

ax.plot_surface(X,Y,Z,alpha=0.5,cmap="winter") #生成表面,alpha用于控制透明度
#ax.contour(X,Y,Z,zdir="x",offset=-6,cmap="rainbow")   #x轴投影
#ax.contour(X,Y,Z,zdir="y",offset=6,cmap="rainbow")    #y轴投影
#ax.contour(X,Y,Z,zdir="z",offset=-3,cmap="rainbow")   #z轴投影
ax.set_xlabel("X")  #设置X、Y、Z 坐标范围
ax.set_xlim(-6,6)   #设置X、Y、Z 轴
ax.set_ylabel("Y")
ax.set_ylim(-6,6)
ax.set_zlabel("Z")
plt.show()

在这里插入图片描述
给代码中添加图像在XYZ的投影:

在这里插入图片描述
投影中参数解释:offset:默认的投影面是在(0,0,0)处,如果想让投影位于坐标轴平面上,就要用offset去设置投影的位置。

注意:纸上得来终觉浅,绝知此事要躬行。

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐