当前位置:   article > 正文

数学建模--三维图像绘制的Python实现_python画三维立体图

python画三维立体图

目录

1.绘制三维坐标轴的方法

2.绘制三维函数的样例1 

3.绘制三维函数的样例2

4.绘制三维函数的样例3

 5.绘制三维函数的样例4

 6.绘制三维函数的样例5


1.绘制三维坐标轴的方法

  1. #%%
  2. #1.绘制三维坐标轴的方法
  3. from matplotlib import pyplot as plt
  4. from mpl_toolkits.mplot3d import Axes3D
  5. #开始绘图
  6. #采用方法1或者方法2都能够建立三维坐标轴
  7. fig=plt.figure()
  8. """
  9. 就个人而言还是比较推荐方法1的.
  10. 因为再使用方法二的时候,某些函数再jupyter中不能够运行,最后显示的图片是空白甚至报错!
  11. """
  12. ax1=plt.axes(projection='3d')#方法1
  13. ax2=Axes3D(fig)#方法2
  14. plt.xlabel("x")
  15. plt.ylabel("y")
  16. plt.title("A blank 3D axis")
  17. plt.savefig('C:/Users/Zeng Zhong Yan/Desktop/空白三维轴.png', dpi=500, bbox_inches='tight')

2.绘制三维函数的样例1 

  1. fig = plt.figure() #定义新的三维坐标轴
  2. ax3 = plt.axes(projection='3d')
  3. #定义三维数据
  4. xx = np.arange(-5,5,0.5)
  5. yy = np.arange(-5,5,0.5)
  6. X, Y = np.meshgrid(xx, yy)
  7. Z = np.sin(X)+np.cos(Y)
  8. #作图
  9. ax3.plot_surface(X,Y,Z,rstride = 1, cstride = 1,cmap='rainbow')
  10. plt.xlabel("x")
  11. plt.ylabel("y")
  12. plt.title("3D surface plot")
  13. plt.savefig('C:/Users/Zeng Zhong Yan/Desktop/三维曲面.png', dpi=500, bbox_inches='tight')
  14. plt.show()

 

3.绘制三维函数的样例2

  1. #绘制等高线曲面tu
  2. from matplotlib import pyplot as plt
  3. from mpl_toolkits.mplot3d import Axes3D
  4. #定义坐标轴
  5. fig4 = plt.figure()
  6. ax4 = plt.axes(projection='3d')
  7. #生成三维数据
  8. xx = np.arange(-5,5,0.1)
  9. yy = np.arange(-5,5,0.1)
  10. X, Y = np.meshgrid(xx, yy)
  11. Z = np.cos(np.sqrt(X**2+Y**2))
  12. #作图,分别向对应的面做投影线,增强效果美感
  13. ax4.plot_surface(X,Y,Z,alpha=0.3,cmap='winter') #生成表面, alpha 用于控制透明度
  14. ax4.contour(X,Y,Z,zdir='z', offset=-3,cmap="rainbow") #生成z方向投影,投到x-y平面
  15. ax4.contour(X,Y,Z,zdir='x', offset=-6,cmap="rainbow") #生成x方向投影,投到y-z平面
  16. ax4.contour(X,Y,Z,zdir='y', offset=6,cmap="rainbow") #生成y方向投影,投到x-z平面
  17. #设定显示范围
  18. ax4.set_xlabel('X')
  19. ax4.set_xlim(-6, 4)
  20. ax4.set_ylabel('Y')
  21. ax4.set_ylim(-4, 6)
  22. ax4.set_zlabel('Z')
  23. ax4.set_zlim(-3, 3)
  24. plt.title("Contour surface plot")
  25. plt.savefig('C:/Users/Zeng Zhong Yan/Desktop/等高线图.png', dpi=500, bbox_inches='tight')
  26. plt.show()

  

4.绘制三维函数的样例3

  1. #再绘制一个3D彩面图
  2. %matplotlib inline
  3. %config InlineBackend.figure_format = 'retina'
  4. import numpy as np
  5. import matplotlib.pyplot as plt
  6. from mpl_toolkits.mplot3d import Axes3D
  7. # x,y的导入
  8. x=np.linspace(-3,3,1000)
  9. y=np.linspace(-3,3,1000)
  10. x, y = np.meshgrid(x,y)
  11. z = (1 - x / 2 + x ** 5 + y ** 3) * \
  12. np.exp(-(x *x+y *y))
  13. # 绘制图片
  14. fig = plt.figure()
  15. plt.title("3D Light Surface", fontsize=18)
  16. #ax3d = Axes3D(fig) #写第一种图片总是出不来,我们一般推荐第种写法
  17. ax3d = mp.axes(projection="3d") # 同样可以实现
  18. ax3d.set_xlabel("X",color='r')
  19. ax3d.set_ylabel("Y",color='r')
  20. ax3d.set_zlabel("Z",color='r')
  21. plt.tick_params(labelsize=10)
  22. ax3d.plot_surface(x, y, z, rstride=20,cstride=20, cmap="jet")
  23. plt.savefig('C:/Users/Zeng Zhong Yan/Desktop/3D彩色图片.png', dpi=500, bbox_inches='tight')
  24. plt.show()

 

 5.绘制三维函数的样例4

  1. #再画一个利用coolwarm类型的图
  2. import pylab as plt
  3. import numpy as np
  4. #数据处理
  5. X=np.linspace(-6,6,1000)
  6. Y=np.linspace(-6,6,1000)
  7. X,Y=np.meshgrid(X,Y)
  8. #设置绘图
  9. #推荐plt.axes的写法,不容易出现图像显示空白的情况
  10. ax=plt.axes(projection="3d")
  11. Z=np.sin(np.sqrt(X*X+Y*Y))
  12. surf=ax.plot_surface(X,Y,Z,cmap="coolwarm")
  13. plt.colorbar(surf)
  14. ax.set_xlabel("X",color='r')
  15. ax.set_ylabel("Y",color='r')
  16. plt.title("3D CoolWarm Surface", fontsize=10)
  17. plt.savefig('C:/Users/Zeng Zhong Yan/Desktop/3D CoolWarm Surface.png', dpi=500, bbox_inches='tight')
  18. plt.show()

 6.绘制三维函数的样例5

  1. #最后一张难度比较大一点的图片
  2. #首先引入必要的库
  3. import numpy as np
  4. import matplotlib.pyplot as plt
  5. import mpl_toolkits.axisartist as axisartist
  6. from mpl_toolkits.mplot3d import Axes3D
  7. from matplotlib import cm
  8. #数据处理
  9. X1=np.linspace(-6,6,2000)
  10. Y1=np.linspace(-6,6,2000)
  11. x,y=np.meshgrid(X1,Y1)
  12. #代入计算行数
  13. def gaussian_fun(x,y,mu_x,mu_y,sigma_x,sigma_y):
  14. f_x_y = 1/(sigma_x*sigma_y*(np.sqrt(2*np.pi))**2)*np.exp(-np.power\
  15. (x-mu_x, 2.)/(2*np.power(sigma_x,2.))-np.power(y-mu_y, 2.)/\
  16. (2*np.power(sigma_y,2.)))
  17. return(f_x_y)
  18. mu_x=0
  19. mu_y=0
  20. sigma_x=0.8
  21. sigma_y=0.8
  22. F_x_y = gaussian_fun(X,Y,mu_x,mu_y,sigma_x,sigma_y)
  23. #可视化处理
  24. fig = plt.figure()
  25. ax = plt.axes(projection='3d')
  26. ax.plot_surface(X,Y,F_x_y,cmap='jet')
  27. # 显示等高线图
  28. plt.xlabel("x",color='r')
  29. plt.ylabel("y",color='r')
  30. plt.title("Gaussian Function Figure",color='r')
  31. plt.savefig('C:/Users/Zeng Zhong Yan/Desktop/Gaussian Function Figure.png', dpi=500, bbox_inches='tight')
  32. plt.show()

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/627323
推荐阅读
相关标签
  

闽ICP备14008679号