2
matplotlib의 FuncAnimation을 사용하여 포인트가 애니메이션 처리되는 시뮬레이션 뷰어를 디자인하고 있습니다.matplotlib에서 애니메이션이 적용되지 않았습니다.
이것은 내가 지금까지 가지고있는 것입니다 (VX, VY, M, t_lim은 나중에 사용됩니다). 빈 줄거리 만 생성되고 아무 것도 움직이지 않습니다.
첫 번째 예제의 일부를 here에서 복사했습니다.
이것은 정말 간단합니다 (말 그대로 2 개의 포인트가 하나의 타임 스텝에서 결합 됨). 왜 작동하지 않습니까?
import numpy as np
import matplotlib.pyplot as plt
from matplotlib import animation
class visualisation(object):
def __init__(self, X, Y, VX, VY, M, t_lim=None):
self.X = X
self.Y = Y
self.VX = VX
self.VY = VY
self.M = M
self.t_lim = t_lim
self.fig = plt.figure()
addx = (X.max() - X.min()) * 0.05
addy = (Y.max() - Y.min()) * 0.05
self.ax = plt.axes(xlim=(X.min()-addx, X.max()+addx), ylim=(Y.min()-addy, Y.max()+addy))
self.points, = self.ax.plot([], [], 'b.', ms=10)
def init(self):
self.points.set_data([], [])
return self.points,
def animator(self, i):
print self.X[:,i]
self.points.set_data(self.X[:,i], self.Y[:,i])
return self.points,
def animate(self):
return animation.FuncAnimation(self.fig, self.animator, init_func=self.init, frames=200, interval=20, blit=True)
M_sun = 2.99e30
N = 1000
ms = np.array([1., 1.]) * M_sun
#initial conditions
xs = np.zeros([len(ms), N]) #[n, t]
xs[:, 0] = [0, 1]
ys = np.zeros([len(ms), N]) #[n, t]
ys[:, 0] = [0, 1]
vxs, vys = (np.zeros_like(xs))*2
visual = visualisation(xs, ys, vxs, vys, ms)
visual.animate()
plt.show()