![](/img/trans.png)
[英]How can I integrate the Ordinary differential equation using odeint from scipy.integrate?
[英]Can I integrate with scipy's odeint until a local max is found?
这是我在这里的第一个问题,所以请放轻松我。 我想知道是否有办法只集成ODE系统,直到找到指定变量的局部最大值。 这里有一些更详细的信息:
让我们调用我们的ODE系统dX/dt = F(X) where X(t) = [x1(t), x2(t), ... , xn(t)]
。 假设该系统的解决方案被吸引到稳定的极限周期C,但是在一个不稳定的固定点p处。 选择一些初始条件X0而不是p,而不是C.我们希望遵循解决方案的轨迹:
dX/dt = F(X), X(0) = X0 (*)
直到x1(t)达到其第一个局部最大值。
进展:使用scipy.integrate.odeint我能够找到极限周期C及其周期T的解,但是从任意点开始我能够解决这个问题的唯一方法是求解(*)for “长时间”(可能是4 * T),假设这是一个足够长的时间,确定事后的第一个局部最大值x1。 我的大项目要求多次完成,所以我尽量减少计算时间。 似乎必须有一种更快的方法来做到这一点,而无需编写我自己的颂歌解算器。
有可能(也可能)我让这个太复杂了吗? 如果你想到一个不同的方式来做到这一点,我将不胜感激任何建议。
我没有测试过这个,但以下代码应该起作用或者至少有用:
from scipy.integrate import ode
y0, t0 = [1.0j, 2.0], 0
def f(t, y, arg1):
return [1j*arg1*y[0] + y[1], -arg1*y[1]**2]
r = ode(f).set_integrator('zvode', method='bdf')
r.set_initial_value(y0, t0).set_f_params(2.0)
t1 = 10
dt = 1
older = 0
previous = 0
current = 0
while r.successful() and not (older < previous and prevous > current):
older = previous
previous = current
current = r.integrate(r.t+dt)
print("Maximum occurs at {}".format(r.t - dt))
我还会进一步研究python ode
编辑:
更妙的是使用solout
可以发现这里
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.