51Testing软件测试论坛

标题: 秀技能:Python绘制表白玫瑰花 [打印本页]

作者: 草帽路飞UU    时间: 2022-10-27 15:44
标题: 秀技能:Python绘制表白玫瑰花
一、玫瑰花绘制—深红色
[attach]144377[/attach]



  import numpy as np

  import matplotlib.pyplot as plt


  from mpl_toolkits.mplot3d import Axes3D


  fig = plt.figure()


  ax = fig.gca(projection='3d')

  [x, t] = np.meshgrid(np.array(range(25)) / 24.0, np.arange(0, 575.5, 0.5) / 575 * 30 * np.pi - 4*np.pi)


  p = (np.pi / 2) * np.exp(-t / (8 * np.pi))


  change = np.sin(20*t)/50


  u = 1 - (1 - np.mod(3.3 * t, 2 * np.pi) / np.pi) ** 4 / 2 + change


  y = 2 * (x ** 2 - x) ** 2 * np.sin(p)


  r = u * (x * np.sin(p) + y * np.cos(p)) * 1.5


  h = u * (x * np.cos(p) - y * np.sin(p))


  c= plt.get_cmap('magma')


  surf = ax.plot_surface(r * np.cos(t), r * np.sin(t), h, rstride=1, cstride=1,


                         cmap= c, linewidth=0, antialiased=True)


  plt.show()




  二、玫瑰花绘制—五颜六色


[attach]144378[/attach]
[attach]144379[/attach]


 import numpy as np

  import matplotlib.pyplot as plt


  from matplotlib import cm


  from mpl_toolkits.mplot3d import Axes3D


  fig = plt.figure()


  ax = fig.gca(projection='3d')


  [x, t] = np.meshgrid(np.array(range(25)) / 24.0, np.arange(0, 575.5, 0.5) / 575 * 17 * np.pi - 2 * np.pi)


  p = (np.pi / 2) * np.exp(-t / (8 * np.pi))


  u = 1 - (1 - np.mod(3.6 * t, 2 * np.pi) / np.pi) ** 4 / 2


  y = 2 * (x ** 2 - x) ** 2 * np.sin(p)


  r = u * (x * np.sin(p) + y * np.cos(p))


  h = u * (x * np.cos(p) - y * np.sin(p))


  c= cm.gist_rainbow_r


  surf = ax.plot_surface(r * np.cos(t), r * np.sin(t), h, rstride=1, cstride=1,


                         cmap= c, linewidth=0, antialiased=True)


  plt.show()




  三、玫瑰花绘制—粉红色


[attach]144380[/attach]


 import numpy as np

  import matplotlib.pyplot as plt


  from matplotlib import cm


  from mpl_toolkits.mplot3d import Axes3D


  fig = plt.figure()


  ax = fig.gca(projection='3d')


  [x, t] = np.meshgrid(np.array(range(25)) / 24.0, np.arange(0, 575.5, 0.5) / 575 * 17 * np.pi - 2 * np.pi)


  p = (np.pi / 2) * np.exp(-t / (8 * np.pi))


  u = 1 - (1 - np.mod(3.6 * t, 2 * np.pi) / np.pi) ** 4 / 2


  y = 2 * (x ** 2 - x) ** 2 * np.sin(p)

  r = u * (x * np.sin(p) + y * np.cos(p))


  h = u * (x * np.cos(p) - y * np.sin(p))


  c= cm.get_cmap('spring_r')


  surf = ax.plot_surface(r * np.cos(t), r * np.sin(t), h, rstride=1, cstride=1,


                         cmap= c, linewidth=0, antialiased=True)


  plt.show()




  四、玫瑰花绘制—红色


[attach]144381[/attach]


 # 省略了头文件,可以在之前的博客里看到

  import numpy as np


  import matplotlib.pyplot as plt


  from mpl_toolkits.mplot3d import Axes3D


  fig = plt.figure()


  ax = fig.gca(projection='3d')


  # 将相位向后移动了6*pi


  [x, t] = np.meshgrid(np.array(range(25)) / 24.0, np.arange(0, 575.5, 0.5) / 575 * 20 * np.pi + 4*np.pi)


  p = (np.pi / 2) * np.exp(-t / (8 * np.pi))

  # 添加边缘扰动


  change = np.sin(15*t)/150


  # 将t的参数减少,使花瓣的角度变大


  u = 1 - (1 - np.mod(3.3 * t, 2 * np.pi) / np.pi) ** 4 / 2 + change


  y = 2 * (x ** 2 - x) ** 2 * np.sin(p)


  r = u * (x * np.sin(p) + y * np.cos(p))


  h = u * (x * np.cos(p) - y * np.sin(p))


  c= plt.get_cmap('Reds')


  surf = ax.plot_surface(r * np.cos(t), r * np.sin(t), h, rstride=1, cstride=1,


                         cmap= c, linewidth=0, antialiased=True)


  plt.show()




  五、桃花绘制


[attach]144382[/attach]


  import numpy as np

  import matplotlib.pyplot as plt


  from mpl_toolkits.mplot3d import Axes3D


  fig = plt.figure()


  ax = fig.gca(projection='3d')


  [x, t] = np.meshgrid(np.array(range(25)) / 24.0, np.arange(0, 575.5, 0.5) / 575 * 6 * np.pi - 4*np.pi)


  p = (np.pi / 2) * np.exp(-t / (8 * np.pi))


  change = np.sin(10*t)/20


  u = 1 - (1 - np.mod(5.2 * t, 2 * np.pi) / np.pi) ** 4 / 2 + change


  y = 2 * (x ** 2 - x) ** 2 * np.sin(p)


  r = u * (x * np.sin(p) + y * np.cos(p)) * 1.5


  h = u * (x * np.cos(p) - y * np.sin(p))


  c= plt.get_cmap('spring_r')


  surf = ax.plot_surface(r * np.cos(t), r * np.sin(t), h, rstride=1, cstride=1,


                         cmap= c, linewidth=0, antialiased=True)


  plt.show()






欢迎光临 51Testing软件测试论坛 (http://bbs.51testing.com/) Powered by Discuz! X3.2