我是使用 python 的新手,我想问你一个我当前代码的问题。我正在求解一个偏微分方程(空间中的一维),我想每次都为给定的数值解制作动画,但我不想每次都保存解的所有数组(因为这不是高效的)
为简单起见,我只向您展示微分方程的解析解。
我试图为每次尝试制作动画都制作一个陡峭的情节,但正如我在其他地方读到的那样,由于 plt.pause()
import numpy as np
import math
from matplotlib import pyplot as plt
pi = math.pi
xmin = 0.0
xmax = 10.0
N = 100 #number of points
x = np.arange(xmin, xmax , (xmax-xmin)/N)
def solution(t):
p = np.exp(-x**2/(4*k*t))/(np.sqrt(4.*pi*k*t))
return p
t_final = 10.0
t_initial = 0.0
t = t_initial
dt = 0.1
k = 1.0
while t<t_final:
t +=dt
pp = solution(t)
plt.ion()
plt.xlabel('x')
plt.ylabel('P')
plt.plot(x, pp, 'r-',label = "t=%s" % t)
plt.legend(loc='upper right')
plt.draw()
plt.pause(10**(-20))
plt.show()
plt.clf()
您知道如何在不保存数据的情况下重新实现我的代码以制作动画(并保存)吗?
德玛西亚99
相关分类