Решение дифференциальных уравнений в цикле с разными параметрами каждый раз R

Я думаю, это должно быть просто. Я численно решаю ряд дифференциальных уравнений в R. Когда я делаю это одно, это нормально. Однако мне нужно проверить набор дифференциальных уравнений для нескольких групп параметров, поэтому я использую цикл. Проблема в том, что для всего набора параметров он показывает одинаковые значения, что не правильно.

contrand<-sample(paste0("p",1:18), 
                 size=nb, replace=TRUE, 
                 prob=c(0, 0, 0.052, 0.013, 0.033,  0.017, 0.002,0.026, 0.005, 0.093, 
                        0.186, 0.006, 0.001, 0.004, 0.0044, 0.4395, 0.005, 0.113))

z.cont <- data.frame(matrix(rep(NA,1*nb),nrow=nb,ncol=1))
for (i in 1:nb){
    params <- get(contrand[i])
    model<-function(t,x,params){
      S<-x[1]
      I<-x[2]
      R<-x[3]
      with(as.list(params),{
        N<- S+I+R
        dS <- birth*N - beta*S*I- death*S
        dI <- beta*S*I - gamma*I - death*I
        dR <- gamma*I - death*R

        dx <- c(dS,dI,dR)
        list(dx)
      })
    }
    out<-as.data.frame(lsoda(xstart,times,model,params))
    I<-as.data.frame(out$I)
    z.cont[i,1] <- Iv[157,]
}

0 ответов

Другие вопросы по тегам