Mercurial > repos > lecorguille > xcms_fillpeaks
annotate lib.r @ 20:02bb34af0921 draft
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
| author | lecorguille | 
|---|---|
| date | Wed, 08 Feb 2017 06:36:24 -0500 | 
| parents | 7b74ec867ad2 | 
| children | 7e289788d37d | 
| rev | line source | 
|---|---|
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 1 #Authors ABiMS TEAM | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 2 #Lib.r for Galaxy Workflow4Metabolomics xcms tools | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 3 # | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 4 #version 2.4: lecorguille | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 5 # add getPeaklistW4M | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 6 #version 2.3: yguitton | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 7 # correction for empty PDF when only 1 class | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 8 #version 2.2 | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 9 # correct bug in Base Peak Chromatogram (BPC) option, not only TIC when scanrange used in xcmsSet | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 10 # Note if scanrange is used a warning is prompted in R console but do not stop PDF generation | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 11 #version 2.1: yguitton | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 12 # Modifications made by Guitton Yann | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 13 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 14 | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 15 #@author G. Le Corguille | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 16 #This function convert if it is required the Retention Time in minutes | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 17 RTSecondToMinute <- function(variableMetadata, convertRTMinute) { | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 18 if (convertRTMinute){ | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 19 #converting the retention times (seconds) into minutes | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 20 print("converting the retention times into minutes in the variableMetadata") | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 21 variableMetadata[,"rt"]=variableMetadata[,"rt"]/60 | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 22 variableMetadata[,"rtmin"]=variableMetadata[,"rtmin"]/60 | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 23 variableMetadata[,"rtmax"]=variableMetadata[,"rtmax"]/60 | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 24 } | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 25 return (variableMetadata) | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 26 } | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 27 | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 28 #@author G. Le Corguille | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 29 #This function format ions identifiers | 
| 20 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 30 formatIonIdentifiers <- function(variableMetadata, numDigitsRT=0, numDigitsMZ=0) { | 
| 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 31 splitDeco = strsplit(as.character(variableMetadata$name),"_") | 
| 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 32 idsDeco = sapply(splitDeco, function(x) { deco=unlist(x)[2]; if (is.na(deco)) return ("") else return(paste0("_",deco)) }) | 
| 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 33 namecustom = make.unique(paste0("M",round(variableMetadata[,"mz"],numDigitsMZ),"T",round(variableMetadata[,"rt"],numDigitsRT),idsDeco)) | 
| 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 34 variableMetadata=cbind(name=variableMetadata$name, namecustom=namecustom, variableMetadata[,!(colnames(variableMetadata) %in% c("name"))]) | 
| 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 35 return(variableMetadata) | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 36 } | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 37 | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 38 #@author G. Le Corguille | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 39 # value: intensity values to be used into, maxo or intb | 
| 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 40 getPeaklistW4M <- function(xset, intval="into",convertRTMinute=F,numDigitsMZ=4,numDigitsRT=0,variableMetadataOutput,dataMatrixOutput) { | 
| 20 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 41 variableMetadata_dataMatrix = peakTable(xset, method="medret", value=intval) | 
| 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 42 variableMetadata_dataMatrix = cbind(name=groupnames(xset),variableMetadata_dataMatrix) | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 43 | 
| 20 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 44 dataMatrix = variableMetadata_dataMatrix[,(make.names(colnames(variableMetadata_dataMatrix)) %in% c("name", make.names(sampnames(xset))))] | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 45 | 
| 20 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 46 variableMetadata = variableMetadata_dataMatrix[,!(make.names(colnames(variableMetadata_dataMatrix)) %in% c(make.names(sampnames(xset))))] | 
| 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 47 variableMetadata = RTSecondToMinute(variableMetadata, convertRTMinute) | 
| 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 48 variableMetadata = formatIonIdentifiers(variableMetadata, numDigitsRT=numDigitsRT, numDigitsMZ=numDigitsMZ) | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 49 | 
| 20 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 50 write.table(variableMetadata, file=variableMetadataOutput,sep="\t",quote=F,row.names=F) | 
| 
02bb34af0921
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 481448087f0e09c131b24f7d552db69f3552d371-dirty
 lecorguille parents: 
19diff
changeset | 51 write.table(dataMatrix, file=dataMatrixOutput,sep="\t",quote=F,row.names=F) | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 52 } | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 53 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 54 #@author Y. Guitton | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 55 getBPC <- function(file,rtcor=NULL, ...) { | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 56 object <- xcmsRaw(file) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 57 sel <- profRange(object, ...) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 58 cbind(if (is.null(rtcor)) object@scantime[sel$scanidx] else rtcor ,xcms:::colMax(object@env$profile[sel$massidx,sel$scanidx,drop=FALSE])) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 59 #plotChrom(xcmsRaw(file), base=T) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 60 } | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 61 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 62 #@author Y. Guitton | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 63 getBPCs <- function (xcmsSet=NULL, pdfname="BPCs.pdf",rt=c("raw","corrected"), scanrange=NULL) { | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 64 cat("Creating BIC pdf...\n") | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 65 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 66 if (is.null(xcmsSet)) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 67 cat("Enter an xcmsSet \n") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 68 stop() | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 69 } else { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 70 files <- filepaths(xcmsSet) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 71 } | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 72 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 73 phenoDataClass<-as.vector(levels(xcmsSet@phenoData[,1])) #sometime phenoData have more than 1 column use first as class | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 74 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 75 classnames<-vector("list",length(phenoDataClass)) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 76 for (i in 1:length(phenoDataClass)){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 77 classnames[[i]]<-which( xcmsSet@phenoData[,1]==phenoDataClass[i]) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 78 } | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 79 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 80 N <- dim(phenoData(xcmsSet))[1] | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 81 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 82 TIC <- vector("list",N) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 83 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 84 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 85 for (j in 1:N) { | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 86 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 87 TIC[[j]] <- getBPC(files[j]) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 88 #good for raw | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 89 # seems strange for corrected | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 90 #errors if scanrange used in xcmsSetgeneration | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 91 if (!is.null(xcmsSet) && rt == "corrected") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 92 rtcor <- xcmsSet@rt$corrected[[j]] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 93 else | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 94 rtcor <- NULL | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 95 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 96 TIC[[j]] <- getBPC(files[j],rtcor=rtcor) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 97 # TIC[[j]][,1]<-rtcor | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 98 } | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 99 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 100 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 101 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 102 pdf(pdfname,w=16,h=10) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 103 cols <- rainbow(N) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 104 lty = 1:N | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 105 pch = 1:N | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 106 #search for max x and max y in BPCs | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 107 xlim = range(sapply(TIC, function(x) range(x[,1]))) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 108 ylim = range(sapply(TIC, function(x) range(x[,2]))) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 109 ylim = c(-ylim[2], ylim[2]) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 110 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 111 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 112 ##plot start | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 113 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 114 if (length(phenoDataClass)>2){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 115 for (k in 1:(length(phenoDataClass)-1)){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 116 for (l in (k+1):length(phenoDataClass)){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 117 #print(paste(phenoDataClass[k],"vs",phenoDataClass[l],sep=" ")) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 118 plot(0, 0, type="n", xlim = xlim/60, ylim = ylim, main = paste("Base Peak Chromatograms \n","BPCs_",phenoDataClass[k]," vs ",phenoDataClass[l], sep=""), xlab = "Retention Time (min)", ylab = "BPC") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 119 colvect<-NULL | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 120 for (j in 1:length(classnames[[k]])) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 121 tic <- TIC[[classnames[[k]][j]]] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 122 # points(tic[,1]/60, tic[,2], col = cols[i], pch = pch[i], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 123 points(tic[,1]/60, tic[,2], col = cols[classnames[[k]][j]], pch = pch[classnames[[k]][j]], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 124 colvect<-append(colvect,cols[classnames[[k]][j]]) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 125 } | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 126 for (j in 1:length(classnames[[l]])) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 127 # i=class2names[j] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 128 tic <- TIC[[classnames[[l]][j]]] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 129 points(tic[,1]/60, -tic[,2], col = cols[classnames[[l]][j]], pch = pch[classnames[[l]][j]], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 130 colvect<-append(colvect,cols[classnames[[l]][j]]) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 131 } | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 132 legend("topright",paste(basename(files[c(classnames[[k]],classnames[[l]])])), col = colvect, lty = lty, pch = pch) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 133 } | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 134 } | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 135 }#end if length >2 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 136 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 137 if (length(phenoDataClass)==2){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 138 k=1 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 139 l=2 | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 140 colvect<-NULL | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 141 plot(0, 0, type="n", xlim = xlim/60, ylim = ylim, main = paste("Base Peak Chromatograms \n","BPCs_",phenoDataClass[k],"vs",phenoDataClass[l], sep=""), xlab = "Retention Time (min)", ylab = "BPC") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 142 | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 143 for (j in 1:length(classnames[[k]])) { | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 144 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 145 tic <- TIC[[classnames[[k]][j]]] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 146 # points(tic[,1]/60, tic[,2], col = cols[i], pch = pch[i], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 147 points(tic[,1]/60, tic[,2], col = cols[classnames[[k]][j]], pch = pch[classnames[[k]][j]], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 148 colvect<-append(colvect,cols[classnames[[k]][j]]) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 149 } | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 150 for (j in 1:length(classnames[[l]])) { | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 151 # i=class2names[j] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 152 tic <- TIC[[classnames[[l]][j]]] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 153 points(tic[,1]/60, -tic[,2], col = cols[classnames[[l]][j]], pch = pch[classnames[[l]][j]], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 154 colvect<-append(colvect,cols[classnames[[l]][j]]) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 155 } | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 156 legend("topright",paste(basename(files[c(classnames[[k]],classnames[[l]])])), col = colvect, lty = lty, pch = pch) | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 157 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 158 }#end length ==2 | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 159 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 160 #case where only one class | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 161 if (length(phenoDataClass)==1){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 162 k=1 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 163 ylim = range(sapply(TIC, function(x) range(x[,2]))) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 164 colvect<-NULL | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 165 plot(0, 0, type="n", xlim = xlim/60, ylim = ylim, main = paste("Base Peak Chromatograms \n","BPCs_",phenoDataClass[k], sep=""), xlab = "Retention Time (min)", ylab = "BPC") | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 166 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 167 for (j in 1:length(classnames[[k]])) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 168 tic <- TIC[[classnames[[k]][j]]] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 169 # points(tic[,1]/60, tic[,2], col = cols[i], pch = pch[i], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 170 points(tic[,1]/60, tic[,2], col = cols[classnames[[k]][j]], pch = pch[classnames[[k]][j]], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 171 colvect<-append(colvect,cols[classnames[[k]][j]]) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 172 } | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 173 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 174 legend("topright",paste(basename(files[c(classnames[[k]])])), col = colvect, lty = lty, pch = pch) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 175 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 176 }#end length ==1 | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 177 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 178 dev.off() #pdf(pdfname,w=16,h=10) | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 179 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 180 invisible(TIC) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 181 } | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 182 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 183 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 184 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 185 #@author Y. Guitton | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 186 getTIC <- function(file,rtcor=NULL) { | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 187 object <- xcmsRaw(file) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 188 cbind(if (is.null(rtcor)) object@scantime else rtcor, rawEIC(object,mzrange=range(object@env$mz))$intensity) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 189 } | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 190 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 191 ## | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 192 ## overlay TIC from all files in current folder or from xcmsSet, create pdf | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 193 ## | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 194 #@author Y. Guitton | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 195 getTICs <- function(xcmsSet=NULL,files=NULL, pdfname="TICs.pdf",rt=c("raw","corrected")) { | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 196 cat("Creating TIC pdf...\n") | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 197 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 198 if (is.null(xcmsSet)) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 199 filepattern <- c("[Cc][Dd][Ff]", "[Nn][Cc]", "([Mm][Zz])?[Xx][Mm][Ll]", "[Mm][Zz][Dd][Aa][Tt][Aa]", "[Mm][Zz][Mm][Ll]") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 200 filepattern <- paste(paste("\\.", filepattern, "$", sep = ""), collapse = "|") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 201 if (is.null(files)) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 202 files <- getwd() | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 203 info <- file.info(files) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 204 listed <- list.files(files[info$isdir], pattern = filepattern, recursive = TRUE, full.names = TRUE) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 205 files <- c(files[!info$isdir], listed) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 206 } else { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 207 files <- filepaths(xcmsSet) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 208 } | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 209 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 210 phenoDataClass<-as.vector(levels(xcmsSet@phenoData[,1])) #sometime phenoData have more than 1 column use first as class | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 211 classnames<-vector("list",length(phenoDataClass)) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 212 for (i in 1:length(phenoDataClass)){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 213 classnames[[i]]<-which( xcmsSet@phenoData[,1]==phenoDataClass[i]) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 214 } | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 215 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 216 N <- length(files) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 217 TIC <- vector("list",N) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 218 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 219 for (i in 1:N) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 220 if (!is.null(xcmsSet) && rt == "corrected") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 221 rtcor <- xcmsSet@rt$corrected[[i]] else | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 222 rtcor <- NULL | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 223 TIC[[i]] <- getTIC(files[i],rtcor=rtcor) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 224 } | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 225 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 226 pdf(pdfname,w=16,h=10) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 227 cols <- rainbow(N) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 228 lty = 1:N | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 229 pch = 1:N | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 230 #search for max x and max y in TICs | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 231 xlim = range(sapply(TIC, function(x) range(x[,1]))) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 232 ylim = range(sapply(TIC, function(x) range(x[,2]))) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 233 ylim = c(-ylim[2], ylim[2]) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 234 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 235 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 236 ##plot start | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 237 if (length(phenoDataClass)>2){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 238 for (k in 1:(length(phenoDataClass)-1)){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 239 for (l in (k+1):length(phenoDataClass)){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 240 #print(paste(phenoDataClass[k],"vs",phenoDataClass[l],sep=" ")) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 241 plot(0, 0, type="n", xlim = xlim/60, ylim = ylim, main = paste("Total Ion Chromatograms \n","TICs_",phenoDataClass[k]," vs ",phenoDataClass[l], sep=""), xlab = "Retention Time (min)", ylab = "TIC") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 242 colvect<-NULL | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 243 for (j in 1:length(classnames[[k]])) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 244 tic <- TIC[[classnames[[k]][j]]] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 245 # points(tic[,1]/60, tic[,2], col = cols[i], pch = pch[i], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 246 points(tic[,1]/60, tic[,2], col = cols[classnames[[k]][j]], pch = pch[classnames[[k]][j]], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 247 colvect<-append(colvect,cols[classnames[[k]][j]]) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 248 } | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 249 for (j in 1:length(classnames[[l]])) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 250 # i=class2names[j] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 251 tic <- TIC[[classnames[[l]][j]]] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 252 points(tic[,1]/60, -tic[,2], col = cols[classnames[[l]][j]], pch = pch[classnames[[l]][j]], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 253 colvect<-append(colvect,cols[classnames[[l]][j]]) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 254 } | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 255 legend("topright",paste(basename(files[c(classnames[[k]],classnames[[l]])])), col = colvect, lty = lty, pch = pch) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 256 } | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 257 } | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 258 }#end if length >2 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 259 if (length(phenoDataClass)==2){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 260 k=1 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 261 l=2 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 262 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 263 plot(0, 0, type="n", xlim = xlim/60, ylim = ylim, main = paste("Total Ion Chromatograms \n","TICs_",phenoDataClass[k],"vs",phenoDataClass[l], sep=""), xlab = "Retention Time (min)", ylab = "TIC") | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 264 colvect<-NULL | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 265 for (j in 1:length(classnames[[k]])) { | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 266 tic <- TIC[[classnames[[k]][j]]] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 267 # points(tic[,1]/60, tic[,2], col = cols[i], pch = pch[i], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 268 points(tic[,1]/60, tic[,2], col = cols[classnames[[k]][j]], pch = pch[classnames[[k]][j]], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 269 colvect<-append(colvect,cols[classnames[[k]][j]]) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 270 } | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 271 for (j in 1:length(classnames[[l]])) { | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 272 # i=class2names[j] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 273 tic <- TIC[[classnames[[l]][j]]] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 274 points(tic[,1]/60, -tic[,2], col = cols[classnames[[l]][j]], pch = pch[classnames[[l]][j]], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 275 colvect<-append(colvect,cols[classnames[[l]][j]]) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 276 } | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 277 legend("topright",paste(basename(files[c(classnames[[k]],classnames[[l]])])), col = colvect, lty = lty, pch = pch) | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 278 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 279 }#end length ==2 | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 280 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 281 #case where only one class | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 282 if (length(phenoDataClass)==1){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 283 k=1 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 284 ylim = range(sapply(TIC, function(x) range(x[,2]))) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 285 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 286 plot(0, 0, type="n", xlim = xlim/60, ylim = ylim, main = paste("Total Ion Chromatograms \n","TICs_",phenoDataClass[k], sep=""), xlab = "Retention Time (min)", ylab = "TIC") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 287 colvect<-NULL | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 288 for (j in 1:length(classnames[[k]])) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 289 tic <- TIC[[classnames[[k]][j]]] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 290 # points(tic[,1]/60, tic[,2], col = cols[i], pch = pch[i], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 291 points(tic[,1]/60, tic[,2], col = cols[classnames[[k]][j]], pch = pch[classnames[[k]][j]], type="l") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 292 colvect<-append(colvect,cols[classnames[[k]][j]]) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 293 } | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 294 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 295 legend("topright",paste(basename(files[c(classnames[[k]])])), col = colvect, lty = lty, pch = pch) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 296 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 297 }#end length ==1 | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 298 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 299 dev.off() #pdf(pdfname,w=16,h=10) | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 300 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 301 invisible(TIC) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 302 } | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 303 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 304 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 305 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 306 ## | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 307 ## Get the polarities from all the samples of a condition | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 308 #@author Misharl Monsoor misharl.monsoor@sb-roscoff.fr ABiMS TEAM | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 309 #@author Gildas Le Corguille lecorguille@sb-roscoff.fr ABiMS TEAM | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 310 getSampleMetadata <- function(xcmsSet=NULL, sampleMetadataOutput="sampleMetadata.tsv") { | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 311 cat("Creating the sampleMetadata file...\n") | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 312 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 313 #Create the sampleMetada dataframe | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 314 sampleMetadata=xset@phenoData | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 315 sampleNamesOrigin=rownames(sampleMetadata) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 316 sampleNamesMakeNames=make.names(sampleNamesOrigin) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 317 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 318 if (any(duplicated(sampleNamesMakeNames))) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 319 write("\n\nERROR: Usually, R has trouble to deal with special characters in its column names, so it rename them using make.names().\nIn your case, at least two columns after the renaming obtain the same name, thus XCMS will collapse those columns per name.", stderr()) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 320 for (sampleName in sampleNamesOrigin) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 321 write(paste(sampleName,"\t->\t",make.names(sampleName)),stderr()) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 322 } | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 323 stop("\n\nERROR: One or more of your files will not be import by xcmsSet. It may due to bad characters in their filenames.") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 324 } | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 325 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 326 if (!all(sampleNamesOrigin == sampleNamesMakeNames)) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 327 cat("\n\nWARNING: Usually, R has trouble to deal with special characters in its column names, so it rename them using make.names()\nIn your case, one or more sample names will be renamed in the sampleMetadata and dataMatrix files:\n") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 328 for (sampleName in sampleNamesOrigin) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 329 cat(paste(sampleName,"\t->\t",make.names(sampleName),"\n")) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 330 } | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 331 } | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 332 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 333 sampleMetadata$sampleMetadata=sampleNamesMakeNames | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 334 sampleMetadata=cbind(sampleMetadata["sampleMetadata"],sampleMetadata["class"]) #Reorder columns | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 335 rownames(sampleMetadata)=NULL | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 336 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 337 #Create a list of files name in the current directory | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 338 list_files=xset@filepaths | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 339 #For each sample file, the following actions are done | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 340 for (file in list_files){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 341 #Check if the file is in the CDF format | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 342 if (!mzR:::netCDFIsFile(file)){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 343 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 344 # If the column isn't exist, with add one filled with NA | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 345 if (is.null(sampleMetadata$polarity)) sampleMetadata$polarity=NA | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 346 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 347 #Create a simple xcmsRaw object for each sample | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 348 xcmsRaw=xcmsRaw(file) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 349 #Extract the polarity (a list of polarities) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 350 polarity=xcmsRaw@polarity | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 351 #Verify if all the scans have the same polarity | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 352 uniq_list=unique(polarity) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 353 if (length(uniq_list)>1){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 354 polarity="mixed" | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 355 } else { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 356 polarity=as.character(uniq_list) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 357 } | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 358 #Transforms the character to obtain only the sample name | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 359 filename=basename(file) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 360 library(tools) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 361 samplename=file_path_sans_ext(filename) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 362 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 363 #Set the polarity attribute | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 364 sampleMetadata$polarity[sampleMetadata$sampleMetadata==samplename]=polarity | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 365 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 366 #Delete xcmsRaw object because it creates a bug for the fillpeaks step | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 367 rm(xcmsRaw) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 368 } | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 369 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 370 } | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 371 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 372 write.table(sampleMetadata, sep="\t", quote=FALSE, row.names=FALSE, file=sampleMetadataOutput) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 373 | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 374 return(list("sampleNamesOrigin"=sampleNamesOrigin,"sampleNamesMakeNames"=sampleNamesMakeNames)) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 375 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 376 } | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 377 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 378 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 379 ## | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 380 ## This function check if xcms will found all the files | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 381 ## | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 382 #@author Gildas Le Corguille lecorguille@sb-roscoff.fr ABiMS TEAM | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 383 checkFilesCompatibilityWithXcms <- function(directory) { | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 384 cat("Checking files filenames compatibilities with xmcs...\n") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 385 # WHAT XCMS WILL FIND | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 386 filepattern <- c("[Cc][Dd][Ff]", "[Nn][Cc]", "([Mm][Zz])?[Xx][Mm][Ll]","[Mm][Zz][Dd][Aa][Tt][Aa]", "[Mm][Zz][Mm][Ll]") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 387 filepattern <- paste(paste("\\.", filepattern, "$", sep = ""),collapse = "|") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 388 info <- file.info(directory) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 389 listed <- list.files(directory[info$isdir], pattern = filepattern,recursive = TRUE, full.names = TRUE) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 390 files <- c(directory[!info$isdir], listed) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 391 files_abs <- file.path(getwd(), files) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 392 exists <- file.exists(files_abs) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 393 files[exists] <- files_abs[exists] | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 394 files[exists] <- sub("//","/",files[exists]) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 395 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 396 # WHAT IS ON THE FILESYSTEM | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 397 filesystem_filepaths=system(paste("find $PWD/",directory," -not -name '\\.*' -not -path '*conda-env*' -type f -name \"*\"", sep=""), intern=T) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 398 filesystem_filepaths=filesystem_filepaths[grep(filepattern, filesystem_filepaths, perl=T)] | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 399 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 400 # COMPARISON | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 401 if (!is.na(table(filesystem_filepaths %in% files)["FALSE"])) { | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 402 write("\n\nERROR: List of the files which will not be imported by xcmsSet",stderr()) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 403 write(filesystem_filepaths[!(filesystem_filepaths %in% files)],stderr()) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 404 stop("\n\nERROR: One or more of your files will not be import by xcmsSet. It may due to bad characters in their filenames.") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 405 } | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 406 } | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 407 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 408 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 409 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 410 ## | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 411 ## This function check if XML contains special caracters. It also checks integrity and completness. | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 412 ## | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 413 #@author Misharl Monsoor misharl.monsoor@sb-roscoff.fr ABiMS TEAM | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 414 checkXmlStructure <- function (directory) { | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 415 cat("Checking XML structure...\n") | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 416 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 417 cmd=paste("IFS=$'\n'; for xml in $(find",directory,"-not -name '\\.*' -not -path '*conda-env*' -type f -iname '*.*ml*'); do if [ $(xmllint --nonet --noout \"$xml\" 2> /dev/null; echo $?) -gt 0 ]; then echo $xml;fi; done;") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 418 capture=system(cmd,intern=TRUE) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 419 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 420 if (length(capture)>0){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 421 #message=paste("The following mzXML or mzML file is incorrect, please check these files first:",capture) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 422 write("\n\nERROR: The following mzXML or mzML file(s) are incorrect, please check these files first:", stderr()) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 423 write(capture, stderr()) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 424 stop("ERROR: xcmsSet cannot continue with incorrect mzXML or mzML files") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 425 } | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 426 | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 427 } | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 428 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 429 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 430 ## | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 431 ## This function check if XML contain special characters | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 432 ## | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 433 #@author Misharl Monsoor misharl.monsoor@sb-roscoff.fr ABiMS TEAM | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 434 deleteXmlBadCharacters<- function (directory) { | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 435 cat("Checking Non ASCII characters in the XML...\n") | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 436 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 437 processed=F | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 438 l=system( paste("find",directory, "-not -name '\\.*' -not -path '*conda-env*' -type f -iname '*.*ml*'"),intern=TRUE) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 439 for (i in l){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 440 cmd=paste("LC_ALL=C grep '[^ -~]' \"",i,"\"",sep="") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 441 capture=suppressWarnings(system(cmd,intern=TRUE)) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 442 if (length(capture)>0){ | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 443 cmd=paste("perl -i -pe 's/[^[:ascii:]]//g;'",i) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 444 print( paste("WARNING: Non ASCII characters have been removed from the ",i,"file") ) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 445 c=system(cmd,intern=TRUE) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 446 capture="" | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 447 processed=T | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 448 } | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 449 } | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 450 if (processed) cat("\n\n") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 451 return(processed) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 452 } | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 453 | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 454 | 
| 15 
1c78d61fd646
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 08e7f269a5c59687a7768be8db5fcb4e4d736093
 lecorguille parents: 
14diff
changeset | 455 ## | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 456 ## This function will compute MD5 checksum to check the data integrity | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 457 ## | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 458 #@author Gildas Le Corguille lecorguille@sb-roscoff.fr | 
| 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 459 getMd5sum <- function (directory) { | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 460 cat("Compute md5 checksum...\n") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 461 # WHAT XCMS WILL FIND | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 462 filepattern <- c("[Cc][Dd][Ff]", "[Nn][Cc]", "([Mm][Zz])?[Xx][Mm][Ll]","[Mm][Zz][Dd][Aa][Tt][Aa]", "[Mm][Zz][Mm][Ll]") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 463 filepattern <- paste(paste("\\.", filepattern, "$", sep = ""),collapse = "|") | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 464 info <- file.info(directory) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 465 listed <- list.files(directory[info$isdir], pattern = filepattern,recursive = TRUE, full.names = TRUE) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 466 files <- c(directory[!info$isdir], listed) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 467 exists <- file.exists(files) | 
| 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 468 files <- files[exists] | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 469 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 470 library(tools) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 471 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 472 #cat("\n\n") | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 473 | 
| 16 
5f61570177e2
planemo upload for repository https://github.com/workflow4metabolomics/xcms commit 22c4e92909198328fc7439ff47e4546a273eb907
 lecorguille parents: 
15diff
changeset | 474 return(as.matrix(md5sum(files))) | 
| 6 
f00e39a4b0fb
planemo upload commit a3229faad6949bbca965d1d7e138cb3c0550780e
 lecorguille parents: diff
changeset | 475 } | 
