52 lines
1.2 KiB
R
52 lines
1.2 KiB
R
|
library(shiny)
|
||
|
|
||
|
# Define server logic for random distribution app ----
|
||
|
server <- function(input, output) {
|
||
|
|
||
|
# Reactive expression to generate the requested distribution ----
|
||
|
# This is called whenever the inputs change. The output functions
|
||
|
# defined below then use the value computed from this expression
|
||
|
d <- reactive({
|
||
|
dist <- switch(
|
||
|
input$dist,
|
||
|
norm = rnorm,
|
||
|
unif = runif,
|
||
|
lnorm = rlnorm,
|
||
|
exp = rexp,
|
||
|
rnorm
|
||
|
)
|
||
|
|
||
|
dist(input$n)
|
||
|
})
|
||
|
|
||
|
# Generate a plot of the data ----
|
||
|
# Also uses the inputs to build the plot label. Note that the
|
||
|
# dependencies on the inputs and the data reactive expression are
|
||
|
# both tracked, and all expressions are called in the sequence
|
||
|
# implied by the dependency graph.
|
||
|
output$plot <- renderPlot({
|
||
|
dist <- input$dist
|
||
|
n <- input$n
|
||
|
|
||
|
hist(
|
||
|
d(),
|
||
|
main = paste("r", dist, "(", n, ")", sep = ""),
|
||
|
col = "#75AADB",
|
||
|
border = "white"
|
||
|
)
|
||
|
})
|
||
|
|
||
|
# Generate a summary of the data ----
|
||
|
output$summary <- renderPrint({
|
||
|
summary(d())
|
||
|
})
|
||
|
|
||
|
# Generate an HTML table view of the head of the data ----
|
||
|
output$table <- renderTable({
|
||
|
head(data.frame(x = d()))
|
||
|
})
|
||
|
}
|
||
|
|
||
|
# Create Shiny app ----
|
||
|
shinyApp(ui = htmlTemplate("www/index.html"), server)
|