Здесь вы создаете 5000 отдельных точечных диаграмм.Это точно неэффективно.Вы можете использовать решение, которое я предложил в этом ответе , а именно, чтобы установить отдельные маркеры как пути к PathCollection
.Это будет работать подобно разбросу, с дополнительным аргументом m
для маркеров.
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.markers as mmarkers
def mscatter(x,y,ax=None, m=None, **kw):
import matplotlib.markers as mmarkers
if not ax: ax=plt.gca()
sc = ax.scatter(x,y,**kw)
if (m is not None) and (len(m)==len(x)):
paths = []
for marker in m:
if isinstance(marker, mmarkers.MarkerStyle):
marker_obj = marker
else:
marker_obj = mmarkers.MarkerStyle(marker)
path = marker_obj.get_path().transformed(
marker_obj.get_transform())
paths.append(path)
sc.set_paths(paths)
return sc
np.random.seed(42)
data = np.random.rand(5000,3)
data[:,2] *= 360
markers = []
fig, ax = plt.subplots()
for i in range(len(data)):
t = mmarkers.MarkerStyle(marker='|')
t._transform = t.get_transform().rotate_deg(data[i,2])
markers.append(t)
mscatter(data[:,0], data[:,1], m=markers, s=50, c='0', linewidth=1)
plt.show()
Если мы рассчитаем это время, мы обнаружим, что для создания графика с 5000 точками и 5000 различными значениями требуется ~ 250 мсуглы.В отличие от этого, решение цикла будет занимать более 12 секунд.
Пока что на общий вопрос о том, как вращать множество маркеров.Для особого случая здесь, кажется, вы хотите использовать простые линейные маркеры.Это легко сделать с помощью графика quiver
.Затем можно отключить наконечники стрел, чтобы стрелки выглядели как линии.
fig, ax = plt.subplots()
ax.quiver(data[:,0], data[:,1], 1,1, angles=data[:,2]+90, scale=1/10, scale_units="dots",
units="dots", color="k", pivot="mid",width=1, headwidth=1, headlength=0)
Результат почти такой же, сПреимущество этого графика составляет всего ~ 80 мс, что опять же в три раза быстрее, чем PathCollection
.