inst/templates/00_init.r

defaults <- list(
  nfcore      = "{{{nfcore}}}",     ## directory that contains nfcore output
  metadata    = "{{{metadata}}}",    ## Path to  spreadsheet containing covariates
  file_col    = {{{file_col}}},    ## Column in that spreadsheet that identifies the basename of count file for each sample
  name_col    = {{{name_col}}},    ## Column in that spreadsheet that identifies the basename of count file for each sample
  counts      = "{{{counts}}}",      ## directory that contains the quantified gene counts
  org_package = "{{{org_package}}}", ## NULL will derive org.*.eg.db from nfcore info, otherwise specifcy string identifying annotation package of relevant species.
  count_source = "{{{count_source}}}"
)


library(readxl)
library(tidyverse)
library(tximport)
library(DESeq2)
library(DESdemonA)
library(R.utils)


args <- R.utils::cmdArgs(defaults=defaults)


if (grepl("\\.csv$", args$metadata)) {
  sample_sheet <- read.csv(args$metadata, header=TRUE, check.names=FALSE)
} else {
  sample_sheet <- readxl::read_excel(args$metadata, sheet=1)
}
file_col <- args$file_col[args$file_col %in% names(sample_sheet)][1]
if (is.na(file_col)) {
  stop("Metadata has none of: ", paste(args$file_col, collapse=", "))
}
name_col <- args$name_col[args$name_col %in% names(sample_sheet)][1]
if (is.na(name_col)) {
  stop("Metadata has none of: ", paste(args$name_col, collapse=", "))
}


sample_sheet[sapply(sample_sheet, is.character)] <- lapply(sample_sheet[sapply(sample_sheet, is.character)], 
                                                          as.factor)

tx_path <-   file.path(
  args$counts,
  paste0(as.character(sample_sheet[[file_col]]), ".genes.results")
)

names(tx_path) <- as.character(sample_sheet[[name_col]])
not_here <- !file.exists(tx_path)
if (any(not_here)) {
  warning("Dropping samples", tx_path[not_here])
  tx_path <- tx_path[!not_here]
  sample_sheet <- sample_sheet[!not_here,]
}

txi <- tximport(tx_path, type="rsem")
txi$length[txi$length==0] <- 1

dds <- DESeqDataSetFromTximport(txi, sample_sheet, ~ 1) # ok to have fixed trivial design - it'll get swapped out
ind <- rowSums(counts(dds)!=0) > 0
dds <- dds[ind,]

txi[c("abundance", "counts", "length")] <- map(txi[c("abundance", "counts", "length")], ~ .[ind,])


if (args$org_package=="") {
  run_info <- readLines(file.path(args$nfcore, "pipeline_info", "pipeline_report.txt"))
  gtf_file <- sub(".*/", "", grep(" - gtf:", run_info, value=TRUE))
  organism <- list(binomial=strsplit(gtf_file, ".", fixed=TRUE)[[1]][1])
  organism <- list(
    genus   = sub("_.*", "", organism$binomial),
    species = sub(".*_", "", organism$binomial)
  )
  organism$Gs <- paste0(toupper(substr(organism$genus, 1, 1)),
                       tolower(substr(organism$species, 1, 1)))
  organism$org <-  unique(grep(paste0("org\\.",organism$Gs),row.names(installed.packages()),  value=TRUE))
  if (length(organism$org)!=1) {
    stop(paste("Can't find annotation for", organism$genus, organism$species))
  }
} else {
  organism <- list(org=args$org_package)
}
metadata(dds)$organism <- organism
metadata(dds)$template_git <- packageDescription("DESdemonA")$git_last_commit
metadata(dds)$count_source <- args$count_source

library(organism$org, character.only=TRUE)

mcols(dds)$symbol <- mapIds(
  eval(parse(text = organism$org)), 
  keys=row.names(dds),
  column="SYMBOL",
  keytype="ENSEMBL",
  multiVals="first")[row.names(dds)]

mcols(dds)$entrez <- mapIds(
  eval(parse(text = organism$org)),
  keys=row.names(dds),
  column="ENTREZID",
  keytype="ENSEMBL",
  multiVals="first")[row.names(dds)]

save(dds, file=file.path("data",paste0("counts_", args$count_source, ".rda")))
saveRDS(dds, file=file.path("data",paste0("counts_", args$count_source, ".rds")))
FrancisCrickInstitute/DESdemonA documentation built on Jan. 2, 2023, 8:08 p.m.