I am a python beginner, currently using scipy's odeint to compute a coupled ODE system, however, when I run, python shell always tell me that
>>> Excess work done on this call (perhaps wrong Dfun type). Run with full_output = 1 to get quantitative information. >>> So, I have to change my time step and final time, in order to make it integratable. To do this, I need to try a different combinations, which is quite a pain. Could anyone tell me how can I ask odeint to automatically vary the time step and final time to successfully integrate this ode system?
and here is part of the code which has called odeint:
def main(t, init_pop_a, init_pop_b, *args, **kwargs): """ solve the obe for a given set of parameters """ # construct initial condition # initially, rho_ee = 0 rho_init = zeros((16,16))*1j ######## rho_init[1,1] = init_pop_a rho_init[2,2] = init_pop_b rho_init[0,0] = 1 - (init_pop_a + init_pop_b)######## rho_init_ravel, params = to_1d(rho_init) # perform the integration result = odeint(wrapped_bloch3, rho_init_ravel, t, args=args) # BUG: need to pass kwargs # rewrap the result return from_1d(result, params, prepend=(len(t),)) things = [2*pi, 20*pi, 0,0, 0,0, 0.1,100] Omega_a, Omega_b, Delta_a, Delta_b, \ init_pop_a, init_pop_b, tstep, tfinal = things args = ( Delta_a, Delta_b, Omega_a, Omega_b ) t = arange(0, tfinal + tstep, tstep) data = main(t, init_pop_a, init_pop_b, *args) plt.plot(t,abs(data[:,4,4])) where wrapped_bloch3 is the function compute dy/dt.
odeint? Are you sure it is reasonable?