matplotlib 绘制三维图

本文介绍了如何使用matplotlib库中的Axes3D模块创建三维图形。通过示例代码展示了如何生成横坐标和纵坐标的网格,计算出对应的Z坐标,并利用plot_surface函数绘制三维曲面。最后设置了Z轴的刻度和颜色条。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.对于竖坐标是由横坐标,纵坐标用公式表示的情况

采用先meshgrid再plot_surface的方法

from mpl_toolkits.mplot3d import Axes3D  
from matplotlib import cm  
from matplotlib.ticker import LinearLocator, FormatStrFormatter  
import matplotlib.pyplot as plt  
import numpy as np  
 
fig = plt.figure()  
ax = fig.gca(projection='3d')  
X = np.arange(-5, 5, 0.25) //横坐标区间,内部不能重复
Y = np.arange(-5, 5, 0.25) //纵坐标区间,内部不能重复
X, Y = np.meshgrid(X, Y)  //生成网格
R = np.sqrt(X**2 + Y**2)  
Z = np.sin(R)  
surf = ax.plot_surface(X, Y, Z, rstride=1, cstride=1, cmap=cm.jet,  
        linewidth=0, antialiased=False)  
ax.set_zlim(-1.01, 1.01)  
 
ax.zaxis.set_major_locator(LinearLocator(10))  
ax.zaxis.set_major_formatter(FormatStrFormatter('%.02f'))  
 
fig.colorbar(surf, shrink=0.5, aspect=5)  
 
plt.show() 

2.对于纯粹散点的情况
fig = plt.figure()
ax = fig.add_subplot(111,projection='3d')
x =np.array()//点的横坐标,比如[1,1,1,2,2,2,3,3,3]
y= np.array()//点的横坐标,比如[4,5,6,4,5,6,4,5,6]
z =np.array()//点的竖坐标,比如[........]
ax.plot_trisurf(x,y,z)
plt.show()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值