Я пытаюсь решить ряд краевых задач, заданных 4 дифференциальными уравнениями. Я использую bvp_solver в python и получаю ошибки, в которых указано «недопустимое значение, обнаруженное при делении». Я предполагаю, что это означает, что я делю на NaN или 0 в какой-то момент, но я не уверен, где.
import numpy as np
from scipy.integrate import solve_bvp
import matplotlib.pyplot as plt
%matplotlib inline
alpha = 1
zeta = 1
C_k = 1
sigma = 1
Q = 30
U_0 = 0.1
gamma = 5/3
theta = 3
m = 1.5
def fun(x, y):
U, dU, B, dB, T, dT, M, dM = y;
d2U = -2*U_0*Q**2*(1/np.cosh(Q*x))**2*np.tanh(Q*x)-((alpha)/(C_k*sigma))*dB;
d2B = -(1/(C_k*zeta))*dU;
d2T = (1/gamma - 1)*(sigma*dU**2 + zeta*alpha*dB**2);
d2M = -(dM/T)*dT + (dM/T)*theta*(m+1) - (alpha/T)*B*dB
return dU, d2U, dB, d2B, dT, d2T, dM, d2M
def bc(ya, yb):
return ya[0]+U_0*np.tanh(Q*0.5), yb[0]-U_0*np.tanh(Q*0.5), ya[2]-0, yb[2]-0, ya[4] - 1, yb[4] - 4, ya[6], yb[6] - 1
x = np.linspace(-0.5, 0.5, 500)
y = np.zeros((8, x.size))
sol = solve_bvp(fun, bc, x, y)
Если я уберу последние два уравнения для M и dM, то решение будет работать нормально. В прошлом у меня были проблемы с пониманием возвращаемых массивов bvp_solver, но я уверен, что теперь я это понимаю. Но я продолжаю получать ошибки каждый раз, когда добавляю больше уравнений. Любая помощь с благодарностью.