inst/humanrater2/server.R

library(shiny)
library(dplyr)
library(reshape2)
library(ggplot2)

options(shiny.maxRequestSize=20*1024^2)

# Define server logic required to draw a histogram
shinyServer(function(input, output) {
  
  raw_input <- reactive({
    validate(
      need(input[["amp_file"]], "Provide a datafile")
    )
    
    read.csv(input[["amp_file"]][["datapath"]])
  })
  
  
  all_splits <- reactive({

    split(1L:ncol(raw_input()), ceiling(seq_along(1L:ncol(raw_input()))/input[["n_splits"]]))
  })
  
  runs <- reactiveValues(
    selected = character(),
    split = 1
  )
  
  observeEvent(input[["next"]], {
    runs[["split"]] <- runs[["split"]] + 1
  })
  
  observeEvent(input[["previous"]], {
    runs[["split"]] <- runs[["split"]] - 1
  })
  
  observeEvent(input[["plot_click"]], {
    selected_runs <- as.character(nearPoints(plot_dat(), input[["plot_click"]], 
                                             xvar = "cycle", yvar = "value")[, "run"])
    
    if(length(selected_runs) > 0){
      remove <- selected_runs %in% runs[["selected"]]
      runs[["selected"]] <- runs[["selected"]][!runs[["selected"]] %in% selected_runs[remove]]
      runs[["selected"]] <- c(runs[["selected"]], selected_runs[!remove])
    }
  })
  
  plot_dat <- reactive({
    # if(!is.null(input[["amp_file"]][["datapath"]]))
    #   browser()
    
    cbind(cycle = 1L:nrow(raw_input()), 
          raw_input()[all_splits()[[runs[["split"]]]]]) %>% 
      melt(id.vars = "cycle", variable.name = "run") %>% 
      mutate(selected = run %in% runs[["selected"]])
  })
  
  
  output[["amp_plot"]] <- renderPlot({
    dat <- plot_dat() 
    
    ggplot(dat, aes(x = cycle, y = value, color = run, group = run, linetype = selected)) +
      geom_line(size = 1.5) +
      geom_point(size = 3, show.legend = FALSE) +
      scale_linetype_manual(values = c("solid", "dashed")) +
      theme_bw(base_size = 17) +
      guides(color = "none") +
      facet_wrap(~ selected, ncol = 1)
    
  }, height = 800)
  
  
  output[["selected_info"]] <- renderPrint({
    dput(as.character(runs[["selected"]]))
  })
  
  output[["chosen_split"]] <- renderText({
    paste0("Chosen split: ", runs[["split"]], " (out of ", last(names(all_splits())), " splits).")
  })
  
})

Try the PCRedux package in your browser

Any scripts or data that you put into this service are public.

PCRedux documentation built on May 11, 2022, 5:18 p.m.