Fab*_*ini 4 arrays differential-equations julia
我尝试在 Julia 文档中使用这个示例。我的尝试是将细胞分成两部分,每部分的蛋白质含量都是一半。
using OrdinaryDiffEq
const ? = 0.3
function f(du,u,p,t)
for i in 1:length(u)
du[i] = ?*u[i]/length(u)
end
end
function condition(u,t,integrator) # Event when event_f(u,t) == 0
1-maximum(u)
end
function affect!(integrator)
u = integrator.u
idxs = findall(x->x>=1-eps(eltype(u)),u)
resize!(integrator,length(u)+length(idxs))
u[idxs] ./ 2
u[end-idxs:end] = 0.5
nothing
end
callback = ContinuousCallback(condition,affect!)
u0 = [0.2]
tspan = (0.0,10.0)
prob = ODEProblem(f,u0,tspan)
sol = solve(prob,Tsit5(),callback=callback)
Run Code Online (Sandbox Code Playgroud)
我收到错误:MethodError: no method matching -(::Int64, ::Array{Int64,1})。我知道 存在问题idxs = findall(x->x>=1-eps(eltype(u)),u),我尝试在 1 和 eps 之间加一个点,但这并没有解决问题。我正在使用 Julia 1.1.1。
运行您的代码,堆栈跟踪指向该行
u[end-idxs:end] = 0.5
Run Code Online (Sandbox Code Playgroud)
这里的问题是findall即使只找到一个元素也会返回一个数组,例如
julia> findall(x -> x > 2, [1,2,3])
1-element Array{Int64,1}:
3
Run Code Online (Sandbox Code Playgroud)
并且您不能从end索引表达式中减去数组。
我对您的代码了解不够,无法弄清楚idxs应该是什么,但是如果您希望这仅返回一个元素,您可以使用first(idxs)(甚至only(idxs)在 Julia 1.4 中),或者替换findall为findfirst,它将索引作为整数返回(而不是数组)。