view msi_classification.xml @ 0:f0b415eb3bcf draft default tip

planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/msi_classification commit 8087490eb4dcaf4ead0f03eae4126780d21e5503
author galaxyp
date Fri, 06 Jul 2018 14:12:51 -0400 (2018-07-06)
parents
children
line wrap: on
line source
<tool id="mass_spectrometry_imaging_classification" name="MSI classification" version="1.10.0.0">
    <description>spatial classification of mass spectrometry imaging data</description>
    <requirements>
        <requirement type="package" version="1.10.0">bioconductor-cardinal</requirement>
        <requirement type="package" version="2.2.1">r-gridextra</requirement>
        <requirement type="package" version="0.20-35">r-lattice</requirement>
        <requirement type="package" version="2.2.1">r-ggplot2</requirement>
    </requirements>
    <command detect_errors="exit_code">
    <![CDATA[

        #if $infile.ext == 'imzml'
            ln -s '${infile.extra_files_path}/imzml' infile.imzML &&
            ln -s '${infile.extra_files_path}/ibd' infile.ibd &&
        #elif $infile.ext == 'analyze75'
            ln -s '${infile.extra_files_path}/hdr' infile.hdr &&
            ln -s '${infile.extra_files_path}/img' infile.img &&
            ln -s '${infile.extra_files_path}/t2m' infile.t2m &&
        #else
            ln -s $infile infile.RData &&
        #end if
        cat '${MSI_segmentation}' &&
        echo ${MSI_segmentation} &&
        Rscript '${MSI_segmentation}'

    ]]>
    </command>
    <configfiles>
        <configfile name="MSI_segmentation"><![CDATA[


################################# load libraries and read file #########################

library(Cardinal)
library(gridExtra)
library(lattice)
library(ggplot2)


#if $infile.ext == 'imzml'
    #if str($processed_cond.processed_file) == "processed":
        msidata <- readImzML('infile', mass.accuracy=$processed_cond.accuracy, units.accuracy = "$processed_cond.units")
    #else
        msidata <- readImzML('infile')
    #end if
#elif $infile.ext == 'analyze75'
    msidata = readAnalyze('infile')
#else
    load('infile.RData')
#end if

## function to later read RData reference files in

loadRData <- function(fileName){
#loads an RData file, and returns it
load(fileName)
get(ls()[ls() != "fileName"])
}

## create full matrix to make processed imzML files compatible with classification
iData(msidata) <- iData(msidata)[] 

###################################### file properties in numbers ##############

## Number of features (mz)
maxfeatures = length(features(msidata))
## Range mz
minmz = round(min(mz(msidata)), digits=2)
maxmz = round(max(mz(msidata)), digits=2)
## Number of spectra (pixels)
pixelcount = length(pixels(msidata))
## Range x coordinates
minimumx = min(coord(msidata)[,1])
maximumx = max(coord(msidata)[,1])
## Range y coordinates
minimumy = min(coord(msidata)[,2])
maximumy = max(coord(msidata)[,2])
## Range of intensities
minint = round(min(spectra(msidata)[]), digits=2)
maxint = round(max(spectra(msidata)[]), digits=2)
medint = round(median(spectra(msidata)[]), digits=2)
## Number of intensities > 0
npeaks= sum(spectra(msidata)[]>0)
## Spectra multiplied with mz (potential number of peaks)
numpeaks = ncol(spectra(msidata)[])*nrow(spectra(msidata)[])
## Percentage of intensities > 0
percpeaks = round(npeaks/numpeaks*100, digits=2)
## Number of empty TICs
TICs = colSums(spectra(msidata)[]) 
NumemptyTIC = sum(TICs == 0)


## Processing informations
processinginfo = processingData(msidata)
centroidedinfo = processinginfo@centroided # TRUE or FALSE

## if TRUE write processinginfo if no write FALSE

## normalization
if (length(processinginfo@normalization) == 0) {
  normalizationinfo='FALSE'
} else {
  normalizationinfo=processinginfo@normalization
}
## smoothing
if (length(processinginfo@smoothing) == 0) {
  smoothinginfo='FALSE'
} else {
  smoothinginfo=processinginfo@smoothing
}
## baseline
if (length(processinginfo@baselineReduction) == 0) {
  baselinereductioninfo='FALSE'
} else {
  baselinereductioninfo=processinginfo@baselineReduction
}
## peak picking
if (length(processinginfo@peakPicking) == 0) {
  peakpickinginfo='FALSE'
} else {
  peakpickinginfo=processinginfo@peakPicking
}

#############################################################################

properties = c("Number of mz features",
               "Range of mz values",
               "Number of pixels", 
               "Range of x coordinates", 
               "Range of y coordinates",
               "Range of intensities", 
               "Median of intensities",
               "Intensities > 0",
               "Number of empty spectra",
               "Preprocessing", 
               "Normalization", 
               "Smoothing",
               "Baseline reduction",
               "Peak picking",
               "Centroided")

values = c(paste0(maxfeatures), 
           paste0(minmz, " - ", maxmz), 
           paste0(pixelcount), 
           paste0(minimumx, " - ", maximumx),  
           paste0(minimumy, " - ", maximumy), 
           paste0(minint, " - ", maxint), 
           paste0(medint),
           paste0(percpeaks, " %"), 
           paste0(NumemptyTIC), 
           paste0(" "),
           paste0(normalizationinfo),
           paste0(smoothinginfo),
           paste0(baselinereductioninfo),
           paste0(peakpickinginfo),
           paste0(centroidedinfo))

property_df = data.frame(properties, values)


######################################## PDF ###################################
################################################################################
################################################################################

Title = "Prediction"

#if str( $type_cond.type_method) == "training":
    #if str( $type_cond.method_cond.class_method) == "PLS":
        Title = "PLS"
    #elif str( $type_cond.method_cond.class_method) == "OPLS":
        Title = "OPLS"
    #elif str( $type_cond.method_cond.class_method) == "spatialShrunkenCentroids":
        Title = "SSC"
    #end if
#end if

pdf("classificationpdf.pdf", fonts = "Times", pointsize = 12)
plot(0,type='n',axes=FALSE,ann=FALSE)


title(main=paste0(Title," for file: \n\n", "$infile.display_name"))



##################### I) numbers and control plots #############################
###############################################################################

## table with values
grid.table(property_df, rows= NULL)

if (npeaks > 0){

opar <- par()
 
    ######################## II) Training #############################
    #############################################################################
    #if str( $type_cond.type_method) == "training":
        print("training")


        ## load y response (will be needed in every training scenario)

        #if str($type_cond.y_cond.y_vector) == "y_internal":
            y_vector = msidata\$$type_cond.y_cond.y_name
        #elif str($type_cond.y_cond.y_vector) == "y_external":
            y_tabular = read.delim("$type_cond.y_cond.y_data", header = FALSE, stringsAsFactors = FALSE)
            y_vector = as.factor(y_tabular[,$type_cond.y_cond.y_column])
            number_pixels = length(y_vector) ## should be same as in data
        #end if

    ## plot of y vector

    position_df = cbind(coord(msidata)[,1:2], y_vector)
    y_plot = ggplot(position_df, aes(x=x, y=y, fill=y_vector))+
           geom_tile() +
           coord_fixed()+
           ggtitle("Distribution of the response variable y")+
           theme_bw()+
           theme(text=element_text(family="ArialMT", face="bold", size=15))+
           theme(legend.position="bottom",legend.direction="vertical")+
           guides(fill=guide_legend(ncol=4,byrow=TRUE))
    coord_labels = aggregate(cbind(x,y)~y_vector, data=position_df, mean, na.rm=TRUE, na.action="na.pass")
    coord_labels\$file_number = gsub( "_.*$", "", coord_labels\$y_vector)
    print(y_plot)


        ######################## PLS #############################
        #if str( $type_cond.method_cond.class_method) == "PLS":
            print("PLS")

            ######################## PLS - CV #############################
            #if str( $type_cond.method_cond.analysis_cond.PLS_method) == "cvapply":
                print("PLS cv")

                ## folds
                #if str($type_cond.method_cond.analysis_cond.fold_cond.fold_vector) == "fold_internal":

                    fold_vector = msidata\$$type_cond.method_cond.analysis_cond.fold_cond.fold_name
                #elif str($type_cond.method_cond.analysis_cond.fold_cond.fold_vector) == "fold_external":
                    fold_tabular = read.delim("$type_cond.method_cond.analysis_cond.fold_cond.fold_data", header = FALSE, stringsAsFactors = FALSE)
                    fold_vector = as.factor(fold_tabular[,$type_cond.method_cond.analysis_cond.fold_cond.fold_column])
                    number_pixels = length(fold_vector) ## should be same as in data
                #end if

                ## plot of folds

                    position_df = cbind(coord(msidata)[,1:2], fold_vector)
                    fold_plot = ggplot(position_df, aes(x=x, y=y, fill=fold_vector))+
                           geom_tile() +
                           coord_fixed()+
                           ggtitle("Distribution of the fold variable")+
                           theme_bw()+
                           theme(text=element_text(family="ArialMT", face="bold", size=15))+
                           theme(legend.position="bottom",legend.direction="vertical")+
                           guides(fill=guide_legend(ncol=4,byrow=TRUE))
                    coord_labels = aggregate(cbind(x,y)~fold_vector, data=position_df, mean, na.rm=TRUE, na.action="na.pass")
                    coord_labels\$file_number = gsub( "_.*$", "", coord_labels\$fold_vector)
                    print(fold_plot)

                ## number of components
                components = c($type_cond.method_cond.analysis_cond.plscv_comp)

                ## PLS-cvApply:
                msidata.cv.pls <- cvApply(msidata, .y = y_vector, .fold = fold_vector, .fun = "PLS", ncomp = components)

                ## create table with summary
                count = 1
                summary_plscv = list()
                accuracy_vector = numeric()
                for (iteration in components){

                    summary_iteration = summary(msidata.cv.pls)\$accuracy[[paste0("ncomp = ", iteration)]]
                    summary_iteration = cbind(rownames(summary_iteration), summary_iteration) ## include rownames in table
                    accuracy_vector[count] = summary_iteration[1,2] ## vector with accuracies to find later maximum for plot
                    empty_row = c(paste0("ncomp = ", iteration), rep( "", length(levels(y_vector)))) ## add line with ncomp for each iteration
                    ##rownames(labeled_iteration)[1] = paste0("ncomp = ", iteration)
                    ##labeled_iteration = cbind(rownames(labeled_iteration), labeled_iteration)
                    labeled_iteration = rbind(empty_row, summary_iteration)

                    summary_plscv[[count]] = labeled_iteration
                    count = count+1} ## create list with summary table for each component
                ## create dataframe from list
                summary_plscv = do.call(rbind, summary_plscv) 
                summary_df = as.data.frame(summary_plscv)
                rownames(summary_df) = NULL

                ## plots
                ## plot to find ncomp with highest accuracy
                plot(summary(msidata.cv.pls), main="Accuracy of PLS classification")
                ncomp_max = components[which.max(accuracy_vector)] ## find ncomp with max. accuracy
                ## one image for each sample/fold, 4 images per page
                image(msidata.cv.pls, model = list(ncomp = ncomp_max), layout = c(2, 2))

                par(opar)   
                ## print table with summary in pdf
                plot(0,type='n',axes=FALSE,ann=FALSE)
                title(main="Summary for the different components\n", adj=0.5)
                ## summary for 4 components (20 rows) fits in one page:
                if (length(components)<5){
                    grid.table(summary_df, rows= NULL)
                }else{
                    grid.table(summary_df[1:20,], rows= NULL)
                    mincount = 21
                    maxcount = 40
                    for (count20 in 1:(ceiling(nrow(summary_df)/20)-1)){
                        plot(0,type='n',axes=FALSE,ann=FALSE)
                        if (maxcount <= nrow(summary_df)){
                            grid.table(summary_df[mincount:maxcount,], rows= NULL)
                            mincount = mincount+20
                            maxcount = maxcount+20
                        }else{### stop last page with last sample otherwise NA in table
                            grid.table(summary_df[mincount:nrow(summary_df),], rows= NULL)} 
                    }
                }

                ## optional output as .RData
                #if $output_rdata:
                save(msidata.cv.pls, file="$classification_rdata")
                #end if
            ######################## PLS - analysis ###########################
            #elif str( $type_cond.method_cond.analysis_cond.PLS_method) == "PLS_analysis":
                print("PLS analysis")

                ## number of components
                component = c($type_cond.method_cond.analysis_cond.pls_comp)

                ### pls analysis
                msidata.pls <- PLS(msidata, y = y_vector, ncomp = component, scale=$type_cond.method_cond.analysis_cond.pls_scale)

                ### plot of PLS coefficients
                plot(msidata.pls, main="PLS coefficients per m/z")

                ### summary table of PLS
                summary_table = summary(msidata.pls)\$accuracy[[paste0("ncomp = ",component)]]
                summary_table = cbind(rownames(summary_table), data.frame(summary_table))
                rownames(summary_table) = NULL
print(summary_table)
                ###plot(0,type='n',axes=FALSE,ann=FALSE)
                ###grid.table(test, rows= TRUE)

                ### image of the best m/z
                print(image(msidata, mz = topLabels(msidata.pls)[1,1], normalize.image = "linear", contrast.enhance = "histogram",smooth.image="gaussian", main="best m/z heatmap"))

                ## m/z and pixel information output
                pls_classes = data.frame(msidata.pls\$classes[[1]])
                rownames(pls_classes) = names(pixels(msidata))
                colnames(pls_classes) = "predicted diagnosis"
                pls_toplabels = topLabels(msidata.pls, n=$type_cond.method_cond.analysis_cond.pls_toplabels)

                write.table(pls_toplabels, file="$mzfeatures", quote = FALSE, row.names = TRUE, col.names=NA, sep = "\t")
                write.table(pls_classes, file="$pixeloutput", quote = FALSE, row.names = TRUE, col.names=NA, sep = "\t")

                ## optional output as .RData
                #if $output_rdata:
                save(msidata.pls, file="$classification_rdata")
                #end if

            #end if


        ######################## OPLS #############################
        #elif str( $type_cond.method_cond.class_method) == "OPLS":
            print("OPLS")

            ######################## OPLS -CV #############################
            #if str( $type_cond.method_cond.opls_analysis_cond.opls_method) == "opls_cvapply":
                print("OPLS cv")

                ## folds
                #if str($type_cond.method_cond.opls_analysis_cond.opls_fold_cond.opls_fold_vector) == "opls_fold_internal":
                    fold_vector = msidata\$$type_cond.method_cond.opls_analysis_cond.opls_fold_cond.opls_fold_name
                #elif str($type_cond.method_cond.opls_analysis_cond.opls_fold_cond.opls_fold_vector) == "opls_fold_external":
                    fold_tabular = read.delim("$type_cond.method_cond.opls_analysis_cond.opls_fold_cond.opls_fold_data", header = FALSE, stringsAsFactors = FALSE)
                    fold_vector = as.factor(fold_tabular[,$type_cond.method_cond.opls_analysis_cond.opls_fold_cond.opls_fold_column])
                    number_pixels = length(fold_vector) ## should be same as in data
                #end if

                ## plot of folds

                position_df = cbind(coord(msidata)[,1:2], fold_vector)
                fold_plot = ggplot(position_df, aes(x=x, y=y, fill=fold_vector))+
                       geom_tile() +
                       coord_fixed()+
                       ggtitle("Distribution of the fold variable")+
                       theme_bw()+
                       theme(text=element_text(family="ArialMT", face="bold", size=15))+
                       theme(legend.position="bottom",legend.direction="vertical")+
                       guides(fill=guide_legend(ncol=4,byrow=TRUE))
                coord_labels = aggregate(cbind(x,y)~fold_vector, data=position_df, mean, na.rm=TRUE, na.action="na.pass")
                coord_labels\$file_number = gsub( "_.*$", "", coord_labels\$fold_vector)
                print(fold_plot)

                ## number of components
                components = c($type_cond.method_cond.opls_analysis_cond.opls_cvcomp)

                ## OPLS-cvApply:
                msidata.cv.opls <- cvApply(msidata, .y = y_vector, .fold = fold_vector, .fun = "OPLS", ncomp = components, keep.Xnew = $type_cond.method_cond.opls_analysis_cond.xnew_cv)

                ## create table with summary
                count = 1
                summary_oplscv = list()
                accuracy_vector = numeric()
                for (iteration in components){
                    summary_iteration = summary(msidata.cv.opls)\$accuracy[[paste0("ncomp = ", iteration)]]
                    summary_iteration = cbind(rownames(summary_iteration), summary_iteration) ## include rownames in table
                    accuracy_vector[count] = summary_iteration[1,2] ## vector with accuracies to find later maximum for plot
                    empty_row = c(paste0("ncomp = ", iteration), rep( "", length(levels(y_vector)))) ## add line with ncomp for each iteration
                    ##rownames(labeled_iteration)[1] = paste0("ncomp = ", iteration)
                    ##labeled_iteration = cbind(rownames(labeled_iteration), labeled_iteration)
                    labeled_iteration = rbind(empty_row, summary_iteration)
                    summary_oplscv[[count]] = labeled_iteration ## create list with summary table for each component
                    count = count+1} 
                ## create dataframe from list
                summary_oplscv = do.call(rbind, summary_oplscv) 
                summary_df = as.data.frame(summary_oplscv)
                rownames(summary_df) = NULL

                ## plots
                ## plot to find ncomp with highest accuracy
                plot(summary(msidata.cv.opls), main="Accuracy of OPLS classification")
                ncomp_max = components[which.max(accuracy_vector)] ## find ncomp with max. accuracy
                ## one image for each sample/fold, 4 images per page
                image(msidata.cv.opls, model = list(ncomp = ncomp_max), layout = c(2, 2))

                par(opar)   
                ## print table with summary in pdf
                plot(0,type='n',axes=FALSE,ann=FALSE)
                title(main="Summary for the different components\n", adj=0.5)
                ## summary for 4 components (20 rows) fits in one page:
                if (length(components)<5){
                    grid.table(summary_df, rows= NULL)
                }else{
                    grid.table(summary_df[1:20,], rows= NULL)
                    mincount = 21
                    maxcount = 40
                    for (count20 in 1:(ceiling(nrow(summary_df)/20)-1)){
                        plot(0,type='n',axes=FALSE,ann=FALSE)
                        if (maxcount <= nrow(summary_df)){
                            grid.table(summary_df[mincount:maxcount,], rows= NULL)
                            mincount = mincount+20
                            maxcount = maxcount+20
                        }else{### stop last page with last sample otherwise NA in table
                            grid.table(summary_df[mincount:nrow(summary_df),], rows= NULL)} 
                    }
                }

                ## optional output as .RData
                #if $output_rdata:
                save(msidata.cv.opls, file="$classification_rdata")
                #end if

            ######################## OPLS -analysis ###########################
            #elif str( $type_cond.method_cond.opls_analysis_cond.opls_method) == "opls_analysis":
                print("OPLS analysis")

                ## number of components
                component = c($type_cond.method_cond.opls_analysis_cond.opls_comp)

                ### opls analysis
                msidata.opls <- PLS(msidata, y = y_vector, ncomp = component, scale=$type_cond.method_cond.opls_analysis_cond.opls_scale, keep.Xnew = $type_cond.method_cond.opls_analysis_cond.xnew)

                ### plot of OPLS coefficients
                plot(msidata.opls, main="OPLS coefficients per m/z")

                ### summary table of OPLS
                summary_table = summary(msidata.opls)\$accuracy[[paste0("ncomp = ",component)]]
                summary_table = cbind(rownames(summary_table), summary_table)
                rownames(summary_table) = NULL
                summary_table = data.frame(summary_table)
                print(summary_table)
                ###plot(0,type='n',axes=FALSE,ann=FALSE)
                ###grid.table(test, rows= TRUE)

                ### image of the best m/z
                print(image(msidata, mz = topLabels(msidata.opls)[1,1], normalize.image = "linear", contrast.enhance = "histogram",smooth.image="gaussian", main="best m/z heatmap"))

                ## m/z and pixel information output
                opls_classes = data.frame(msidata.opls\$classes[[1]])
                rownames(opls_classes) = names(pixels(msidata))
                colnames(opls_classes) = "predicted diagnosis"
                opls_toplabels = topLabels(msidata.opls, n=$type_cond.method_cond.opls_analysis_cond.opls_toplabels)

                write.table(opls_toplabels, file="$mzfeatures", quote = FALSE, row.names = TRUE, col.names=NA, sep = "\t")
                write.table(opls_classes, file="$pixeloutput", quote = FALSE, row.names = TRUE, col.names=NA, sep = "\t")

                ## optional output as .RData
                #if $output_rdata:
                save(msidata.opls, file="$classification_rdata")
                #end if

            #end if

        ######################## SSC #############################
        #elif str( $type_cond.method_cond.class_method) == "spatialShrunkenCentroids":
            print("SSC")

            ######################## SSC - CV #############################
            #if str( $type_cond.method_cond.ssc_analysis_cond.ssc_method) == "ssc_cvapply":
                print("SSC cv")

                ## folds
                #if str($type_cond.method_cond.ssc_analysis_cond.ssc_fold_cond.ssc_fold_vector) == "ssc_fold_internal":
                    fold_vector = msidata\$$type_cond.method_cond.ssc_analysis_cond.ssc_fold_cond.ssc_fold_name

                #elif str($type_cond.method_cond.ssc_analysis_cond.ssc_fold_cond.ssc_fold_vector) == "ssc_fold_external":
                    fold_tabular = read.delim("$type_cond.method_cond.ssc_analysis_cond.ssc_fold_cond.ssc_fold_data", header = FALSE, stringsAsFactors = FALSE)
                    fold_vector = as.factor(fold_tabular[,$type_cond.method_cond.ssc_analysis_cond.ssc_fold_cond.ssc_fold_column])
                    number_pixels = length(fold_vector) ## should be same as in data
                #end if

                ## plot of folds
                position_df = cbind(coord(msidata)[,1:2], fold_vector)
                fold_plot = ggplot(position_df, aes(x=x, y=y, fill=fold_vector))+
                       geom_tile() +
                       coord_fixed()+
                       ggtitle("Distribution of the fold variable")+
                       theme_bw()+
                       theme(text=element_text(family="ArialMT", face="bold", size=15))+
                       theme(legend.position="bottom",legend.direction="vertical")+
                       guides(fill=guide_legend(ncol=4,byrow=TRUE))
                coord_labels = aggregate(cbind(x,y)~fold_vector, data=position_df, mean, na.rm=TRUE, na.action="na.pass")
                coord_labels\$file_number = gsub( "_.*$", "", coord_labels\$fold_vector)
                print(fold_plot)

                ## SSC-cvApply:
                msidata.cv.ssc <- cvApply(msidata, .y = y_vector,.fold = fold_vector,.fun = "spatialShrunkenCentroids", r = c($type_cond.method_cond.ssc_r), s = c($type_cond.method_cond.ssc_s), method = "$type_cond.method_cond.ssc_kernel_method")

                ## create table with summary
                count = 1
                summary_ssccv = list()
                accuracy_vector = numeric()

                for (iteration in names(msidata.cv.ssc@resultData[[1]][,1])){
                    summary_iteration = summary(msidata.cv.ssc)\$accuracy[[iteration]]
                    summary_iteration = cbind(rownames(summary_iteration), summary_iteration) ## include rownames in table
                    accuracy_vector[count] = summary_iteration[1,2] ## vector with accuracies to find later maximum for plot
                    empty_row = c(iteration, rep( "", length(levels(y_vector)))) ## add line with ncomp for each iteration
                    labeled_iteration = rbind(empty_row, summary_iteration)
                    summary_ssccv[[count]] = labeled_iteration ## create list with summary table for each component
                    count = count+1
                }

                ##create dataframe from list
                summary_ssccv = do.call(rbind, summary_ssccv) 
                summary_df = as.data.frame(summary_ssccv)
                rownames(summary_df) = NULL

                ## plot to find parameters with highest accuracy
                plot(summary(msidata.cv.ssc), main="Accuracy of SSC classification")
                best_params = names(msidata.cv.ssc@resultData[[1]][,1])[which.max(accuracy_vector)] ## find parameters with max. accuracy
                r_value = as.numeric(substring(unlist(strsplit(best_params, ","))[1], 4))
                s_value = as.numeric(substring(unlist(strsplit(best_params, ","))[3], 5)) ## remove space

                image(msidata.cv.ssc, model = list( r = r_value, s = s_value ), layout=c(2,2))

                par(opar)
                ## print table with summary in pdf
                plot(0,type='n',axes=FALSE,ann=FALSE)
                title(main="Summary for the different parameters\n", adj=0.5)
                ## summary for 4 parameters (20 rows) fits in one page:
                if (length(names(msidata.cv.ssc@resultData[[1]][,1]))<5){
                    grid.table(summary_df, rows= NULL)
                }else{
                    grid.table(summary_df[1:20,], rows= NULL)
                    mincount = 21
                    maxcount = 40
                    for (count20 in 1:(ceiling(nrow(summary_df)/20)-1)){
                        plot(0,type='n',axes=FALSE,ann=FALSE)
                        if (maxcount <= nrow(summary_df)){
                            grid.table(summary_df[mincount:maxcount,], rows= NULL)
                            mincount = mincount+20
                            maxcount = maxcount+20
                        }else{### stop last page with last sample otherwise NA in table
                            grid.table(summary_df[mincount:nrow(summary_df),], rows= NULL)} 
                    }
                }

                ## optional output as .RData
                #if $output_rdata:
                save(msidata.cv.opls, file="$classification_rdata")
                #end if

            ######################## SSC -analysis ###########################
            #elif str( $type_cond.method_cond.ssc_analysis_cond.ssc_method) == "ssc_analysis":
                print("SSC analysis")

                ## SSC analysis
                msidata.ssc <- spatialShrunkenCentroids(msidata, y = y_vector, .fold = fold_vector, 
r = c($type_cond.method_cond.ssc_r), s = c($type_cond.method_cond.ssc_s), method = "$type_cond.method_cond.ssc_kernel_method")

                plot(msidata.ssc, mode = "tstatistics", model = list("r" = c($type_cond.method_cond.ssc_r), "s" = c($type_cond.method_cond.ssc_s)))

                ### summary table SSC

                ##summary(msidata.ssc)\$accuracy[[names(msidata.ssc@resultData)]]
                summary_table = summary(msidata.ssc)
print(summary_table)
                ##summary_table = cbind(rownames(summary_table), summary_table)
                ##rownames(summary_table) = NULL

                ###plot(0,type='n',axes=FALSE,ann=FALSE)
                ###grid.table(summary_table, rows= TRUE)

                ### image of the best m/z
                print(image(msidata, mz = topLabels(msidata.ssc)[1,1], normalize.image = "linear", contrast.enhance = "histogram",smooth.image="gaussian", main="best m/z heatmap"))

                ## m/z and pixel information output
                ssc_classes = data.frame(msidata.ssc\$classes[[1]])
                rownames(ssc_classes) = names(pixels(msidata))
                colnames(ssc_classes) = "predicted diagnosis"
                ssc_toplabels = topLabels(msidata.ssc)

                write.table(ssc_toplabels, file="$mzfeatures", quote = FALSE, row.names = TRUE, col.names=NA, sep = "\t")
                write.table(ssc_classes, file="$pixeloutput", quote = FALSE, row.names = TRUE, col.names=NA, sep = "\t")

                ## optional output as .RData
                #if $output_rdata:
                save(msidata.ssc, file="$classification_rdata")
                #end if

            #end if
        #end if


    ######################## II) Prediction #############################
    #############################################################################
    #elif str( $type_cond.type_method) == "prediction":
        print("prediction")

        #if str($type_cond.new_y.new_y_values) == "no_new_y": 
            new_y_vector = FALSE
        #elif str($type_cond.new_y.new_y_values) == "new_y_internal":
            new_y_vector = msidata\$$type_cond.new_y.new_y_name
        #elif str($type_cond.new_y.new_y_values) == "new_y_external":
            
            new_y_tabular = read.delim("$type_cond.new_y.new_y_data", header = FALSE, stringsAsFactors = FALSE)
            new_y_vector = new_y_tabular[,$type_cond.new_y.new_y_column]
            number_pixels = length(new_y_vector) ## should be same as in data
        #end if

        training_data = loadRData("$type_cond.training_result")
        prediction = predict(training_data,msidata, newy = new_y_vector)

        ## optional output as .RData
        #if $output_rdata:
        msidata = prediction
        save(msidata, file="$classification_rdata")
        #end if
    #end if

    dev.off()
}else{
    print("Inputfile has no intensities > 0")
    dev.off()
}

    ]]></configfile>
    </configfiles>
    <inputs>
        <param name="infile" type="data" format="imzml, rdata, analyze75"
               label="Inputfile as imzML, Analyze7.5 or Cardinal MSImageSet saved as RData"
                help="Upload composite datatype imzml (ibd+imzML) or analyze75 (hdr+img+t2m) or regular upload .RData (Cardinal MSImageSet)"/>
        <conditional name="processed_cond">
            <param name="processed_file" type="select" label="Is the input file a processed imzML file ">
                <option value="no_processed" selected="True">not a processed imzML</option>
                <option value="processed">processed imzML</option>
            </param>
            <when value="no_processed"/>
            <when value="processed">
                <param name="accuracy" type="float" value="50" label="Mass accuracy to which the m/z values will be binned" help="This should be set to the native accuracy of the mass spectrometer, if known"/>
                <param name="units" display="radio" type="select" label="Unit of the mass accuracy" help="either m/z or ppm">
                    <option value="mz" >mz</option>
                    <option value="ppm" selected="True" >ppm</option>
                </param>
            </when>
        </conditional>

        <conditional name="type_cond">
            <param name="type_method" type="select" label="Analysis step to perform">
                <option value="training" selected="True">training</option>
                <option value="prediction">prediction</option>
            </param>
            <when value="training">

                <conditional name="method_cond">
                    <param name="class_method" type="select" label="Select the method for classification">
                        <option value="PLS" selected="True">PLS</option>
                        <option value="OPLS">OPLS</option>
                        <option value="spatialShrunkenCentroids">spatial shrunken centroids</option>
                    </param>
                    <when value="PLS">

                        <conditional name="analysis_cond">
                            <param name="PLS_method" type="select" label="Crossvalidation or analysis">
                                <option value="cvapply" selected="True">cvApply</option>
                                <option value="PLS_analysis">PLS analysis</option>
                            </param>
                            <when value="cvapply">

                                <param name="plscv_comp" type="text" value="1:2"
                                       label="The number of PLS components" help="Multiple values are allowed (e.g. 1,2,3 or 2:5)"/>
                                <conditional name="fold_cond">
                                    <param name="fold_vector" type="select" label="Define the fold variable">
                                        <option value="fold_internal" selected="True">dataset contains already fold</option>
                                        <option value="fold_external">use fold from tabular file</option>
                                    </param>
                                    <when value="fold_internal">
                                        <param name="fold_name" type="text" value="sample" label="Name of the pData slot where fold is stored" help="each fold must contain pixels of all categories"/>
                                    </when>
                                    <when value="fold_external">
                                        <param name="fold_data" type="data" format="tabular" label="Tabular file with column for folds" help="Number of rows must be number of pixels"/>
                                        <param name="fold_column" data_ref="fold_data" label="Column with folds" type="data_column"/>
                                    </when>
                                </conditional>
                            </when>

                            <when value="PLS_analysis">
                                <param name="pls_comp" type="integer" value="5"
                                       label="The optimal number of PLS components as indicated by cross-validations" help="Run cvApply first to optain optiaml number of PLS components"/>
                                <param name="pls_scale" type="boolean" display="radio" label="data scaling" truevalue="TRUE" falsevalue="FALSE"/>
                                <param name="pls_toplabels" type="integer" value="100"
                                   label="Number of toplabels (masses) which should be written in tabular output"/>
                            </when>
                        </conditional>
                    </when>

                    <when value="OPLS">

                        <conditional name="opls_analysis_cond">
                            <param name="opls_method" type="select" label="Analysis step to perform">
                                <option value="opls_cvapply" selected="True">cvApply</option>
                                <option value="opls_analysis">OPLS analysis</option>
                            </param>

                            <when value="opls_cvapply">
                                <param name="opls_cvcomp" type="text" value="1:2"
                                       label="The number of OPLS components" help="Multiple values are allowed (e.g. 1,2,3 or 2:5)"/>
                                <param name="xnew_cv" type="boolean" display="radio" truevalue="TRUE" falsevalue="FALSE" label="Keep new matrix"/>
                                <conditional name="opls_fold_cond">
                                    <param name="opls_fold_vector" type="select" label="Define the fold variable">
                                        <option value="opls_fold_internal" selected="True">dataset contains already fold</option>
                                        <option value="opls_fold_external">use fold from tabular file</option>
                                    </param>
                                    <when value="opls_fold_internal">
                                        <param name="opls_fold_name" type="text" value="sample" label="Name of the pData slot where fold is stored" help="each fold must contain pixels of all categories"/>
                                    </when>
                                    <when value="opls_fold_external">
                                        <param name="opls_fold_data" type="data" format="tabular" label="Tabular file with column for folds" help="Number of rows must be number of pixels"/>
                                        <param name="opls_fold_column" data_ref="opls_fold_data" label="Column with folds" type="data_column"/>
                                    </when>
                                </conditional>
                            </when>

                            <when value="opls_analysis">
                                <param name="opls_comp" type="integer" value="5"
                                       label="The optimal number of PLS components as indicated by cross-validations" help="Run cvApply first to optain optiaml number of PLS components"/>
                                <param name="xnew" type="boolean" display="radio" truevalue="TRUE" falsevalue="FALSE" label="Keep new matrix"/>                                
                                <param name="opls_scale" type="select" label="data scaling" display="radio" optional="False">
                                    <option value="TRUE">yes</option>
                                    <option value="FALSE" selected="True">no</option>
                               </param>
                                <param name="opls_toplabels" type="integer" value="100"
                                   label="Number of toplabels (features) which should be written in tabular output"/>
                            </when>
                        </conditional>
                    </when>

                    <when value="spatialShrunkenCentroids">
                        <conditional name="ssc_analysis_cond">
                            <param name="ssc_method" type="select" label="Analysis step to perform">
                                <option value="ssc_cvapply" selected="True">cvApply</option>
                                <option value="ssc_analysis">spatial shrunken centroids analysis</option>
                            </param>
                            <when value="ssc_cvapply">

                                <conditional name="ssc_fold_cond">
                                    <param name="ssc_fold_vector" type="select" label="Define the fold variable">
                                        <option value="ssc_fold_internal" selected="True">dataset contains already fold</option>
                                        <option value="ssc_fold_external">use fold from tabular file</option>
                                    </param>
                                    <when value="ssc_fold_internal">
                                        <param name="ssc_fold_name" type="text" value="sample" label="Name of the pData slot where fold is stored" help="each fold must contain pixels of all categories"/>
                                    </when>
                                    <when value="ssc_fold_external">
                                        <param name="ssc_fold_data" type="data" format="tabular" label="Tabular file with column for folds" help="Number of rows must be number of pixels"/>
                                        <param name="ssc_fold_column" data_ref="ssc_fold_data" label="Column with folds" type="data_column"/>
                                    </when>
                                </conditional>
                            </when>

                            <when value="ssc_analysis">

                                <param name="ssc_toplabels" type="integer" value="100"
                                   label="Number of toplabels (features) which should be written in tabular output"/>
                            </when>
                        </conditional>
                        <param name="ssc_r" type="text" value="2"
                               label="The spatial neighborhood radius of nearby pixels to consider (r)" help="For cvapply multiple values are allowed (e.g. 1,2,3 or 2:5)"/>
                        <param name="ssc_s" type="text" value="2"
                               label="The sparsity thresholding parameter by which to shrink the t-statistics (s)" help="For cvapply multiple values are allowed (e.g. 1,2,3 or 2:5)"/>
                        <param name="ssc_kernel_method" type="select" display="radio" label = "The method to use to calculate the spatial smoothing kernels for the embedding. The 'gaussian' method refers to spatially-aware (SA) weights, and 'adaptive' refers to spatially-aware structurally-adaptive (SASA) weights">
                            <option value="gaussian">gaussian</option>
                            <option value="adaptive" selected="True">adaptive</option>
                        </param>

                    </when>
                </conditional>
                <conditional name="y_cond">
                    <param name="y_vector" type="select" label="Define the response variable y">
                        <option value="y_internal" selected="True">dataset contains already y</option>
                        <option value="y_external">use y from tabular file</option>
                    </param>
                    <when value="y_internal">
                        <param name="y_name" type="text" value="combined_sample" label="Name of the pData slot where y is stored" help="Outputs of MSI_combine tool have 'combined_sample' as name"/>
                    </when>
                    <when value="y_external">
                        <param name="y_data" type="data" format="tabular" label="Tabular file with column for y response"/>
                        <param name="y_column" data_ref="y_data" label="Column with y response" type="data_column"/>
                    </when>
                </conditional>
            </when>

            <when value="prediction">
                <param name="training_result" type="data" format="rdata" label="Result from previous classification training"/>
                <conditional name="new_y">
                    <param name="new_y_values" type="select" label="Define the new response y">
                        <option value="no_new_y" >no new y response</option>
                        <option value="new_y_internal" selected="True">dataset contains already y</option>
                        <option value="new_y_external">use y from tabular file</option>
                    </param>
                    <when value="no_new_y"/>
                    <when value="new_y_internal">
                        <param name="new_y_name" type="text" value="combined_sample" label="Name of the pData slot where y is stored" help="data merged with MSI_combine tool has 'combined_sample' as name"/>
                    </when>

                    <when value="new_y_external">
                        <param name="new_y_data" type="data" format="tabular" label="Tabular file with column for y response"/>
                        <param name="new_y_column" data_ref="new_y_data" label="Column with y response" type="data_column"/>
                    </when>
                </conditional>
            </when>
        </conditional>
        <param name="output_rdata" type="boolean" display="radio" label="Results as .RData output"/>
    </inputs>
    <outputs>
        <data format="pdf" name="classification_images" from_work_dir="classificationpdf.pdf" label = "$infile.display_name classification"/>
        <data format="tabular" name="mzfeatures" label="$infile.display_name features"/>
        <data format="tabular" name="pixeloutput" label="$infile.display_name pixels"/>
        <data format="rdata" name="classification_rdata" label="$infile.display_name classification">
            <filter>output_rdata</filter>
        </data>
    </outputs>
    <tests>
        <test expect_num_outputs="3">
            <param name="infile" value="testfile_squares.rdata" ftype="rdata"/>
            <conditional name="type_cond">
                <param name="type_method" value="training"/>
                <conditional name="method_cond">
                    <param name="class_method" value="PLS"/>
                    <conditional name="analysis_cond">
                        <param name="PLS_method" value="cvapply"/>

                        <param name="plscv_comp" value="2:4"/>
                        <conditional name="fold_cond">
                            <param name="fold_vector" value="fold_external"/>
                            <param name="fold_data" value="pixel_annotation_file1.tabular" ftype="tabular"/>
                            <param name="fold_column" value="1"/>
                        </conditional>

                    </conditional>
                </conditional>
                <conditional name="y_cond">
                    <param name="y_vector" value="y_external"/>
                    <param name="y_data" value="pixel_annotation_file1.tabular" ftype="tabular"/>
                    <param name="y_column" value="2"/>
                </conditional>
            </conditional>
            <output name="mzfeatures" file="features_test1.tabular"/>
            <output name="pixeloutput" file="pixels_test1.tabular"/>
            <output name="classification_images" file="test1.pdf" compare="sim_size" delta="20000"/>
        </test>

        <test expect_num_outputs="4">
            <param name="infile" value="testfile_squares.rdata" ftype="rdata"/>
            <conditional name="type_cond">
                <param name="type_method" value="training"/>
                <conditional name="method_cond">
                    <param name="class_method" value="PLS"/>
                    <conditional name="analysis_cond">
                        <param name="PLS_method" value="PLS_analysis"/>

                        <param name="pls_comp" value="2"/>
                        <param name="pls_scale" value="TRUE"/>
                        <param name="pls_toplabels" value="100"/>
                        <conditional name="fold_cond">
                            <param name="fold_vector" value="fold_external"/>
                            <param name="fold_data" value="pixel_annotation_file1.tabular" ftype="tabular"/>
                            <param name="fold_column" value="1"/>
                        </conditional>

                    </conditional>
                </conditional>
                <conditional name="y_cond">
                    <param name="y_vector" value="y_external"/>
                    <param name="y_data" value="pixel_annotation_file1.tabular" ftype="tabular"/>
                    <param name="y_column" value="2"/>
                </conditional>
            </conditional>
            <param name="output_rdata" value="True"/>
            <output name="mzfeatures" file="features_test2.tabular"/>
            <output name="pixeloutput" file="pixels_test2.tabular"/>
            <output name="classification_images" file="test2.pdf" compare="sim_size" delta="20000"/>
            <output name="classification_rdata" file="test2.rdata" compare="sim_size" />
        </test>

        <test expect_num_outputs="3">
            <param name="infile" value="testfile_squares.rdata" ftype="rdata"/>
            <conditional name="type_cond">
                <param name="type_method" value="training"/>
                <conditional name="method_cond">
                    <param name="class_method" value="OPLS"/>
                    <conditional name="opls_analysis_cond">
                        <param name="opls_method" value="opls_analysis"/>

                        <param name="opls_cvcomp" value="1:2"/>
                        <param name="xnew_cv" value="FALSE"/>
                        <conditional name="opls_fold_cond">
                            <param name="opls_fold_vector" value="opls_fold_external"/>
                            <param name="opls_fold_data" ftype="tabular" value="random_factors.tabular"/>
                            <param name="opls_fold_column" value="1"/>
                        </conditional>
                    </conditional>
                </conditional>
                <conditional name="y_cond">
                    <param name="y_vector" value="y_external"/>
                    <param name="y_data" value="random_factors.tabular" ftype="tabular"/>
                    <param name="y_column" value="2"/>
                </conditional>
            </conditional>
            <output name="mzfeatures" file="features_test3.tabular"/>
            <output name="pixeloutput" file="pixels_test3.tabular"/>
            <output name="classification_images" file="test3.pdf" compare="sim_size" delta="20000"/>
        </test>

        <test expect_num_outputs="4">
            <param name="infile" value="testfile_squares.rdata" ftype="rdata"/>
            <conditional name="type_cond">
                <param name="type_method" value="training"/>
                <conditional name="method_cond">
                    <param name="class_method" value="OPLS"/>
                    <conditional name="opls_analysis_cond">

                        <param name="opls_method" value="opls_analysis"/>
                        <param name="opls_comp" value="3"/>
                        <param name="xnew" value="FALSE"/>
                        <param name="opls_scale" value="FALSE"/>
                        <param name="opls_toplabels" value="100"/>
                    </conditional>

                </conditional>
                <conditional name="y_cond">
                    <param name="y_vector" value="y_external"/>
                    <param name="y_data" value="random_factors.tabular" ftype="tabular"/>
                    <param name="y_column" value="2"/>
                </conditional>
            </conditional>
            <param name="output_rdata" value="True"/>
            <output name="mzfeatures" file="features_test4.tabular"/>
            <output name="pixeloutput" file="pixels_test4.tabular"/>
            <output name="classification_images" file="test4.pdf" compare="sim_size" delta="20000"/>
            <output name="classification_rdata" file="test4.rdata" compare="sim_size" />
        </test>

        <test expect_num_outputs="3">
            <param name="infile" value="testfile_squares.rdata" ftype="rdata"/>
            <conditional name="type_cond">
                <param name="type_method" value="training"/>
                <conditional name="method_cond">
                    <param name="class_method" value="spatialShrunkenCentroids"/>
                    <conditional name="ssc_analysis_cond">
                        <param name="ssc_method" value="ssc_cvapply"/>
                        <conditional name="ssc_fold_cond">
                            <param name="ssc_fold_vector" value="ssc_fold_external"/>
                            <param name="ssc_fold_data" value="pixel_annotation_file1.tabular" ftype="tabular"/>
                            <param name="ssc_fold_column" value="1"/>
                        </conditional>
                        <param name="ssc_r" value="1:2"/>
                        <param name="ssc_s" value="2:3"/>
                        <param name="ssc_kernel_method" value="adaptive"/>
                    </conditional>
                </conditional>
                <conditional name="y_cond">
                    <param name="y_vector" value="y_external"/>
                    <param name="y_data" value="pixel_annotation_file1.tabular" ftype="tabular"/>
                    <param name="y_column" value="2"/>
                </conditional>
            </conditional>
            <output name="mzfeatures" file="features_test5.tabular"/>
            <output name="pixeloutput" file="pixels_test5.tabular"/>
            <output name="classification_images" file="test5.pdf" compare="sim_size" delta="20000"/>
        </test>

        <test expect_num_outputs="4">
            <param name="infile" value="testfile_squares.rdata" ftype="rdata"/>
            <conditional name="type_cond">
                <param name="type_method" value="training"/>
                <conditional name="method_cond">
                    <param name="class_method" value="spatialShrunkenCentroids"/>
                    <conditional name="ssc_analysis_cond">
                        <param name="ssc_method" value="ssc_analysis"/>
                        <param name="ssc_toplabels" value="100"/>
                     </conditional>
                    <param name="ssc_r" value="2"/>
                    <param name="ssc_s" value="2"/>
                    <param name="ssc_kernel_method" value="adaptive"/>
                </conditional>
                <conditional name="y_cond">
                    <param name="y_vector" value="y_external"/>
                    <param name="y_data" value="random_factors.tabular" ftype="tabular"/>
                    <param name="y_column" value="2"/>
                </conditional>
            </conditional>
            <param name="output_rdata" value="True"/>
            <output name="mzfeatures" file="features_test6.tabular"/>
            <output name="pixeloutput" file="pixels_test6.tabular"/>
            <output name="classification_images" file="test6.pdf" compare="sim_size" delta="20000"/>
            <output name="classification_rdata" file="test6.rdata" compare="sim_size" />
        </test>

        <test expect_num_outputs="4">
            <param name="infile" value="testfile_squares.rdata" ftype="rdata"/>
            <conditional name="type_cond">
                <param name="type_method" value="prediction"/>
                <param name="training_result" value="test2.rdata" ftype="rdata"/>
                <conditional name="new_y">
                    <param name="new_y_values" value="new_y_external"/>
                    <param name="new_y_data" value="pixel_annotation_file1.tabular" ftype="tabular"/>
                        <param name="new_y_column" value="2"/>
                </conditional>
            </conditional>
            <param name="output_rdata" value="True"/>
            <output name="mzfeatures" file="features_test7.tabular"/>
            <output name="pixeloutput" file="pixels_test7.tabular"/>
            <output name="classification_images" file="test7.pdf" compare="sim_size" delta="20000"/>
            <output name="classification_rdata" file="test7.rdata" compare="sim_size" />
        </test>

    </tests>
    <help>
        <![CDATA[

Cardinal is an R package that implements statistical & computational tools for analyzing mass spectrometry imaging datasets. `More information on Cardinal <http://cardinalmsi.org//>`_

This tool provides three different Cardinal functions for supervised classification of mass-spectrometry imaging data.

Input data: 3 types of input data can be used:

- imzml file (upload imzml and ibd file via the "composite" function) `Introduction to the imzml format <https://ms-imaging.org/wp/imzml/>`_
- Analyze7.5 (upload hdr, img and t2m file via the "composite" function)
- Cardinal "MSImageSet" data (with variable name "msidata", saved as .RData)

Options: 

- PLS(-DA): partial least square (discriminant analysis)
- O-PLS(-DA): Orthogonal partial least squares (discriminant analysis)
- Spatial shrunken centroids

Output: 

- Pdf with the heatmaps and plots for the classification
- Tabular file with information on masses and pixels: toplabels/classes (PLS, spatial shrunken centroids)
- optional RData output to further explore the results with Cardinal in R

        ]]>
    </help>
    <citations>
        <citation type="doi">10.1093/bioinformatics/btv146</citation>
    </citations>
</tool>