-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathBistability.R
executable file
·70 lines (60 loc) · 1.98 KB
/
Bistability.R
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
library("deSolve")
library(tidyr)
library(dplyr)
library(magrittr)
library(ggplot2)
library(gridExtra)
bistable <- function(t, y, p) {
with(as.list(c(y, p)), {
dX <- X^h/(K^h + X^h) - d*X
list(X=dX)
})
}
## prepare data structures to create UI programmatically
y0 <- c(X=1)
parms <- c(K = 1, h=2, d=0.25)
aspect <- 0.5
makelist <- function(i, obj, min=NA, max=NA, step=NA, width=NULL) {
list(inputId=names(obj[i]), label=names(obj[i]),
value=unname(obj[i]), min=min, max=max, step=step,
width=width)
}
## two lists of lists
L_parms <- lapply(1:length(parms), makelist, obj=parms, min=0, max=2, step=0.05, width=200)
L_y0 <- lapply(1:length(y0), makelist, obj=y0, min=0, max=5, step=0.1, width=200)
server <- function(input, output, session) {
output$bistable <- renderPlot({
L_input <- reactiveValuesToList(input) # to enable width
y0 <- with(L_input, c(X=X))
parms <- with(L_input, c(K=K, h=h, d=d))
times <- seq(0, 150, .1)
out <- ode(y0, times, bistable, parms)
df1 <- data.frame(out) %>% gather(var, value,-time)
par(mfrow=c(2, 1))
f <- ggplot(df1, aes(x=time, y=value, color=var)) + geom_line(size=1) + theme_bw() + xlab("Time") +
ylab("Species") + theme(aspect.ratio = 1/4, legend.position = "top", legend.title = element_blank()) +
ggtitle("time course") + ylim(c(0,5))
print(f)
}, height = function() {
aspect * session$clientData$output_bistable_width
})
}
ui <- fluidPage(
headerPanel("A simple bistable system"),
withMathJax("$$\\frac{dX}{dt} = \\frac{X^h}{X^h + K^h} - dX$$"),
sidebarLayout(
sidebarPanel(
## generic creation of UI elements
h4("Initial values"),
lapply(L_y0, function(x) do.call("sliderInput", x)), # <--------
h4("Parameters"),
lapply(L_parms, function(x) do.call("sliderInput", x)), # <--------
width = 4
),
mainPanel(
h4("Simulation results"),
plotOutput("bistable")
)
)
)
shinyApp(ui = ui, server = server)