Мне нужно нарисовать сферы, которые изменяются в координатах прозрачности, радиуса и x, y, z.Построение поверхности (сферы) в matplotlib, с центром в координатах, отличных от 0,0,0
Я могу отображать сферы и передавать значения прозрачности (альфа) и значения радиуса (которые я изменил на случайные числа, чтобы упростить этот пример), но я не смог понять, как центрируйте сферы вокруг координат, отличные от 0,0,0.
Как центрировать сферу вокруг координат, отличных от 0,0,0, используя pythons matplotlib libary?
Вот что я до сих пор;
from __future__ import print_function
from mpl_toolkits.mplot3d import axes3d
import matplotlib.pyplot as plt
import numpy as np
import time , random
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
ax.set_xlim3d([100.0, 0.0])
ax.set_xlabel('X')
ax.set_ylim3d([0.0, 100.0])
ax.set_ylabel('Y')
ax.set_zlim3d([0.0, 100.0])
ax.set_zlabel('Z')
ax.set_title('pFC-amygdala-insula')
wframe = None
tstart = time.time()
for num in range(100):
oldcol = wframe
r = random.randint(1, 20)
alpha = 1.0/random.randint(25, 100)
u = np.linspace(0, 2 * np.pi, 100)
v = np.linspace(0, np.pi, 100)
x = r * np.outer(np.cos(u), np.sin(v))
y = r * np.outer(np.sin(u), np.sin(v))
z = r * np.outer(np.ones(np.size(u)), np.cos(v))
sphere = ax.plot_surface(x, y, z, color='b', alpha=alpha)
if oldcol is not None: ax.collections.remove(oldcol)
plt.pause(.001)
print('Duration: %f' % (100/(time.time() - tstart)))
Отлично, спасибо! – user1454024