For developers: fasterRaster and GRASS Regions

Adam B. Smith

2024-12-15

A GRASS region is a data structure like a raster in that it is composed of a grid, but different in that “cells” in this grid do not contain values. Rather, their resolution and the extent of the region influence how rasters are imported, created, processed, and exported. In most cases, whenever a raster undergoes one of these processes using a GRASS module, the raster will be resampled and/or crop/extend it so that matches the region”s extent and resolution. If ignored, this can cause unintended side effects if the region’s geometry doesn’t match the raster being processed.

Generally, most users of fasterRaster will not need to know how regions work because their management is handled automatically. This help page is provided to assist power users who may wish to use regions explicitly or develop their own applications based on fasterRaster.

Each GRASS “location” typically has one active region. The extent and resolution of this region is initially set by the first raster that is imported into it.

Functions for regions in fasterRaster

Properties of the current region can be obtained using the following functions (with no arguments):

fasterRaster provides several hidden functions for managing regions:

Most of the hidden functions can be used in three different ways: * No arguments: The function reports the respective value(s) (e.g., regionExt() reports the extent of the region–same as ext() with no arguments). * With a GRaster, GVector, SpatRaster, SpatVector, or sf object: Resizes and/or resamples the region so it has the same extent and/or resolution as the spatial object. Note that vector objects do not have a resolution, so cannot be used in .region*() functions that resample the region’s resolution. * With numeric values (i.e., representing extent, resolution, or dimensions): Resize or resample the region so it has these dimensions. When a region’s extent is resized or resolution is changed, it will be extended to have the next-larger number of rows and/or columns so it can accommodate cells of the desired size.

Regions are inherently 3-dimensional, but often have a single depth (i.e., one “layer” of cells).

~ FINIS ~