循环和分叉图

时间:2016-01-23 22:08:26

标签: python numpy matplotlib scipy

我正在编写一个脚本,用于描绘一个带有小直接强迫的阻尼摆的分叉图。

import numpy as np
import matplotlib.pyplot as plt
from scipy.integrate import odeint
epsi = 0.01
# Declare the model
f_dir = np.arange(0,1.3,0.01)
A_s = np.zeros(len(f_dir))

i = 0
for f in f_dir:
 def myModel(y, t):

    dy0 = y[1]
    dy1 = -epsi*y[1]-np.sin(y[0]) - f*np.cos((1.01)*t)*np.cos(y[0])
    return [dy0, dy1]
    time = np.arange(0.0, 2000,0.01)
    yinit = np.array([np.pi/2, 0])
    y = odeint(myModel, yinit, time)

    A_s.insert(i,np.abs(np.max(y[-600:-1,0])- np.min(y[-600:-1,0])))

 i += 1


plt.plot(f_dir,A_s,'*')
plt.xlabel(r'$f_s$')
plt.ylabel(r'$A_s$')
plt.hold
plt.show()

问题是我没有在A_s中插入任何内容,我不知道为什么因为变量i在循环的每一步都增加了。

2 个答案:

答案 0 :(得分:3)

有点难以遵循您的代码,但这可能更接近您的需求。您只需要定义一次模型,即使f是一个变量参数:您可以将这些参数传递给odeint元组中的args,然后将它们传递给模型函数。

另请注意,NumPy数组没有insert方法。

import numpy as np
import matplotlib.pyplot as plt
from scipy.integrate import odeint
epsi = 0.01
# Declare the model
f_dir = np.arange(0,1.3,0.01)
A_s = np.zeros(len(f_dir))

def myModel(y, t, f):
    dy0 = y[1]
    dy1 = -epsi*y[1]-np.sin(y[0]) - f*np.cos((1.01)*t)*np.cos(y[0])
    return [dy0, dy1]

i = 0
for f in f_dir:
    time = np.arange(0.0, 2000,0.01)
    yinit = np.array([np.pi/2, 0])
    y = odeint(myModel, yinit, time, args=(f,))
    A_s[i] = np.abs(np.max(y[-600:-1,0])- np.min(y[-600:-1,0]))
    i += 1


plt.plot(f_dir,A_s,'*')
plt.xlabel(r'$f_s$')
plt.ylabel(r'$A_s$')
plt.hold
plt.show()

答案 1 :(得分:0)

你定义了myModel函数,但实际上并没有在任何地方调用它 - 它只是从函数本身引用。