【发布时间】:2021-12-05 17:04:23
【问题描述】:
我正在尝试编写一个程序,使用两个差分方程以图形方式绘制两个物种(狐狸和兔子)之间的 Lotka-Volterra 相互作用。
有问题的两个方程是:
rabit 的初始状态应该是R[0] = 100,fox 的初始状态应该是F[0] = 20
通常,当我遇到在 python 中用数值求解差分方程时,我会这样写:
import numpy as np
N = 15
x = np.zeros(N+1, int)
x[0] = 1
x[1] = 1
for n in range(2, N+1):
x[n] = x[n-1] + x[n-2]
print(f"x[{n}] = {x[n]}")
我认为类似上述策略的方法也适用于“Lotka-Volterra-difference-equation”问题。
于是我尝试了下面的代码,得到了一些不愉快的惊喜:
import numpy as np
import matplotlib.pyplot as plt
N = 500
a = 0.4
b = 0.1
c = 0.005
e = 0.2
R = np.zeros(N+1)
F = np.zeros(N+1)
t = np.linspace(0,500,num=10_000)
R[0] = 100
F[0] = 20
for n in range(2,N):
# Rabbit
R[n] = R[n-1] + a*R[n-1] - c*R[n-1] * F[n-1]
#Fox
F[n] = F[n - 1] + e * c * R[n - 1] * F[n - 1] - b * F[n - 1]
print(R[n],F[n])
plt.plot(t,R[n])
plt.show()
代码的问题是:
1.除了
之外,我不会制作任何其他印刷品0.0 0.0
0.0 0.0
0.0 0.0
0.0 0.0
0.0 0.0
2。如果您尝试使用 matplotlib/pyplot 绘制它,它会给出很多错误消息。
File "C:/Users/(...)lotka_volterra.py", line 36, in <module>
plt.plot(t,R[n])
File "C:\Users\(...)\lib\site-packages\matplotlib\pyplot.py", line 3019, in plot
return gca().plot(
File "C:\Users\(...)\lib\site-packages\matplotlib\axes\_axes.py", line 1605, in plot
lines = [*self._get_lines(*args, data=data, **kwargs)]
File "C:\Users\(...)\lib\site-packages\matplotlib\axes\_base.py", line 315, in __call__
yield from self._plot_args(this, kwargs)
File "C:\Users\(...)\lib\site-packages\matplotlib\axes\_base.py", line 501, in _plot_args
raise ValueError(f"x and y must have same first dimension, but "
ValueError: x and y must have same first dimension, but have shapes (10000,) and (1,)
有没有好心人帮我解决这个问题?或许还能提供解决方案?
感谢并欢迎所有帮助。
【问题讨论】:
-
@Andy:狐狸的正确初始状态是 F[0] = 20,而兔子 R[0] = 100。我将对其进行编辑以使问题更清楚。谢谢。
标签: python arrays numpy matplotlib differential-equations