diff --git a/core/common.jl b/core/common.jl index 56987bf6ef79e37205d8bc9442de7281a5dc2ee0..b3b129f10ac8c42bcbbe14d0e296198be87b2237 100644 --- a/core/common.jl +++ b/core/common.jl @@ -18,7 +18,7 @@ mutable struct ContinuousTimeModel <: Model map_var_idx::Dict{VariableModel,Int} # maps variable str to index in the state space _map_obs_var_idx::Dict{VariableModel,Int} # maps variable str to index in the observed state space map_param_idx::Dict{ParameterModel,Int} # maps parameter str to index in the parameter space - transitions::Vector{<:Transition} + transitions::Vector{Transition} p::Vector{Float64} x0::Vector{Int} t0::Float64 @@ -35,17 +35,17 @@ struct Trajectory <: AbstractTrajectory m::ContinuousTimeModel values::Vector{Vector{Int}} times::Vector{Float64} - transitions::Vector{<:Transition} + transitions::Vector{Transition} end struct Edge - transitions::Vector{<:Transition} + transitions::Vector{Transition} check_constraints::Function update_state!::Function end struct LHA - transitions::Vector{<:Transition} + transitions::Vector{Transition} locations::Vector{Location} Λ::Dict{Location,Function} locations_init::Vector{Location} @@ -74,7 +74,7 @@ struct SynchronizedTrajectory <: AbstractTrajectory sm::SynchronizedModel values::Vector{Vector{Int}} times::Vector{Float64} - transitions::Vector{<:Transition} + transitions::Vector{Transition} end struct ParametricModel @@ -86,12 +86,13 @@ end # Constructors function ContinuousTimeModel(dim_state::Int, dim_params::Int, map_var_idx::Dict{VariableModel,Int}, - map_param_idx::Dict{ParameterModel,Int}, transitions::Vector{<:Transition}, + map_param_idx::Dict{ParameterModel,Int}, transitions::Vector{<:Transition}, p::Vector{Float64}, x0::Vector{Int}, t0::Float64, f!::Function, isabsorbing::Function; g::Vector{VariableModel} = keys(map_var_idx), time_bound::Float64 = Inf, buffer_size::Int = 10, estim_min_states::Int = 50, name::String = "Unnamed") dim_obs_state = length(g) + transitions = convert(Vector{Transition}, transitions) _map_obs_var_idx = Dict() _g_idx = Vector{Int}(undef, dim_obs_state) for i = 1:dim_obs_state diff --git a/models/ER.jl b/models/ER.jl index f4d7312573d5de6285b3f9d54c9b8a799d4e418e..b2d0d0c88dfabdbef74a606d91c1e0c9ce98e33f 100644 --- a/models/ER.jl +++ b/models/ER.jl @@ -9,7 +9,7 @@ l_tr_ER = [:R1,:R2,:R3] p_ER = [1.0, 1.0, 1.0] x0_ER = [100, 100, 0, 0] t0_ER = 0.0 -function ER_f!(xnplus1::Vector{Int}, l_t::Vector{Float64}, l_tr::Vector{<:Transition}, +function ER_f!(xnplus1::Vector{Int}, l_t::Vector{Float64}, l_tr::Vector{Transition}, xn::Vector{Int}, tn::Float64, p::Vector{Float64}) @inbounds a1 = p[1] * xn[1] * xn[2] @inbounds a2 = p[2] * xn[3] diff --git a/models/SIR.jl b/models/SIR.jl index 1b4e953bf4fc07ab3b3dd0d19e755cf71cb0511c..7161169bd7b103eac1a133fc9c0676a63744c1f1 100644 --- a/models/SIR.jl +++ b/models/SIR.jl @@ -9,7 +9,7 @@ l_tr_SIR = [:R1,:R2] p_SIR = [0.0012, 0.05] x0_SIR = [95, 5, 0] t0_SIR = 0.0 -function SIR_f!(xnplus1::Vector{Int}, l_t::Vector{Float64}, l_tr::Vector{<:Transition}, +function SIR_f!(xnplus1::Vector{Int}, l_t::Vector{Float64}, l_tr::Vector{Transition}, xn::Vector{Int}, tn::Float64, p::Vector{Float64}) @inbounds a1 = p[1] * xn[1] * xn[2] @inbounds a2 = p[2] * xn[2] diff --git a/models/SIR_tauleap.jl b/models/SIR_tauleap.jl index 22dd7994ae4d2779426b30c2866b46d90cc398ea..40a07d0b3784cdf330c6d10dcedec1c636429d60 100644 --- a/models/SIR_tauleap.jl +++ b/models/SIR_tauleap.jl @@ -10,7 +10,7 @@ l_tr_SIR_tauleap = [:U] p_SIR_tauleap = [0.0012, 0.05, 5.0] x0_SIR_tauleap = [95, 5, 0] t0_SIR_tauleap = 0.0 -function SIR_tauleap_f!(xnplus1::Vector{Int}, l_t::Vector{Float64}, l_tr::Vector{<:Transition}, +function SIR_tauleap_f!(xnplus1::Vector{Int}, l_t::Vector{Float64}, l_tr::Vector{Transition}, xn::Vector{Int}, tn::Float64, p::Vector{Float64}) tau = p[3] a1 = p[1] * xn[1] * xn[2] diff --git a/models/_bench_perf_test/ER_col.jl b/models/_bench_perf_test/ER_col.jl index 1354cd78792e9735e10684501c49919bc2bb777c..0cbc2d8667fa49b9785ca7cb6806ca0c1708a4d7 100644 --- a/models/_bench_perf_test/ER_col.jl +++ b/models/_bench_perf_test/ER_col.jl @@ -10,7 +10,7 @@ p = [1.0, 1.0, 1.0] x0 = [100, 100, 0, 0] t0 = 0.0 -function ER_col_f!(xnplus1::Vector{Int}, tnplus1::Vector{Float64}, tr::Vector{<:Transition}, +function ER_col_f!(xnplus1::Vector{Int}, tnplus1::Vector{Float64}, tr::Vector{Transition}, xn::AbstractVector{Int}, tn::Float64, p::Vector{Float64}) a1 = p[1] * xn[1] * xn[2] a2 = p[2] * xn[3] diff --git a/models/_bench_perf_test/ER_col_buffer.jl b/models/_bench_perf_test/ER_col_buffer.jl index b975fca1fc280983c92b18e1a667eb102308751f..f826f03107b1aef7cd434ca316cf00ef5b6cbd1e 100644 --- a/models/_bench_perf_test/ER_col_buffer.jl +++ b/models/_bench_perf_test/ER_col_buffer.jl @@ -9,7 +9,7 @@ l_tr = [:R1,:R2,:R3] p = [1.0, 1.0, 1.0] x0 = [100, 100, 0, 0] t0 = 0.0 -function ER_col_buffer_f!(mat_x::Matrix{Int}, l_t::Vector{Float64}, l_tr::Vector{<:Transition}, idx::Int, +function ER_col_buffer_f!(mat_x::Matrix{Int}, l_t::Vector{Float64}, l_tr::Vector{Transition}, idx::Int, xn::AbstractVector{Int}, tn::Float64, p::Vector{Float64}) a1 = p[1] * xn[1] * xn[2] a2 = p[2] * xn[3] diff --git a/models/_bench_perf_test/ER_row_buffer.jl b/models/_bench_perf_test/ER_row_buffer.jl index e8e66e2e97e6db1e2d3a400e865963ee0a5d49ac..395cbaa917b590dd7d0a2af4da45621d17f4bdf5 100644 --- a/models/_bench_perf_test/ER_row_buffer.jl +++ b/models/_bench_perf_test/ER_row_buffer.jl @@ -9,7 +9,7 @@ l_tr = [:R1,:R2,:R3] p = [1.0, 1.0, 1.0] x0 = [100, 100, 0, 0] t0 = 0.0 -function ER_row_buffer_f!(mat_x::Matrix{Int}, l_t::Vector{Float64}, l_tr::Vector{<:Transition}, idx::Int, +function ER_row_buffer_f!(mat_x::Matrix{Int}, l_t::Vector{Float64}, l_tr::Vector{Transition}, idx::Int, xn::AbstractVector{Int}, tn::Float64, p::Vector{Float64}) a1 = p[1] * xn[1] * xn[2] a2 = p[2] * xn[3] diff --git a/models/_bench_perf_test/SIR_col.jl b/models/_bench_perf_test/SIR_col.jl index 8bf497fdf8e7e42ffae8ae45089ef992c74f8353..3a261559825c49a0b009db457da2973ac392a5e5 100644 --- a/models/_bench_perf_test/SIR_col.jl +++ b/models/_bench_perf_test/SIR_col.jl @@ -9,7 +9,7 @@ l_tr = [:R1,:R2] p = [0.0012, 0.05] x0 = [95, 5, 0] t0 = 0.0 -function SIR_col_f!(xnplus1::Vector{Int}, tnplus1::Vector{Float64}, tr::Vector{<:Transition}, +function SIR_col_f!(xnplus1::Vector{Int}, tnplus1::Vector{Float64}, tr::Vector{Transition}, xn::AbstractVector{Int}, tn::Float64, p::Vector{Float64}) a1 = p[1] * xn[1] * xn[2] a2 = p[2] * xn[2] diff --git a/models/_bench_perf_test/SIR_col_buffer.jl b/models/_bench_perf_test/SIR_col_buffer.jl index cecf5f02e317b15dca0360db1d698b0c0126cf92..599dd591cf66a0d3e61370ec133b85411e7dc5c5 100644 --- a/models/_bench_perf_test/SIR_col_buffer.jl +++ b/models/_bench_perf_test/SIR_col_buffer.jl @@ -9,7 +9,7 @@ l_tr = [:R1,:R2] p = [0.0012, 0.05] x0 = [95, 5, 0] t0 = 0.0 -function SIR_col_buffer_f!(mat_x::Matrix{Int}, l_t::Vector{Float64}, l_tr::Vector{<:Transition}, idx::Int, +function SIR_col_buffer_f!(mat_x::Matrix{Int}, l_t::Vector{Float64}, l_tr::Vector{Transition}, idx::Int, xn::AbstractVector{Int}, tn::Float64, p::Vector{Float64}) a1 = p[1] * xn[1] * xn[2] a2 = p[2] * xn[2] diff --git a/models/_bench_perf_test/SIR_row_buffer.jl b/models/_bench_perf_test/SIR_row_buffer.jl index d8cae699db7b54c26fdc86969b79a549100f5f12..b6ba1cdf73671fbc499645ae609bca1d30834260 100644 --- a/models/_bench_perf_test/SIR_row_buffer.jl +++ b/models/_bench_perf_test/SIR_row_buffer.jl @@ -9,7 +9,7 @@ l_tr = [:R1,:R2] p = [0.0012, 0.05] x0 = [95, 5, 0] t0 = 0.0 -function SIR_row_buffer_f!(mat_x::Matrix{Int}, l_t::Vector{Float64}, l_tr::Vector{<:Transition}, idx::Int, +function SIR_row_buffer_f!(mat_x::Matrix{Int}, l_t::Vector{Float64}, l_tr::Vector{Transition}, idx::Int, xn::AbstractVector{Int}, tn::Float64, p::Vector{Float64}) a1 = p[1] * xn[1] * xn[2] a2 = p[2] * xn[2] diff --git a/models/poisson.jl b/models/poisson.jl index 0f107b227cb8d38361eea2603dcff05f835cc01b..c0133aeed16d3497158b1a695910e532239cc320 100644 --- a/models/poisson.jl +++ b/models/poisson.jl @@ -10,7 +10,7 @@ l_tr_poisson = [:R] p_poisson = [5.0] x0_poisson = [0] t0_poisson = 0.0 -function poisson_f!(xnplus1::Vector{Int}, l_t::Vector{Float64}, l_tr::Vector{<:Transition}, +function poisson_f!(xnplus1::Vector{Int}, l_t::Vector{Float64}, l_tr::Vector{Transition}, xn::Vector{Int}, tn::Float64, p::Vector{Float64}) u1 = rand()