gpt4 book ai didi

python - 使用Lorenz方程的运行时警告

转载 作者:行者123 更新时间:2023-12-03 09:02:49 24 4
gpt4 key购买 nike

我正在尝试在python中做Lorenz方程(我遵循Mark Newman的练习8.3-计算物理(2012,CreateSpace独立出版平台))
我已经得到了图形,一切看起来都“正确”。这可能是数学问题,而不是编程问题,但我在这里发布是为了确定。
首先,这是我的代码:

from numpy import arange,array
import pylab

def f(v,t):
s=10
r=28
b=8/3
x= v[0]
y= v[1]
z= v[2]
fx= s*(y - x)
fy= r*x - y - x*z
fz= x*y - b*z
return array([fx,fy,fz],float)



def d(N):
a=0.0
b=50.0
h=(b-a)/N
r=array([0.0,1.0,0.0],float)
tpoints=arange(a,b,h)
xpoints= []
ypoints= []
zpoints= []
for t in tpoints:
xpoints.append(r[0])
ypoints.append(r[1])
zpoints.append(r[2])
k1 = h*f(r,t)
k2 = h*f(r+0.5*k1,t+0.5*h)
k3 = h*f(r+0.5*k2,t+0.5*h)
k4 = h*f(r+k3,t+h)
r += (k1+2*k2+2*k3+k4)*(1/6)
return tpoints,xpoints,ypoints,zpoints



for i in range (1,6):
N=10**i
pylab.plot(d(N)[0],d(N)[1], label=N)
pylab.xlabel("t")
pylab.ylabel("x(t)")
pylab.title("Gráficos x em função de t")
pylab.legend()
pylab.show()
pylab.plot(d(N)[0],d(N)[2], label=N)
pylab.xlabel("t")
pylab.ylabel("y(t)")
pylab.title("Gráficos y em função de t")
pylab.legend()
pylab.show()
pylab.plot(d(N)[0],d(N)[3], label=N)
pylab.xlabel("t")
pylab.ylabel("z(t)")
pylab.title("Gráficos z em função de t")
pylab.legend()
pylab.show()
pylab.plot(d(N)[1],d(N)[3], label=N)
pylab.xlabel("x")
pylab.ylabel("z(x)")
pylab.title("Gráficos z em função de x")
pylab.legend()
pylab.show()
这给了我解决问题的图表,我认为这是正确的。
当我从 i=1转到 i=3时,出现此错误:
enter image description here
我认为这与数学问题有关,但是当我搜索错误时,我得到了带有数组的东西。所以我正在检查。
对于等于或大于4的 i,它没有问题。

最佳答案

带有RK4的Lorenz系统要求步长约为0.05或更小,也就是说,对于您的构造,步长为N=10**4或更大。请参阅几乎重复的Lorenz attractor with Runge-Kutta python
对于较大的步长,即遇到错误的情况,该方法将返回困惑的结果,这些结果与系统的精确解以及与系统的任何界限无关。因此,由于二次超线性项,可能会出现浮点溢出。

关于python - 使用Lorenz方程的运行时警告,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65223436/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com