Бегло взглянув, вам нужно запустить другую функцию, чтобы получить param: res, а затем вставить ее в исходную функцию, как вы описали в сообщении:
solve_SIR <- function(S0, I0, beta = 1, gamma = 1, delta_t = 0.01, times = 8000) {
res <- matrix(
NA, nrow = times, ncol = 4, dimnames = list(NULL, c('S', 'I', 'R', 'Time'))
)
res[1, ] <- c(S0, I0, 1 - S0 - I0, delta_t)
dS <- function(S, I) -beta * I * S
dI <- function(S, I) beta * I * S - gamma * I
for (i in seq(2, times)) {
S <- res[i-1, 1]
I <- res[i-1, 2]
res[i, 1] <- res[i-1, 1] + delta_t * dS(S, I)
res[i, 2] <- res[i-1, 2] + delta_t * dI(S, I)
res[i, 4] <- delta_t * i
}
res[, 3] <- 1 - res[, 1] - res[, 2]
res
}
используйте функцию для gen param и выбрав случайные значения для S0 и I0, вы получите желаемый график.
plot_SIR(solve_SIR(0.95, 0.05))