plot_density4d.py 1.0 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. # Plot a volume evolution in time
  2. # Credits: https://github.com/edmontz
  3. import numpy as np
  4. from scipy.fftpack import fftn, fftshift
  5. from vedo import Axes, Plotter, Volume, progressbar
  6. def f(x, y, z, t):
  7. r = np.sqrt(x*x + y*y + z*z + 2*t*t) + 0.1
  8. return np.sin(9*np.pi * r)/r
  9. n = 64
  10. qn = 25
  11. vol = np.zeros((n, n, n))
  12. n1 = int(n/2)
  13. plt = Plotter(bg="black", interactive=False)
  14. axes = Axes(xrange=(0,n), yrange=(0,n), zrange=(0,n))
  15. plt.show(axes, viewup='z')
  16. for q in progressbar(range(qn), c='r'):
  17. t = 2 * q / qn - 1
  18. for k in range(n1):
  19. z = 2 * k / n1 - 1
  20. for j in range(n1):
  21. y = 2 * j / n1 - 1
  22. for i in range(n1):
  23. x = 2 * i / n1 - 1
  24. vol[i, j, k] = f(x, y, z, t)
  25. volf = fftn(vol)
  26. volf = fftshift(abs(volf))
  27. volf = np.log(12*volf/volf.max()+ 1) / 2.5
  28. volb = Volume(volf)
  29. volb.mode(1).cmap("rainbow").alpha([0, 0.8, 1])
  30. volb.name = "MyVolume"
  31. plt.remove("MyVolume").add(volb).render()
  32. plt.interactive().close()