• 数学建模--三维图像绘制的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()

     

     

  • 相关阅读:
    Automatic Online Calibration of Cameras and Lasers 论文翻译
    ansible部署二进制k8s
    基于py路由器转发内容
    PHP 电竞网站系统mysql数据库web结构apache计算机软件工程网页wamp
    SpringMVC(二)@RequestMapping注解
    linux定时重启tomcat
    重启Oracle数据库命令列表逐步操作
    为什么LDO一般不用在大电流场景?
    中科磐云题目——报错注入 解析(flag)
    Upload-labs 1~15 通关详细教程
  • 原文地址:https://blog.csdn.net/m0_71819746/article/details/132635194