R/ObsLulcRasterStack.R

#' @include class-ObsLulcRasterStack.R class-CategoryLabel.R
NULL

#' Create an ObsLulcRasterStack object
#'
#' Methods to create an ObsLulcRasterStack object, which may be created from file, an
#' existing Raster* object or a list of Raster* objects.
#'
#' Observed land use maps should have the same extent and resolution. The
#' location of non-NA cells in \code{ObsLulcRasterStack} objects defines the region for
#' subsequent analysis.
#' 
#' @param x path (character), Raster* object or list of Raster* objects. Default
#'   behaviour is to search for files in the working directory
#' @param pattern regular expression (character). Only filenames (if \code{x} is
#'   a path) or Raster* objects (if \code{x} is a list) matching the regular
#'   expression will be returned. See \cr
#'   \code{raster::\link[raster]{raster}} for more information about supported filetypes
#' @param categories numeric vector of land use categories in observed maps
#' @param labels character vector (optional) with labels corresponding to
#'   \code{categories}
#' @param t numeric vector containing the timestep of each observed map. The 
#'   first timestep must be 0
#' @param \dots additional arguments to \code{raster::\link[raster]{stack}}
#'
#' @return An ObsLulcRasterStack object.
#'
#' @seealso \code{\link{ObsLulcRasterStack-class}}, \code{raster::\link[raster]{stack}}
#'
#' @export
#' @rdname ObsLulcRasterStack
#'
#' @examples
#'
#' ## Plum Island Ecosystems
#' obs <- ObsLulcRasterStack(x=pie,
#'                    pattern="lu",
#'                    categories=c(1,2,3),
#'                    labels=c("forest","built","other"),
#'                    t=c(0,6,14))
#' 
#' ## Sibuyan Island
#' obs <- ObsLulcRasterStack(x=sibuyan$maps,
#'                    pattern="lu",
#'                    categories=c(1,2,3,4,5),
#'                    labels=c("forest","coconut","grass","rice","other"),
#'                    t=c(0,14))
#'

setGeneric("ObsLulcRasterStack", function(x, pattern, ...)
           standardGeneric("ObsLulcRasterStack"))

#' @rdname ObsLulcRasterStack
#' @aliases ObsLulcRasterStack,missing,character-method
setMethod("ObsLulcRasterStack", signature(x = "missing", pattern = "character"),
          function(x, pattern, ...) {
              out <- ObsLulcRasterStack(x=".", pattern=pattern, ...)
          }
)

#' @rdname ObsLulcRasterStack
#' @aliases ObsLulcRasterStack,character,character-method
setMethod("ObsLulcRasterStack", signature(x = "character", pattern = "character"), 
          function(x, pattern, ...) {
              files <- list.files(path=x, pattern=pattern, full.names=FALSE)
              if (length(files) > 0) {
                  ##files <- mixedsort(obs.files)
                  files <- sort(files)
                  paths <- file.path(x, files)
                  maps <- raster::stack(paths)                  
              } else {
                  stop("maps not found")
              }
              out <- ObsLulcRasterStack(x=maps, ...)
          }
)

#' @rdname ObsLulcRasterStack
#' @aliases ObsLulcRasterStack,list,character-method
setMethod("ObsLulcRasterStack", signature(x = "list", pattern = "character"),
           function(x, pattern, ...) {
              list.names <- names(x)
              if (is.null(list.names)) stop("list elements must be named")
              ix <- grep(pattern=pattern, x=list.names)
              files <- list.names[ix]
              ##obs.files <- mixedsort(obs.files)
              files <- sort(files)
              if (length(files) > 0) {
                  maps <- raster::stack(x[files])
              } else {
                  stop("maps not found")
              }
              out <- ObsLulcRasterStack(x=maps, ...)
          }
)

#' @rdname ObsLulcRasterStack
#' @aliases ObsLulcRasterStack,RasterLayer,ANY-method
setMethod("ObsLulcRasterStack", signature(x = "RasterLayer", pattern = "ANY"),
          function(x, ...) {
              maps <- raster::stack(x)
              out <- ObsLulcRasterStack(x=maps, ...)
          }
)

#' @rdname ObsLulcRasterStack
#' @aliases ObsLulcRasterStack,RasterStack,ANY-method
setMethod("ObsLulcRasterStack", signature(x = "RasterStack", pattern = "ANY"),
          function(x, pattern, categories, labels, t) {
              if (missing(categories)) categories <- sort(unique(as.numeric(raster::getValues(x))))
              ix <- order(categories)
              categories <- categories[ix]
              if (missing(labels)) {
                  labels <- paste0("cat", categories)
              } else {
                  labels <- labels[ix]
              }
              if (missing(t)) t <- 0
              ## info <- total(x, categories)
              ## total <- info$total
              ## out <- new("ObsLulcRasterStack", maps=x, t=t, total=total, categories=categories, labels=labels)
              out <- new("ObsLulcRasterStack", x, t=t, categories=categories, labels=labels)
          }
)

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.