Skip to contents

This function automates the export of raster and vector spatial data from mpg and grain objects. By default it places them in a new directory, unless an existing one is specified with overwrite = TRUE.

It can also be used to process mpg and grain objects to produce R spatial objects that are convenient for plotting or analysis within R. Use R = TRUE in which case all parameters related to file export are ignored. (Default R = FALSE)

The raster::writeRaster() function is used for rasters, and sf::st_write() is used to export ESRI compatible shape files.

Usage

export(
  x,
  dirname = NULL,
  path = ".",
  rasterFormat = "GTiff",
  overwrite = FALSE,
  R = FALSE,
  vorBound = FALSE,
  ...
)

# S4 method for class 'mpg'
export(
  x,
  dirname = NULL,
  path = ".",
  rasterFormat = "GTiff",
  overwrite = FALSE,
  R = FALSE,
  vorBound = FALSE,
  ...
)

# S4 method for class 'grain'
export(
  x,
  dirname = NULL,
  path = ".",
  rasterFormat = "GTiff",
  overwrite = FALSE,
  R = FALSE,
  vorBound = FALSE,
  ...
)

# S4 method for class 'goc'
export(
  x,
  dirname = NULL,
  path = ".",
  rasterFormat = "GTiff",
  overwrite = FALSE,
  R = FALSE,
  vorBound = FALSE,
  ...
)

Arguments

x

A mpg or grain object

dirname

The name of a new directory to create. If NULL a directory with a name containing the date and time will be created.

path

A path to where this new directory dirname should be created. Defaults to the working directory.

rasterFormat

The format for exported rasters. See raster::writeFormats() for options. Defaults to GeoTiff (rasterFormat='GTiff'). Use rasterFormat='raster' to save .grd files in native raster package format.

overwrite

If directory already exists will overwrite existing files inside. Defaults to FALSE.

R

If TRUE, return the spatial objects that would be written to files. Do not write these files and ignore dirname, path, rasterFormat, overwrite parameters. This is useful for visualization using R plotting functions, or spatial analysis within R. Defaults to FALSE

vorBound

Specify whether to create a raster with the boundaries of the Voronoi polygons =1 and the remainder =NA. This may be useful for visualizing relationships among polygons in a grain of connectivity. This can add time to the export on very large rasters. Defaults to FALSE.

...

Additional arguments (not used).

Value

Invisibly returns the path to the folder created.

Side effect of exporting files representing raster and vector spatial data in the object.

Please note that for vector data export the attribute name is limited to 8 characters in shape files. See the tables below for the abbreviations used and their meaning.

Exported from mpg objects:

nodes, linksCentroid, linksPerim are shape files giving the locations of the patch centroids, links among centroids, and links among perimeters of patches respectively. patchId, voronoi are rasters giving the patch identifier of the patch, or of the patch that the Voronoi polygon refers to. lcpPerimWeight, lcpLinkId give the weight in cost surface units of the shortest paths between perimeters, and the identifiers of those links respectively. vorBound gives the boundaries of the Voronoi polygons (if specified).

Description of node (vertex) and link (edge) weights in mpg objects and their corresponding attribute names in the shape files created.

typeMPG nameSHP nameDescription
nodepatchIdpatchIdPatch ID from patchId raster
nodepatchAreapatchAArea of patch
nodepatchEdgeAreapatchEAEdge area of patch
nodecoreAreacoreAArea excluding edge of patch
nodecentroidXctrXCentroid of the patch (X)
nodecentroidYctrYCentroid of the patch (Y)
linke1e1Id of first patch at end of link
linke2e2Id of second patch at end of link
linklinkIdlinkIdLink ID from lcpLinkId raster
linklcPerimWeightlcpPerWtCost length of link from patch perimeters
linkstartPerimXstrtPerXCoordinate of link endpoint on first patch (X)
linkstartPerimYstrtPerYCoordinate of link endpoint on first patch (Y)
linkendPerimXendPerXCoordinate of link endpoint on second patch (X)
linkendPerimYendPerYCoordinate of link endpoint on second patch (Y)

Exported from grain objects:

nodes, linksCentroid are shape files giving the locations of the Voronoi polygon centroids and links among them respectively. voronoi are rasters gives the polygon identifier of each cluster of patches. vorBound gives the boundaries of the Voronoi polygons (if specified).

Description of node (vertex) and link (edge) weights in grain objects and their corresponding attribute names in the shape files created.

TypeGOC nameSHP nameDescription
nodepolygonIdpolyIdPolygon ID from grain voronoi raster
nodepolygonAreapolyAArea of polygon from grain voronoi raster
nodetotalPatchAreapatchATotal area of all patches in polygon
nodetotalPatchEdgeAreapatchEATotal area of all patch edges in polygon
nodetotalCoreAreacoreATotal area of patches in polygon excluding edges
nodecentroidXctrXCentroid of the polygon (X)
nodecentroidYctrYCentroid of the polygon (Y)
linke1e1ID of first patch at end of link
linke2e2ID of second patch at end of link
linkmaxWeightmaxWtThe maximum weight of all links connecting patches between polygons
linklinkIdMaxWeightmaxWtThe link id of that maximum weight link (lcpLinkId)
linkminWeightminThe minimum weight of all links connecting patches between polygons
linklinkIdMinWeightminWtThe link id of that minimum weight link (lcpLinkId)
linkmedianWeightmedWtThe median weight of all links connecting patches between polygons
linkmeanWeightmeanWTThe minimum weight of all links connecting patches between polygons
linknumlinksWeightnumEWtThe number of links connecting patches between polygons
linkeucCentroidWeighteucCtrWtThe Euclidean distance between centroids of polygons

See also

Author

Paul Galpern and Alex Chubaty

Examples

## Load raster landscape
tiny <- raster::raster(system.file("extdata/tiny.asc", package = "grainscape"))

## Create a resistance surface from a raster using an is-becomes reclassification
tinyCost <- raster::reclassify(tiny, rcl = cbind(c(1, 2, 3, 4), c(1, 5, 10, 12)))
## Produce a patch-based MPG where patches are resistance features=1
tinyPatchMPG <- MPG(cost = tinyCost, patch = tinyCost == 1)
## Extract a representative subset of 5 grains of connectivity
tinyPatchGOC <- GOC(tinyPatchMPG, nThresh = 5)
## Export rasters and vectors and place in an R object
sp_tinyPatchGOC <- export(grain(tinyPatchGOC, 2), R = TRUE)  # nolint
sp_tinyPatchMPG <- export(tinyPatchMPG, R = TRUE) # nolint

## Export raster and vectors to a specified directory
exportPath <- tempdir()
export(grain(tinyPatchGOC, 2), dirname = "tiny_goc_thresh2", path = exportPath)
#> writing: substituting ENGCRS["Undefined Cartesian SRS with unknown unit"] for missing CRS
#> Writing layer `nodes' to data source 
#>   `/tmp/RtmpE7MNfS/tiny_goc_thresh2' using driver `ESRI Shapefile'
#> Writing 29 features with 5 fields and geometry type Point.
#> writing: substituting ENGCRS["Undefined Cartesian SRS with unknown unit"] for missing CRS
#> Writing layer `linksCentroid' to data source 
#>   `/tmp/RtmpE7MNfS/tiny_goc_thresh2' using driver `ESRI Shapefile'
#> Writing 64 features with 15 fields and geometry type Line String.
#> Exported to:/tmp/RtmpE7MNfS/tiny_goc_thresh2
export(tinyPatchMPG, dirname = "tiny_mpg", path = exportPath, vorBound = TRUE)
#> Extracting voronoi boundaries...
#> writing: substituting ENGCRS["Undefined Cartesian SRS with unknown unit"] for missing CRS
#> Writing layer `nodes' to data source 
#>   `/tmp/RtmpE7MNfS/tiny_mpg' using driver `ESRI Shapefile'
#> Writing 43 features with 4 fields and geometry type Point.
#> writing: substituting ENGCRS["Undefined Cartesian SRS with unknown unit"] for missing CRS
#> Writing layer `linksCentroid' to data source 
#>   `/tmp/RtmpE7MNfS/tiny_mpg' using driver `ESRI Shapefile'
#> Writing 101 features with 12 fields and geometry type Line String.
#> writing: substituting ENGCRS["Undefined Cartesian SRS with unknown unit"] for missing CRS
#> Writing layer `linksPerim' to data source 
#>   `/tmp/RtmpE7MNfS/tiny_mpg' using driver `ESRI Shapefile'
#> Writing 101 features with 8 fields and geometry type Line String.
#> Exported to:/tmp/RtmpE7MNfS/tiny_mpg

## clean up
unlink(file.path(exportPath, "tiny_goc_thresh2"), recursive = TRUE)
unlink(file.path(exportPath, "tiny_mpg"), recursive = TRUE)