inst/PCRedux_gui/functions.R

my_DT <- function(x)
  datatable(x, escape = FALSE, extensions = 'Buttons',
            filter = "top", rownames = FALSE, 
            options = list(scrollX = TRUE,
                           dom = "Brtip",
                           buttons = c("copy", "csv", "excel", "print"),
                           pageLength = 50,
                           digits = 4)) %>% 
  formatStyle(1L:ncol(x), color = "black")

# shiny_encu -------------------------------------------
# a shiny-compatible version of encu https://github.com/devSJR/PCRedux/blob/master/R/encu.R

calcRunRes <- function(ncol_data_RFU, data_RFU) {
  do.call(rbind, lapply(1L:ncol_data_RFU, function(ith_run) {
    incProgress(1/ncol_data_RFU)
    pcrfit_single(data_RFU[, ith_run])
  }))
}

shiny_encu <- function(data, detection_chemistry = NA, device = NA) {
  # Determine the number of available cores and register them
  
  # Prepare the data for further processing
  # Normalize RFU values to the alpha quantiles (0.999)
  cycles <- data.frame(cycles = data[, 1])
  data_RFU <- data.frame(data[, -1, drop = FALSE])
  ncol_data_RFU <- ncol(data_RFU)
  data_RFU_colnames <- colnames(data_RFU)

  run_res <- calcRunRes(ncol_data_RFU, data_RFU)

  res <- cbind(runs = colnames(data_RFU), run_res)
  rownames(res) <- NULL
  res
}

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.