我正在使用DifferentialEquations.jl来解决如下所示的ODE系统。结果并不重要,因为p只包含用于生成MWE的测试参数,但关键是,尽管使用了就地ODE函数,但我还是看到了大量的内存分配。
using DifferentialEquations
function ode_fun!(du,u,p,t)
a,b,c,d,e = p
X = @. u[1] * a * ((b-c)/b)
Y = @. u[2] * d * ((b-e)/b)
du[1] = -sum(X) + sum(Y) - u[1]*u[2]
du[2] = sum(X) - sum(Y) - u[1]*u[2]
end
#exemplary parameters
a = collect(10:-0.1:0.1)
b = a.^2
c = b*0.7
d = collect(0.01:0.01:1)
e = b*0.3
u0 = [1.0, 0.5]
p = [a,b,c,d,e]
tspan = [0.0, 100.0]
t = collect(0:0.01:100)
prob = ODEProblem(ode_fun!,u0,tspan,p,saveat=t)
@time sol = solve(prob)
1.837609 seconds (5.17 M allocations: 240.331 MiB, 2.31% gc time) #Julia 1.5.2因为我需要反复解决这个ODE系统,所以我想尽可能地减少分配,我想知道是否有什么可以做的。我一直在想,问题是否出在X和Y上,并试图在ODE函数之外预先分配它们,但不幸的是,没有成功地以这种方式减少分配。
发布于 2020-12-08 13:51:49
我很确定这应该会更快而且分配的一半
function ode_fun!(du,u,p,t)
a,b,c,d,e = p
XmY = @. u[1] * a * (1-c/b) - u[2] * d * (1-e/b)
sXmY = sum(XmY)
du[1] = -sXmY - u[1]*u[2]
du[2] = sXmY - u[1]*u[2]
end可能有一种方法可以摆脱所有这些问题,但我不是DifferentialEquations专家。
https://stackoverflow.com/questions/65191918
复制相似问题