Mercurial > repos > lecorguille > xcms_report
changeset 11:467dc9b12da5 draft
Uploaded
| author | lecorguille | 
|---|---|
| date | Tue, 19 Jan 2016 15:58:04 -0500 | 
| parents | 753cde95b6a8 | 
| children | f117dbd84303 | 
| files | xcms_report.r | 
| diffstat | 1 files changed, 132 insertions(+), 0 deletions(-) [+] | 
line wrap: on
 line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/xcms_report.r Tue Jan 19 15:58:04 2016 -0500 @@ -0,0 +1,132 @@ +#!/usr/local/public/bin/Rscript --vanilla --slave --no-site-file +# version="0.1.0" +#@author Gildas Le Corguille lecorguille@sb-roscoff.fr ABIMS TEAM + + + +# ----- ARGUMENTS BLACKLIST ----- +#xcms.r +argBlacklist=c("zipfile","xfunction","xsetRdataOutput","sampleMetadataOutput","ticspdf","bicspdf","rplotspdf") +#CAMERA.r +argBlacklist=c(argBlacklist,"dataMatrixOutput","variableMetadataOutput","new_file_path") + +# ----- PACKAGE ----- + +pkgs=c("parallel","BiocGenerics", "Biobase", "Rcpp", "mzR", "xcms","snow","batch") +for(pkg in pkgs) { + suppressPackageStartupMessages( stopifnot( library(pkg, quietly=TRUE, logical.return=TRUE, character.only=TRUE))) +} + + +# ----- FUNCTION ----- +writehtml = function(...) { cat(...,"\n", file=htmlOutput,append = TRUE,sep="") } + + +# ----- ARGUMENTS ----- + +listArguments = parseCommandArgs(evaluate=FALSE) #interpretation of arguments given in command line as an R list of objects + + +# ----- ARGUMENTS PROCESSING ----- + +#image is an .RData file necessary to use xset variable given by previous tools +load(listArguments[["image"]]); + +htmlOutput = "report.html" +if (!is.null(listArguments[["htmlOutput"]])){ + htmlOutput = listArguments[["htmlOutput"]]; +} + +user_email = NULL +if (!is.null(listArguments[["user_email"]])){ + user_email = listArguments[["user_email"]]; +} + + +# ----- MAIN PROCESSING INFO ----- +writehtml("<!DOCTYPE html>") +writehtml("<HTML lang='en'>") + +writehtml("<HEAD>") + writehtml("<meta http-equiv='Content-Type' content='text/html; charset=UTF-8' />") + + writehtml("<title>[W4M] XCMS analysis report</title>") + + writehtml("<style>") + writehtml("table { min-width: 500px; border:1px solid #D6B161; border-collapse:collapse;}") + writehtml("th { background: #898989; text-align:left;}") + writehtml("tr { border: 1px solid #000000 }") + writehtml("h2 { color: #FFA212; }") + writehtml("ul li { margin-bottom:10px; }") + writehtml("</style>") +writehtml("</HEAD>") + +writehtml("<BODY>") + writehtml("<h1>___ XCMS analysis report using Workflow4Metabolomics ___</h1>") + # to pass the planemo shed_test + if (user_email != "test@bx.psu.edu") { + if (!is.null(user_email)) writehtml("By: ",user_email," - ") + writehtml("Date: ",format(Sys.time(), "%y%m%d-%H:%M:%S")) + } + + + writehtml("<h2>Samples used:</h2>") + writehtml("<table") + writehtml("<tr><th>sample</th><th>filename</th></tr>") + writehtml(paste("<tr><td>",sampnames(xset),"</td><td>",xset@filepaths,"</td></tr>")) + writehtml("</table>") + + writehtml("<h2>Function launched:</h2>") + writehtml("<table>") + writehtml("<tr><th>timestamp<br />(ymd-h:m:s)</th><th>function</th><th>argument</th><th>value</th></tr>") + for(tool in names(listOFlistArguments)) { + listOFlistArgumentsDisplay=listOFlistArguments[[tool]][!(names(listOFlistArguments[[tool]]) %in% argBlacklist)] + + timestamp = strsplit(tool,"_")[[1]][1] + xcmsFunction = strsplit(tool,"_")[[1]][2] + writehtml("<tr><td rowspan='",length(listOFlistArgumentsDisplay),"'>",timestamp,"</td><td rowspan='",length(listOFlistArgumentsDisplay),"'>",xcmsFunction,"</td>") + line_begin="" + for (arg in names(listOFlistArgumentsDisplay)) { + writehtml(line_begin,"<td>",arg,"</td><td>",unlist(listOFlistArgumentsDisplay[arg][1]),"</td></tr>") + line_begin="<tr>" + } + } + writehtml("</table>") + + writehtml("<h2>Information about the xcmsSet object:</h2>") + + log_file=file(htmlOutput, open = "at") + writehtml("<pre>") + sink(log_file) + sink(log_file, type = "output") + xset + sink() + writehtml("</pre>") + + writehtml("<h2>Citations:</h2>") + writehtml("<ul>") + writehtml("<li>To cite the <b>XCMS</b> package in publications use:") + writehtml("<ul>") + writehtml("<li>","Smith, C.A. and Want, E.J. and O'Maille, G. and Abagyan,R. and Siuzdak, G.XCMS: Processing mass spectrometry data for metabolite profiling using nonlinear peak alignment, matching and identification, Analytical Chemistry, 78:779-787 (2006)","</li>") + writehtml("<li>","Ralf Tautenhahn, Christoph Boettcher, Steffen Neumann: Highly sensitive feature detection for high resolution LC/MS BMC Bioinformatics, 9:504 (2008)","</li>") + writehtml("<li>","H. Paul Benton, Elizabeth J. Want and Timothy M. D. Ebbels Correction of mass calibration gaps in liquid chromatography-mass spectrometry metabolomics data Bioinformatics, 26:2488 (2010)","</li>") + writehtml("</ul>") + writehtml("</li>") + + writehtml("<li>To cite the <b>CAMERA</b> package in publications use:") + writehtml("<ul>") + writehtml("<li>","Kuhl, C., Tautenhahn, R., Boettcher, C., Larson, T. R. and Neumann,S. CAMERA: an integrated strategy for compound spectra extraction and annotation of liquid chromatography/mass spectrometry data sets. Analytical Chemistry, 84:283-289 (2012)","</li>") + writehtml("</ul>") + writehtml("</li>") + + writehtml("<li>To cite the <b>Workflow4Metabolimics (W4M)</b> project in publications use:") + writehtml("<ul>") + writehtml("<li>","Franck Giacomoni, Gildas Le Corguillé, Misharl Monsoor, Marion Landi, Pierre Pericard, Mélanie Pétéra, Christophe Duperier, Marie Tremblay-Franco, Jean-François Martin, Daniel Jacob, Sophie Goulitquer, Etienne A. Thévenot and Christophe Caron (2014). Workflow4Metabolomics: A collaborative research infrastructure for computational metabolomics. Bioinformatics doi:10.1093/bioinformatics/btu813","</li>") + writehtml("</ul>") + writehtml("</li>") + writehtml("</ul>") + +writehtml("</BODY>") + +writehtml("</HTML>") +
