TypeError: model() принимает ровно 3 аргумента (дано 5)

odeint с последующей настройкой работает нормально;

import numpy as np
import matplotlib.pyplot as plt
from scipy.integrate import odeint

v0 = 10.0
k1 = 0.5
k2 = 0.35

def model(x,t):
    dx0 = v0 - k1*x[0]
    dx1 = k1*x[0] - k2*x[1]
    return [dx0, dx1]
time = linspace(0.0,20.0,100)
xinit = array([0.0,0.0])
x = odeint(model,xinit,time)
plt.plot(time, x[:,0], time, x[:,1])

но когда я хочу определить параметризованную модель и затем передать параметры в функцию model(), я сталкиваюсь с этой ошибкой, когда odeint вызывает ее: TypeError: model() принимает ровно 3 аргумента (дано 5) . Что здесь не так? Как правильно настроить параметры передачи?

import numpy as np
from scipy.integrate import odeint
import matplotlib.pyplot as plt

def model (x,t,p):
    dot_x = np.zeros(2)
    v0 = p[0]
    k1 = p[1]
    k2 = p[2]
    dot_x[0] = v0 - k1*x[0]
    dot_x[1] = k1*x[0] - k2*x[1]
    return dot_x

p = (10,0.5,.35)
xinit = [0.0,0.0] 
time = linspace(0.0,20.0,100)

x = odeint(model,xinit,time,p)

plt.plot(time, x[:,0], time, x[:,1])

1 ответ

Решение

Благодаря комментарию Тиру, вот решение:

import numpy as np
from scipy.integrate import odeint
import matplotlib.pyplot as plt

def model (x,t,*p):
    dot_x = np.zeros(2)
    v0 = p[0]
    k1 = p[1]
    k2 = p[2]
    dot_x[0] = v0 - k1*x[0]
    dot_x[1] = k1*x[0] - k2*x[1]
    return dot_x

p = (10,0.5,.35)
xinit = [0.0,0.0] 
time = linspace(0.0,20.0,100)

x = odeint(model,xinit,time,p)

plt.plot(time, x[:,0], time, x[:,1])
Другие вопросы по тегам