R/plot.FigureOfMerit.R

Defines functions plot.FigureOfMerit

Documented in plot.FigureOfMerit

#' @include class-ThreeMapComparison.R
NULL

#' Plot method for FigureOfMerit objects
#'
#' Plot the overall, category-specific or transition-specific figure of merit at
#' different resolutions.
#'
#' @param x a FigureOfMerit object
#' @param y not used
#' @param from optional numeric value representing a land use category. If 
#'   provided without \code{to} the figure of merit for all transitions from this
#'   category will be plotted
#' @param to similar to \code{from}. If provided with a valid \code{from}
#'   argument the transition defined by these two arguments (i.e. \code{from} ->
#'   \code{to}) will be plotted. It is possible to include more than one category
#'   in which case the different transitions will be included on the same plot
#' @param col character specifying the plotting colour. Default is to use the
#' 'Set2' palette from \code{RColorBrewer}
#' @param type character. See \code{lattice::\link[lattice]{panel.xyplot}}
#' @param key list. See \code{lattice::\link[lattice]{xyplot}}
#' @param scales list. See \code{lattice::\link[lattice]{xyplot}}
#' @param xlab character or expression. See \code{lattice::\link[lattice]{xyplot}}
#' @param ylab character or expression. See \code{lattice::\link[lattice]{xyplot}}
#' @param \dots additional arguments to \code{lattice::\link[lattice]{xyplot}}
#'
#' @seealso \code{\link{FigureOfMerit}}, \code{lattice::\link[lattice]{xyplot}},
#'   \code{lattice::\link[lattice]{panel.xyplot}}
#'
#' @return A trellis object.
#'
#' @export
#' @name plot.FigureOfMerit
#' @rdname plot.FigureOfMerit
#'
#' @examples
#'
#' ## see lulcc-package examples

#' @rdname plot.FigureOfMerit
#' @method plot FigureOfMerit
#' @export
plot.FigureOfMerit <- function(x, y, ..., from, to, col=RColorBrewer::brewer.pal(8, "Set2"), type="b", key, scales, xlab, ylab) {

    if (!missing(from) && missing(to)) fom <- "category"

    if (!missing(from)) {
        from.ix <- which(x@categories %in% from)
        if (length(from.ix) > 1) {
            stop("'from' must be a single land use category")
        } else if (length(from.ix) == 0) {
            stop("'from' is not a valid land use category")
        }

    } else {
        fom <- "overall"
    }

    if (!missing(from) && !missing(to)) {
        to.ix <- which(x@categories %in% to)
        if (length(to.ix) == 0) {
            stop("'to' is not a valid land use category")
        }
        if (length(to.ix) == 1 && from.ix == to.ix) stop("'from' cannot equal 'to'")
        fom <- "transition"        
    }

    ## prepare data.frame
    if (fom == "transition") {
        if (length(to.ix) > 1) {
            data.list <- list()
            var.list <- list() ## for key
            for (i in 1:length(to.ix)) {
                figureofmerit <- sapply(x@transition, function(x) x[from.ix, to.ix[i]])
                if (!all(is.na(figureofmerit))) {
                    var <- paste0("transition ", x@labels[from.ix], " -> ", x@labels[to.ix[i]])
                    var.list[[(length(var.list) + 1)]] <- var
                    data.list[[(length(data.list) + 1)]] <- data.frame(x=1:length(x@factors),
                                                                       var=var,
                                                                       y=figureofmerit)
                } 
            }

            data <- do.call(rbind, data.list)

       } else {
            var <- paste0("transition ", x@labels[from.ix], " -> ", x@labels[to.ix])
            figureofmerit <- sapply(x@transition, function(x) x[from.ix, to.ix])
            data <- data.frame(x=1:length(x@factors),
                               var=var,
                               y=figureofmerit)

       }

    } else if (fom == "category") {
        var <- paste0("transitions from ", x@labels[from.ix])
        figureofmerit <- sapply(x@category, function(x) x[from.ix])
        data <- data.frame(x=1:length(x@factors),
                           var=var,
                           y=figureofmerit)

    } else if (fom == "overall") {
        figureofmerit <- sapply(x@overall, function(x) x)
        var <- paste0("overall")
        data <- data.frame(x=1:length(x@factors),
                           var=var,
                           y=figureofmerit)
    } 

    if (type == "transition" && length(to.ix) > 1) {
        default.key <- list(space="bottom",
                            lines=list(type=type, pch=1, col=col[1:length(data.list)], size=5),
                            text=list(sapply(var.list, function(x) x)),
                            divide=1)
    } else {
        default.key <- list(space="bottom",
                            lines=list(type=type, pch=1, col=col[1], size=5),
                            text=list(var),
                            divide=1)
    }

    if (missing(key)) {
        key <- default.key
    } else if (!is.null(key)) {
         matching.args <- names(default.key)[names(default.key) %in% names(key)]
         key <- c(key, default.key[!names(default.key) %in% names(key)])

         ## deal with embedded lists 
         for (arg in matching.args) {
             key[[arg]] <- c(key[[arg]], default.key[[arg]][!names(default.key[[arg]]) %in% names(key[[arg]])])
         }
   }

    default.scales <- list(x=list(at=1:length(x@factors), labels=x@factors))
    if (missing(scales)) {
        scales <- default.scales
    } else {
         matching.args <- names(default.scales)[names(default.scales) %in% names(scales)]
         scales <- c(scales, default.scales[!names(default.scales) %in% names(scales)])

         ## deal with embedded lists 
         for (arg in matching.args) {
             scales[[arg]] <- c(scales[[arg]], default.scales[[arg]][!names(default.scales[[arg]]) %in% names(scales[[arg]])])
         }
    }

    default.xlab <- list(label="Resolution (multiple of native pixel size)")
    if (missing(xlab)) {
        xlab <- default.xlab
    } else {
         matching.args <- names(default.xlab)[names(default.xlab) %in% names(xlab)]
         xlab <- c(xlab, default.xlab[!names(default.xlab) %in% names(xlab)])

         ## deal with embedded lists 
         for (arg in matching.args) {
             xlab[[arg]] <- c(xlab[[arg]], default.xlab[[arg]][!names(default.xlab[[arg]]) %in% names(xlab[[arg]])])
         }
    }

    default.ylab <- list(label="Figure of merit")
    if (missing(ylab)) {
        ylab <- default.ylab
    } else {
         matching.args <- names(default.ylab)[names(default.ylab) %in% names(ylab)]
         ylab <- c(ylab, default.ylab[!names(default.ylab) %in% names(ylab)])

         ## deal with embedded lists 
         for (arg in matching.args) {
             ylab[[arg]] <- c(ylab[[arg]], default.ylab[[arg]][!names(default.ylab[[arg]]) %in% names(ylab[[arg]])])
         }
    }

    p <- lattice::xyplot(y~x,
                         data=data,
                         groups=var,
                         key=key,
                         #par.settings=list(layout.heights = list(key.top=1.5)), ##,
                         line.col=col,
                         panel=function(x,y,line.col,...) {
                             lattice::panel.xyplot(x,y,type=type,col=line.col,...)
                         }, 
                         xlab=xlab,     #"Resolution (multiple of native pixel size)",
                         ylab=ylab,     #"Figure of merit",
                         scales=scales, #list(x=list(at=1:length(x@factors), labels=x@factors)),
                         ...)
    p

}

#' @rdname plot.FigureOfMerit
#' @aliases plot,FigureOfMerit,ANY-method
setMethod("plot", "FigureOfMerit", plot.FigureOfMerit)


## #' @rdname plot.FigureOfMerit
## #' @aliases plot,FigureOfMerit,ANY-method
## setMethod("plot", "FigureOfMerit", plot.FigureOfMerit)

## setGeneric("FigureOfMerit.plot", function(x, ...)
##            standardGeneric("FigureOfMerit.plot"))

## #' @rdname FigureOfMerit.plot
## #' @aliases FigureOfMerit.plot,FigureOfMerit-method

Try the lulcc package in your browser

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

lulcc documentation built on May 1, 2019, 7:05 p.m.