Как кодировать пропущенное начальное значение купе в ODE, используя openbugs
Я хочу вывести параметры в обыкновенных дифференциальных уравнениях (модель отделения инфекционных заболеваний), используя openBUGS. Однако я не знаю начальную стоимость одного из отсеков. Как мне кодировать недостающее значение купе в openBUGS?
Ниже приведен код, который я написал.
В коде два отсека модель "C" для отсека Начальное значение C[2] для отсека является пропущенным значением.
Конечно, этот код не может быть инициализирован:(
(сообщение об ошибке: множественные определения узла C[2])
Я не мог решить проблему. Заранее спасибо.
model
{
# Observed value.
for (i in 1:n.grid) {
Ca[i] ~dbin(p, Com[i,2])
}
## ODE
Com[1:n.grid, 1:dim] <- ode(init[1:dim], grid[1:n.grid],
D(C[1:dim], t), 0, tol)
D(C[1],t)<-alpha * C[1] - mu * C[1] - beta * C[2]
D(C[2],t)<-beta * C[2] - kappa * C[2]
#prior
C[2] ~ dunif(0,10)
alpha ~ dbeta(2,5)
mu ~ dbeta(2,5)
kappa ~ dnorm(0,0.11)
beta ~ dbeta(2,5)
}
### data
list(
n.grid = 20, dim = 2, tol = 1.0E-3,
init = c(10000, NA,0),
grid = c(1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20),
Ca= c(1,3,5,7,9,11,12,13,14,15,16,33,45,67,78,89,90,100,130,134),
p = 0.95
)
### initial values for sampler ###
list( alpha = 0.5, mu = 0.4, kappa = 0.2, beta = 0.3)