R/compare_clusters.R

#' @title Heatmap to compare partitions
#' @description Build an interactive heatmap of the common GO terms frequency between several partitions.
#' @importFrom data.table data.table
#' @importFrom plotly plot_ly add_heatmap layout
#' @importFrom utils stack unstack tail
#' @family GO_clusters
#' @param clusters  a \code{list} of named \code{\link{GO_clusters-class}} objects,
#' from \code{\link{GOterms_heatmap}} or \code{\link{GOclusters_heatmap}} methods.
#' @details
#' Build an interactive heatmap of common GO terms frequency between partitions from several
#' \code{\link{GO_clusters-class}} objects.
#' @return an interactive javascript heatmap.
#' @references
#'  Carson Sievert, Chris Parmer, Toby Hocking, Scott Chamberlain, Karthik Ram, Marianne Corvellec and Pedro Despouy (2017).
#'  plotly: Create Interactive Web Graphics via 'plotly.js'. R package version 4.6.0. https://CRAN.R-project.org/package=plotly
#' @include GO_clusters.R
#' @examples
#' # load example object
#' data(
#'     myGOs,
#'     package="ViSEAGO"
#' )
#'
#' \dontrun{
#' # compute Semantic Similarity (SS)
#' myGOs<-ViSEAGO::compute_SS_distances(
#'     myGOs,
#'     distance=c("Resnik","Lin","Rel","Jiang","Wang")
#' )
#'
#' # Resnik distance GO terms heatmap
#' Resnik_clusters_wardD2<-ViSEAGO::GOterms_heatmap(
#'     myGOs,
#'     showIC=TRUE,
#'     showGOlabels=TRUE,
#'     GO.tree=list(
#'         tree=list(
#'             distance="Resnik",
#'             aggreg.method="ward.D2"
#'         ),
#'         cut=list(
#'             dynamic=list(
#'                 deepSplit=2,
#'                 minClusterSize =2
#'             )
#'         )
#'     ),
#'     samples.tree=NULL
#' )
#'
#' # Lin distance GO terms heatmap
#' Lin_clusters_wardD2<-ViSEAGO::GOterms_heatmap(
#'     myGOs,
#'     showIC=TRUE,
#'     showGOlabels=TRUE,
#'     GO.tree=list(
#'         tree=list(
#'             distance="Lin",
#'             aggreg.method="ward.D2"
#'         ),
#'         cut=list(
#'             dynamic=list(
#'                 deepSplit=2,
#'                 minClusterSize =2
#'             )
#'         )
#'     ),
#'     samples.tree=NULL
#' )
#'
#' # Resnik distance GO terms heatmap
#' Rel_clusters_wardD2<-ViSEAGO::GOterms_heatmap(
#'     myGOs,
#'     showIC=TRUE,
#'     showGOlabels=TRUE,
#'     GO.tree=list(
#'         tree=list(
#'             distance="Rel",
#'             aggreg.method="ward.D2"
#'         ),
#'         cut=list(
#'             dynamic=list(
#'                 deepSplit=2,
#'                 minClusterSize =2
#'             )
#'         )
#'     ),
#'     samples.tree=NULL
#' )
#'
#' # Resnik distance GO terms heatmap
#' Jiang_clusters_wardD2<-ViSEAGO::GOterms_heatmap(
#'     myGOs,
#'     showIC=TRUE,
#'     showGOlabels=TRUE,
#'     GO.tree=list(
#'         tree=list(
#'             distance="Jiang",
#'             aggreg.method="ward.D2"
#'         ),
#'         cut=list(
#'             dynamic=list(
#'                 deepSplit=2,
#'                 minClusterSize =2
#'             )
#'         )
#'     ),
#'     samples.tree=NULL
#' )
#'
#' # Resnik distance GO terms heatmap
#' Wang_clusters_wardD2<-ViSEAGO::GOterms_heatmap(
#'     myGOs,
#'     showIC=TRUE,
#'     showGOlabels=TRUE,
#'     GO.tree=list(
#'         tree=list(
#'             distance="Wang",
#'             aggreg.method="ward.D2"
#'         ),
#'         cut=list(
#'             dynamic=list(
#'                 deepSplit=2,
#'                 minClusterSize =2
#'             )
#'         )
#'     ),
#'     samples.tree=NULL
#' )
#' }
#'
#' # clusters to compare
#' clusters<-list(
#'     Resnik="Resnik_clusters_wardD2",
#'     Lin="Lin_clusters_wardD2",
#'     Rel="Rel_clusters_wardD2",
#'     Jiang="Jiang_clusters_wardD2",
#'     Wang="Wang_clusters_wardD2"
#' )
#'
#' \dontrun{
#' # clusters content comparisons
#' clusters_comp<-ViSEAGO::compare_clusters(clusters)
#' }
#' @name compare_clusters
#' @rdname compare_clusters-methods
#' @exportMethod compare_clusters
setGeneric(
    name="compare_clusters",
    def=function(clusters)
        {standardGeneric("compare_clusters")
    }
)

#' @rdname compare_clusters-methods
#' @aliases compare_clusters
setMethod(
    "compare_clusters",
    signature ="list",
    definition=function(clusters) {

        ## convert GO.ID GO.clusters column in list

        # extract clusters and GO.ID
        Clusters<-unlist(
            recursive=FALSE,
            lapply(clusters,function(x){

                # load the target object
                object=get(x[[1]])

                # check class
                if(!is(object,"GO_clusters")){
                    stop("object must come from ViSEAGO::GOterms_heatmap()")
                }

                # extract GO.ID and correspond cluster assignation to a list
                object=unstack(
                    slot(slot(object,"enrich_GOs"),"data")[,c("GO.ID","GO.cluster"),with=FALSE]
                )

                # names of list elements
                list.names<-as.numeric(names(object))

                # add 0 if needed
                list.names<-sprintf(
                    paste(
                        "%0",
                        max(nchar(list.names)),
                        "d",
                        sep=""
                    ),
                    list.names
                )

                # rename list elements
                names(object)<-paste(names(x),list.names,sep="cl")

                # return the object
                object
            })
        )

        ## count common terms

        # return a matrix cross-product from all common GO.ID count by Cluster-objects
        clusters.length<-lengths(Clusters)

        # return a matrix cross-product from all common GO.ID count by Cluster-objects
        Data<-crossprod(
            table(
                stack(Clusters)
            )
        )

        # assign 0 to upper part of the matrix
        Data[upper.tri(Data)]<-0

        # reverse matrix row
        Data<-Data[nrow(Data):1,]

        ## rectangle shape definition

        # methods
        methods=unique(
            gsub("\\..+$","",colnames(Data))
        )

        # rectangle shape definition
        coord<-unlist(
            recursive=FALSE,
            lapply(seq_along(methods),function(x){

                # x coordinates
                col=grep(paste(methods[x],"\\.",sep=""),colnames(Data))

                # y coordinates
                lapply(x:length(methods),function(y){

                    # y coordinates
                    row=grep(paste(methods[y],".",sep=""),row.names(Data))

                    # y coordinates
                    val=c(col[1]-1.5,tail(col,n=1)-0.5,row[1]-1.5,tail(row,n=1)-0.5)

                    # val names
                    names(val)<-c("x0","x1","y0","y1")

                    # return val
                    val
                })
            })
        )

        # initiate a rect shape object
        rect <- list(
            type = "rect",
            fillcolor = "",
            line = list(
                color = "black",
                width=1,
                dash="dash"
            ),
            opacity = 0.3,
            xref = "x",
            yref = "y"
        )

        # all rectangles
        rects <-lapply(coord,function(x){

            # rect dimensions
            rect[["x0"]] <- x["x0"]
            rect[["x1"]] <- x["x1"]
            rect[["y0"]] <- x["y0"]
            rect[["y1"]] <- x["y1"]

            # rect rect
            rect
        })

        ## build plot matrix

        # count by line
        rowsum=apply(Data,1,sum)

        # count by column
        colsum=apply(Data,2,sum)

        # keep Data without all 0
        count<-matrix(
            paste('<br>GO.common: ',Data),
            ncol=ncol(Data),
            byrow=FALSE
        )

        # row %
        row_prc<-round(
            (Data/clusters.length[row.names(Data)])*100,
            digits=1
        )

        # col % hover text
        row_prc_hover.text=matrix(
            paste('<br>y%:',row_prc),
            ncol=ncol(Data)
        )

        # replace 0 by NA
        row_prc[row_prc==0]<-NA

        # col %
        col_prc<-t(
            round(
                (t(Data)/clusters.length[colnames(Data)])*100,
                digits=1
            )
        )

        # col % hover text
        col_prc_hover.text=matrix(
            paste('<br>x%:',col_prc),
            ncol=ncol(Data)
        )

        # replace 0 by NA
        col_prc[col_prc==0]<-NA

        # column GOcount
        x=matrix(
            paste(
                'x:',
                rep(
                    colnames(col_prc),
                    each=ncol(col_prc)
                ),
                '<br>x GO sum:',
                rep(
                    clusters.length[colnames(col_prc)],
                    each=ncol(col_prc)
                )
            ),
            ncol=ncol(col_prc)
        )

        # row GOcount
        y=matrix(
            paste(
                '<br>y:',
                rep(
                    row.names(col_prc),
                    each=ncol(col_prc)
                ),
                '<br>y GO sum:',
                rep(
                    clusters.length[row.names(col_prc)],
                    each=ncol(col_prc)
                )
            ),
            ncol=ncol(col_prc),
            byrow=TRUE
        )

        # create hover text matrix
        hover.text<-matrix(
            paste(
                x,
                y,
                count,
                col_prc_hover.text,
                row_prc_hover.text
            ),
            ncol=ncol(count),
            byrow=FALSE
        )

        # remove hover text with no GO in common
        hover.text[count=="<br>GO.common:  0"]<-""

        ## interactive heatmap

        # initialyse p
        p<-plot_ly()

        # Draw heatmap with y%
        p<-add_heatmap(
            p,
            x=colnames(col_prc),
            y=row.names(col_prc),
            z=col_prc,
            colorscale = "Greys",
            name="x identity%",
            hoverinfo='text',
            text=hover.text,
            visible=TRUE
        )

        # Draw heatmap with y%
        p<-add_heatmap(
            p,
            x=colnames(row_prc),
            y=row.names(row_prc),
            z=row_prc,
            colorscale = "Greys",
            name="y identity%",
            hoverinfo='text',
            text=hover.text,
            visible=FALSE
        )

        # add custom layout with dropdown menu
        layout(

            # graph object
            p,

            # add title
            title="clusters comparisons",

            # add axis legends
            xaxis=list(
                title="x",
                tickfont=list(size=10)
            ),
            yaxis=list(
                title="y",
                tickfont=list(size=10)
            ),

            # custom margin
            margin=list(
                t=30,
                b=100,
                l=100,
                r=0)
            ,

            # add scrolling menu for availables measures
            shapes = rects,

            # add scrolling menu for availables measures
            updatemenus = list(

                # measure dropdown menu
                list(

                    # button position
                    x= 0.1,
                    y= 1.1,

                    buttons = list(

                        # x output button
                        list(
                            method ="restyle",
                            args = list("visible",list(TRUE,FALSE)),
                            label="x identity%"
                        ),

                        # y output button
                        list(
                            method ="restyle",
                            args = list("visible",list(FALSE,TRUE)),
                            label="y indentity%"
                        )
                    )
                )
            )
        )
    }
)

Try the ViSEAGO package in your browser

Any scripts or data that you put into this service are public.

ViSEAGO documentation built on Nov. 8, 2020, 6:51 p.m.