Mercurial > repos > workflow4metabolomics > camera_groupcorr
annotate lib.r @ 0:cb57be5de070 draft default tip
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
author | workflow4metabolomics |
---|---|
date | Sun, 24 Nov 2024 21:29:48 +0000 |
parents | |
children |
rev | line source |
---|---|
0
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
1 # lib.r |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
2 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
3 # @author G. Le Corguille |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
4 # solve an issue with batch if arguments are logical TRUE/FALSE |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
5 parseCommandArgs <- function(...) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
6 args <- batch::parseCommandArgs(...) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
7 for (key in names(args)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
8 if (args[key] %in% c("TRUE", "FALSE")) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
9 args[key] <- as.logical(args[key]) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
10 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
11 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
12 return(args) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
13 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
14 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
15 # @author G. Le Corguille |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
16 # This function will |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
17 # - load the packages |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
18 # - display the sessionInfo |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
19 loadAndDisplayPackages <- function(pkgs) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
20 for (pkg in pkgs) suppressPackageStartupMessages(stopifnot(library(pkg, quietly = TRUE, logical.return = TRUE, character.only = TRUE))) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
21 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
22 sessioninfo <- sessionInfo() |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
23 cat(sessioninfo$R.version$version.string, "\n") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
24 cat("Main packages:\n") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
25 for (pkg in names(sessioninfo$otherPkgs)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
26 cat(paste(pkg, packageVersion(pkg)), "\t") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
27 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
28 cat("\n") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
29 cat("Other loaded packages:\n") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
30 for (pkg in names(sessioninfo$loadedOnly)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
31 cat(paste(pkg, packageVersion(pkg)), "\t") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
32 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
33 cat("\n") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
34 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
35 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
36 # This function retrieve a xset like object |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
37 # @author Gildas Le Corguille lecorguille@sb-roscoff.fr |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
38 getxcmsSetObject <- function(xobject) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
39 # XCMS 1.x |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
40 if (class(xobject) == "xcmsSet") { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
41 return(xobject) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
42 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
43 # XCMS 3.x |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
44 if (class(xobject) == "XCMSnExp") { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
45 # Get the legacy xcmsSet object |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
46 suppressWarnings(xset <- as(xobject, "xcmsSet")) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
47 if (is.null(xset@phenoData$sample_group)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
48 sampclass(xset) <- "." |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
49 } else { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
50 sampclass(xset) <- xset@phenoData$sample_group |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
51 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
52 if (!is.null(xset@phenoData$sample_name)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
53 rownames(xset@phenoData) <- xset@phenoData$sample_name |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
54 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
55 return(xset) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
56 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
57 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
58 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
59 # @author G. Le Corguille |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
60 # The function create a pdf from the different png generated by diffreport |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
61 diffreport_png2pdf <- function(filebase) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
62 dir.create("pdf") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
63 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
64 pdfEicOutput <- paste0("pdf/", filebase, "-eic_pdf.pdf") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
65 pdfBoxOutput <- paste0("pdf/", filebase, "-box_pdf.pdf") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
66 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
67 system(paste0("gm convert ", filebase, "_eic/*.png ", pdfEicOutput)) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
68 system(paste0("gm convert ", filebase, "_box/*.png ", pdfBoxOutput)) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
69 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
70 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
71 # @author G. Le Corguille |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
72 # The function create a zip archive from the different png generated by diffreport |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
73 diffreport_png2zip <- function() { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
74 zip("eic.zip", dir(pattern = "_eic"), zip = Sys.which("zip")) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
75 zip("box.zip", dir(pattern = "_box"), zip = Sys.which("zip")) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
76 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
77 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
78 # The function create a zip archive from the different tabular generated by diffreport |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
79 diffreport_tabular2zip <- function() { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
80 zip("tabular.zip", dir(pattern = "tabular/*"), zip = Sys.which("zip")) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
81 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
82 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
83 # @author G. Le Corguille |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
84 # This function convert if it is required the Retention Time in minutes |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
85 RTSecondToMinute <- function(variableMetadata, convertRTMinute) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
86 if (convertRTMinute) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
87 # converting the retention times (seconds) into minutes |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
88 print("converting the retention times into minutes in the variableMetadata") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
89 variableMetadata[, "rt"] <- variableMetadata[, "rt"] / 60 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
90 variableMetadata[, "rtmin"] <- variableMetadata[, "rtmin"] / 60 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
91 variableMetadata[, "rtmax"] <- variableMetadata[, "rtmax"] / 60 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
92 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
93 return(variableMetadata) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
94 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
95 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
96 # @author G. Le Corguille |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
97 # This function format ions identifiers |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
98 formatIonIdentifiers <- function(variableMetadata, numDigitsRT = 0, numDigitsMZ = 0) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
99 splitDeco <- strsplit(as.character(variableMetadata$name), "_") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
100 idsDeco <- sapply(splitDeco, function(x) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
101 deco <- unlist(x)[2] |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
102 if (is.na(deco)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
103 return("") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
104 } else { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
105 return(paste0("_", deco)) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
106 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
107 }) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
108 namecustom <- make.unique(paste0("M", round(variableMetadata[, "mz"], numDigitsMZ), "T", round(variableMetadata[, "rt"], numDigitsRT), idsDeco)) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
109 variableMetadata <- cbind(name = variableMetadata$name, namecustom = namecustom, variableMetadata[, !(colnames(variableMetadata) %in% c("name"))]) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
110 return(variableMetadata) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
111 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
112 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
113 # The function annotateDiffreport without the corr function which bugs |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
114 annotatediff <- function(xset = xset, args = args, variableMetadataOutput = "variableMetadata.tsv") { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
115 # Resolve the bug with x11, with the function png |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
116 options(bitmapType = "cairo") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
117 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
118 # Check if the fillpeaks step has been done previously, if it hasn't, there is an error message and the execution is stopped. |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
119 res <- try(is.null(xset@filled)) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
120 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
121 # ------ annot ------- |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
122 args$calcCiS <- as.logical(args$calcCiS) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
123 args$calcIso <- as.logical(args$calcIso) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
124 args$calcCaS <- as.logical(args$calcCaS) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
125 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
126 # common parameters |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
127 args4annotate <- list( |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
128 object = xset, |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
129 nSlaves = args$nSlaves, sigma = args$sigma, perfwhm = args$perfwhm, |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
130 maxcharge = args$maxcharge, maxiso = args$maxiso, minfrac = args$minfrac, |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
131 ppm = args$ppm, mzabs = args$mzabs, quick = args$quick, |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
132 polarity = args$polarity, max_peaks = args$max_peaks, intval = args$intval |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
133 ) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
134 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
135 if (args$quick == FALSE) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
136 args4annotate <- append( |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
137 args4annotate, |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
138 list( |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
139 graphMethod = args$graphMethod, cor_eic_th = args$cor_eic_th, pval = args$pval, |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
140 calcCiS = args$calcCiS, calcIso = args$calcIso, calcCaS = args$calcCaS |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
141 ) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
142 ) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
143 # no ruleset |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
144 if (!is.null(args$multiplier)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
145 args4annotate <- append( |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
146 args4annotate, |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
147 list(multiplier = args$multiplier) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
148 ) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
149 } else { # ruleset |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
150 rulset <- read.table(args$rules, h = TRUE, sep = ";") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
151 if (ncol(rulset) < 4) rulset <- read.table(args$rules, h = TRUE, sep = "\t") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
152 if (ncol(rulset) < 4) rulset <- read.table(args$rules, h = TRUE, sep = ",") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
153 if (ncol(rulset) < 4) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
154 error_message <- "Your ruleset file seems not well formatted. The column separators accepted are ; , and tabulation" |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
155 print(error_message) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
156 stop(error_message) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
157 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
158 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
159 args4annotate <- append( |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
160 args4annotate, |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
161 list(rules = rulset) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
162 ) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
163 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
164 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
165 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
166 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
167 # launch annotate |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
168 xa <- do.call("annotate", args4annotate) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
169 peakList <- getPeaklist(xa, intval = args$intval) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
170 peakList <- cbind(groupnames(xa@xcmsSet), peakList) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
171 colnames(peakList)[1] <- c("name") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
172 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
173 # --- Multi condition : diffreport --- |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
174 diffrepOri <- NULL |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
175 if (!is.null(args$runDiffreport) && nlevels(sampclass(xset)) >= 2) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
176 # Check if the fillpeaks step has been done previously, if it hasn't, there is an error message and the execution is stopped. |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
177 res <- try(is.null(xset@filled)) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
178 classes <- levels(sampclass(xset)) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
179 for (i in seq_len(length(classes) - 1)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
180 for (n in seq_len(length(classes))) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
181 if (i + n <= length(classes)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
182 filebase <- paste(classes[i], class2 = classes[i + n], sep = "-vs-") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
183 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
184 diffrep <- diffreport( |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
185 object = xset, class1 = classes[i], class2 = classes[i + n], |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
186 filebase = filebase, eicmax = args$eicmax, eicwidth = args$eicwidth, |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
187 sortpval = TRUE, value = args$value, h = args$h, w = args$w, mzdec = args$mzdec, missing = 0 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
188 ) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
189 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
190 diffrepOri <- diffrep |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
191 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
192 # renamming of the column rtmed to rt to fit with camera peaklist function output |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
193 colnames(diffrep)[colnames(diffrep) == "rtmed"] <- "rt" |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
194 colnames(diffrep)[colnames(diffrep) == "mzmed"] <- "mz" |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
195 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
196 # combines results and reorder columns |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
197 diffrep <- merge(peakList, diffrep[, c("name", "fold", "tstat", "pvalue")], by.x = "name", by.y = "name", sort = FALSE) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
198 diffrep <- cbind(diffrep[, !(colnames(diffrep) %in% c(sampnames(xa@xcmsSet)))], diffrep[, (colnames(diffrep) %in% c(sampnames(xa@xcmsSet)))]) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
199 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
200 diffrep <- RTSecondToMinute(diffrep, args$convertRTMinute) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
201 diffrep <- formatIonIdentifiers(diffrep, numDigitsRT = args$numDigitsRT, numDigitsMZ = args$numDigitsMZ) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
202 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
203 if (args$sortpval) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
204 diffrep <- diffrep[order(diffrep$pvalue), ] |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
205 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
206 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
207 dir.create("tabular", showWarnings = FALSE) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
208 write.table(diffrep, sep = "\t", quote = FALSE, row.names = FALSE, file = paste("tabular/", filebase, "_tsv.tabular", sep = "")) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
209 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
210 if (args$eicmax != 0) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
211 if (args$png2 == "pdf") { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
212 diffreport_png2pdf(filebase) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
213 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
214 if (args$png2 == "zip") { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
215 diffreport_png2zip() |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
216 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
217 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
218 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
219 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
220 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
221 if (args$tabular2 == "zip") { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
222 diffreport_tabular2zip() |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
223 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
224 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
225 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
226 # --- variableMetadata --- |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
227 variableMetadata <- peakList[, !(make.names(colnames(peakList)) %in% c(make.names(sampnames(xa@xcmsSet))))] |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
228 variableMetadata <- RTSecondToMinute(variableMetadata, args$convertRTMinute) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
229 variableMetadata <- formatIonIdentifiers(variableMetadata, numDigitsRT = args$numDigitsRT, numDigitsMZ = args$numDigitsMZ) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
230 # if we have 2 conditions, we keep stat of diffrep |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
231 if (!is.null(args$runDiffreport) && nlevels(sampclass(xset)) == 2) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
232 variableMetadata <- merge(variableMetadata, diffrep[, c("name", "fold", "tstat", "pvalue")], by.x = "name", by.y = "name", sort = FALSE) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
233 if (exists("args[[\"sortpval\"]]")) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
234 variableMetadata <- variableMetadata[order(variableMetadata$pvalue), ] |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
235 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
236 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
237 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
238 variableMetadataOri <- variableMetadata |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
239 write.table(variableMetadata, sep = "\t", quote = FALSE, row.names = FALSE, file = variableMetadataOutput) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
240 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
241 return(list("xa" = xa, "diffrep" = diffrepOri, "variableMetadata" = variableMetadataOri)) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
242 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
243 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
244 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
245 combinexsAnnos_function <- function( |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
246 xaP, xaN, diffrepP = NULL, diffrepN = NULL, |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
247 pos = TRUE, tol = 2, ruleset = NULL, keep_meta = TRUE, convertRTMinute = FALSE, numDigitsMZ = 0, |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
248 numDigitsRT = 0, variableMetadataOutput = "variableMetadata.tsv") { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
249 # Load the two Rdata to extract the xset objects from positive and negative mode |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
250 cat("\tObject xset from positive mode\n") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
251 print(xaP) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
252 cat("\n") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
253 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
254 cat("\tObject xset from negative mode\n") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
255 print(xaN) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
256 cat("\n") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
257 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
258 cat("\n") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
259 cat("\tCombining...\n") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
260 # Convert the string to numeric for creating matrix |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
261 row <- as.numeric(strsplit(ruleset, ",")[[1]][1]) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
262 column <- as.numeric(strsplit(ruleset, ",")[[1]][2]) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
263 ruleset <- cbind(row, column) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
264 # Test if the file comes from an older version tool |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
265 if ((!is.null(xaP)) && (!is.null(xaN))) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
266 # Launch the combinexsannos function from CAMERA |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
267 cAnnot <- combinexsAnnos(xaP, xaN, pos = pos, tol = tol, ruleset = ruleset) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
268 } else { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
269 stop("You must relauch the CAMERA.annotate step with the lastest version.") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
270 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
271 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
272 if (pos) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
273 xa <- xaP |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
274 mode <- "neg. Mode" |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
275 } else { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
276 xa <- xaN |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
277 mode <- "pos. Mode" |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
278 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
279 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
280 peakList <- getPeaklist(xa) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
281 peakList <- cbind(groupnames(xa@xcmsSet), peakList) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
282 colnames(peakList)[1] <- c("name") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
283 variableMetadata <- cbind(peakList, cAnnot[, c("isotopes", "adduct", "pcgroup", mode)]) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
284 variableMetadata <- variableMetadata[, !(colnames(variableMetadata) %in% c(sampnames(xa@xcmsSet)))] |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
285 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
286 # Test if there are more than two classes (conditions) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
287 if (nlevels(sampclass(xaP@xcmsSet)) == 2 && (!is.null(diffrepN)) && (!is.null(diffrepP))) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
288 diffrepP <- diffrepP[, c("name", "fold", "tstat", "pvalue")] |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
289 colnames(diffrepP) <- paste("P.", colnames(diffrepP), sep = "") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
290 diffrepN <- diffrepN[, c("name", "fold", "tstat", "pvalue")] |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
291 colnames(diffrepN) <- paste("N.", colnames(diffrepN), sep = "") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
292 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
293 variableMetadata <- merge(variableMetadata, diffrepP, by.x = "name", by.y = "P.name") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
294 variableMetadata <- merge(variableMetadata, diffrepN, by.x = "name", by.y = "N.name") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
295 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
296 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
297 rownames(variableMetadata) <- NULL |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
298 # TODO: checker colnames(variableMetadata)[1:2] = c("name", "mz/rt"); |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
299 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
300 variableMetadata <- RTSecondToMinute(variableMetadata, convertRTMinute) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
301 variableMetadata <- formatIonIdentifiers(variableMetadata, numDigitsRT = numDigitsRT, numDigitsMZ = numDigitsMZ) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
302 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
303 # If the user want to keep only the metabolites which match a difference |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
304 if (keep_meta) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
305 variableMetadata <- variableMetadata[variableMetadata[, c(mode)] != "", ] |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
306 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
307 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
308 # Write the output into a tsv file |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
309 write.table(variableMetadata, sep = "\t", quote = FALSE, row.names = FALSE, file = variableMetadataOutput) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
310 return(variableMetadata) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
311 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
312 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
313 # This function get the raw file path from the arguments |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
314 getRawfilePathFromArguments <- function(singlefile, zipfile, args) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
315 if (!is.null(args$zipfile)) zipfile <- args$zipfile |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
316 if (!is.null(args$zipfilePositive)) zipfile <- args$zipfilePositive |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
317 if (!is.null(args$zipfileNegative)) zipfile <- args$zipfileNegative |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
318 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
319 if (!is.null(args$singlefile_galaxyPath)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
320 singlefile_galaxyPaths <- args$singlefile_galaxyPath |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
321 singlefile_sampleNames <- args$singlefile_sampleName |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
322 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
323 if (!is.null(args$singlefile_galaxyPathPositive)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
324 singlefile_galaxyPaths <- args$singlefile_galaxyPathPositive |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
325 singlefile_sampleNames <- args$singlefile_sampleNamePositive |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
326 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
327 if (!is.null(args$singlefile_galaxyPathNegative)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
328 singlefile_galaxyPaths <- args$singlefile_galaxyPathNegative |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
329 singlefile_sampleNames <- args$singlefile_sampleNameNegative |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
330 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
331 if (exists("singlefile_galaxyPaths")) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
332 singlefile_galaxyPaths <- unlist(strsplit(singlefile_galaxyPaths, ",")) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
333 singlefile_sampleNames <- unlist(strsplit(singlefile_sampleNames, ",")) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
334 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
335 singlefile <- NULL |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
336 for (singlefile_galaxyPath_i in seq_len(length(singlefile_galaxyPaths))) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
337 singlefile_galaxyPath <- singlefile_galaxyPaths[singlefile_galaxyPath_i] |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
338 singlefile_sampleName <- singlefile_sampleNames[singlefile_galaxyPath_i] |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
339 singlefile[[singlefile_sampleName]] <- singlefile_galaxyPath |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
340 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
341 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
342 for (argument in c( |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
343 "zipfile", "zipfilePositive", "zipfileNegative", |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
344 "singlefile_galaxyPath", "singlefile_sampleName", |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
345 "singlefile_galaxyPathPositive", "singlefile_sampleNamePositive", |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
346 "singlefile_galaxyPathNegative", "singlefile_sampleNameNegative" |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
347 )) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
348 args[[argument]] <- NULL |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
349 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
350 return(list(zipfile = zipfile, singlefile = singlefile, args = args)) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
351 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
352 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
353 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
354 # This function retrieve the raw file in the working directory |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
355 # - if zipfile: unzip the file with its directory tree |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
356 # - if singlefiles: set symlink with the good filename |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
357 retrieveRawfileInTheWorkingDir <- function(singlefile, zipfile) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
358 if (!is.null(singlefile) && (length("singlefile") > 0)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
359 for (singlefile_sampleName in names(singlefile)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
360 singlefile_galaxyPath <- singlefile[[singlefile_sampleName]] |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
361 if (!file.exists(singlefile_galaxyPath)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
362 error_message <- paste("Cannot access the sample:", singlefile_sampleName, "located:", singlefile_galaxyPath, ". Please, contact your administrator ... if you have one!") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
363 print(error_message) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
364 stop(error_message) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
365 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
366 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
367 file.symlink(singlefile_galaxyPath, singlefile_sampleName) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
368 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
369 directory <- "." |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
370 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
371 if (!is.null(zipfile) && (zipfile != "")) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
372 if (!file.exists(zipfile)) { |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
373 error_message <- paste("Cannot access the Zip file:", zipfile, ". Please, contact your administrator ... if you have one!") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
374 print(error_message) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
375 stop(error_message) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
376 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
377 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
378 # unzip |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
379 suppressWarnings(unzip(zipfile, unzip = "unzip")) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
380 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
381 # get the directory name |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
382 filesInZip <- unzip(zipfile, list = TRUE) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
383 directories <- unique(unlist(lapply(strsplit(filesInZip$Name, "/"), function(x) x[1]))) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
384 directories <- directories[!(directories %in% c("__MACOSX")) & file.info(directories)$isdir] |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
385 directory <- "." |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
386 if (length(directories) == 1) directory <- directories |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
387 |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
388 cat("files_root_directory\t", directory, "\n") |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
389 } |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
390 return(directory) |
cb57be5de070
planemo upload commit 24d44ee26b7c23380c2b42fae2f7f6e58472100d
workflow4metabolomics
parents:
diff
changeset
|
391 } |