Description Usage Arguments Details Value Examples
Interface to ode()
1 |
y |
named vector of type numeric. Initial values for the integration |
times |
vector of type numeric. Integration times |
func |
return value from funC() |
parms |
named vector of type numeric. |
... |
further arguments going to |
See deSolve-package for a full description of possible arguments
matrix with times and states
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 | ## Not run:
##############################################################################################
## Ozone formation and decay, modified by external forcings
##############################################################################################
library(deSolve)
data(forcData)
forcData$value <- forcData$value + 1
# O2 + O <-> O3
f <- c(
O3 = " (build_O3 + u_build) * O2 * O - (decay_O3 + u_degrade) * O3",
O2 = "-(build_O3 + u_build) * O2 * O + (decay_O3 + u_degrade) * O3",
O = "-(build_O3 + u_build) * O2 * O + (decay_O3 + u_degrade) * O3"
)
# Generate ODE function
forcings <- c("u_build", "u_degrade")
func <- funC(f, forcings = forcings, modelname = "test", fcontrol = "nospline", nGridpoints = 10)
# Initialize times, states, parameters and forcings
times <- seq(0, 8, by = .1)
yini <- c(O3 = 0, O2 = 3, O = 2)
pars <- c(build_O3 = 1/6, decay_O3 = 1)
forc <- setForcings(func, forcData)
# Solve ODE
out <- odeC(y = yini, times = times, func = func, parms = pars, forcings = forc)
# Plot solution
par(mfcol=c(1,2))
t1 <- unique(forcData[,2])
M1 <- matrix(forcData[,3], ncol=2)
t2 <- out[,1]
M2 <- out[,2:4]
M3 <- out[,5:6]
matplot(t1, M1, type="l", lty=1, col=1:2, xlab="time", ylab="value",
main="forcings", ylim=c(0, 4))
matplot(t2, M3, type="l", lty=2, col=1:2, xlab="time", ylab="value",
main="forcings", add=TRUE)
legend("topleft", legend = c("u_build", "u_degrade"), lty=1, col=1:2)
matplot(t2, M2, type="l", lty=1, col=1:3, xlab="time", ylab="value",
main="response")
legend("topright", legend = c("O3", "O2", "O"), lty=1, col=1:3)
## End(Not run)
|
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.