This is a quick overview of how to retrieve data from the Soil and Landscape Grid of Australia.
Two high-level wrapper functions,
get_lscape_data(), have been provided to manage downloads. To use them correctly, you should be aware of the package datasets
slga_product_info(). They contain allowable values for some of the function inputs as well as key metadata.
The two tables are derived from information on the SLGA website and in the WCS metadata documents.
Soils data is available in a large number of combinations - each product has a set of available attributes (soil properties). Not all soil attributes are available within each product, but you can check which ones are available in
slga_attribute_info(). Each soil attribute has six depth slices extending from the land surface to 2.0 metres below. Each soil attribute also has three associated values - the estimated value, plus its lower (5%) and upper (95%) confidence limits. Effectively, if you visited a single pixel on the Grid and sampled 100 points inside that pixel, you should expect that 90 of those samples would return values within those limits.
Detailed metadata for each product can be found on the CSIRO Data Access Portal
get_soils_data() is capable of pulling out data for one combination of product, soil attribute, and depth. It gives the option of returning any combination of value and confidence interval layers, either as a
As a demonstration, the surface (0.0-0.05 metre) estimated percent clay content for central Brisbane is available with
data('bne_surface_clay') bne_surface_clay #> class : RasterStack #> dimensions : 121, 145, 17545, 3 (nrow, ncol, ncell, nlayers) #> resolution : 0.0008333333, 0.0008333333 (x, y) #> extent : 152.9496, 153.0704, -27.55042, -27.44958 (xmin, xmax, ymin, ymax) #> crs : +init=EPSG:4283 +proj=longlat +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +no_defs #> names : NAT_CLY_VAL_000_005, NAT_CLY_CLO_000_005, NAT_CLY_CHI_000_005 #> min values : 10.100820, -3.681541, 23.713245 #> max values : 33.95562, 19.32191, 48.78592
Note that some open-water areas have 0 values rather than NA; these are difficult to remove safely without an adequate mask. You may need to generate one yourself, particularly if you are working along the coast.
The query to retrieve the above maps looked like:
Note that valid
product parameters are defined in
slga_product_info$Short_Name, and valid
attribute parameters in
slga_attribute_info$Code. If a particular combination is not available, the function will fail gracefully.
18 landscape datasets are available, describing DEM-derived terrain attributes and climatic influences. These are considered to be effective environmental covariates in soil modelling exercises. Detailed metadata for each product can be found on the CSIRO Data Access Portal.
get_lscape_data() only requires a product code and aoi, as each landscape attribute is a single raster surface. For example, the Multi-resolution Valley Bottom Flatness Index for central Brisbane is given by
slga output datasets are always source-aligned - that is, the returned SLGA data will align with its parent coverage rather than your supplied
aoi parameter. This is deliberate; WCS services default to target-alignment, which involves hidden server-side resampling behaviour when a geographical subset is supplied. This behaviour is essential for WCS’ primary use case - accessing data dynamically in a GUI. For constructing reproducible workflows that start with rasters, however, it is not appropriate. If you need a dataset that aligns with other data, it is best practice to carry out any resampling and realignment at your end, after retrieving a ‘clean’ subset of SLGA data. This ensures that these operations are clearly documented. Functions like
raster::resample() may be useful at this point.
If you want to save a copy of the downloaded raster(s) to disk, you will need to specify
write_out = TRUE and supply a directory using the
filedir parameter. A full path to an existing directory must be supplied, so any of the following styles will work:
Files are saved in GeoTIFF format with an appropriate datatype and an informative filename. Note that existing files will be overwritten if a file with a matching name is detected in the destination directory.
To retrieve data from e.g. more than one depth, you can use an iterator like
purrr::map(). For instance, to retrieve estimated clay values for all depths over King Island, you could do the following:
Similar iteration can be carried out with a vector of attributes or products. Note that while all the soils products align with each other, not all of the landscape products do. Stacking the latter together will require some pre-processing.
Data values for single-point locations within the grid can be retrieved using
get_lscape_point(), as follows:
A non-spatial dataframe of values is returned. Summaries of the area around a point can also be retrieved. The summary can be of a square or circular window around a point.
Buffering is defined in terms of cells, not metres. A buffer of
n cells implies that the raster extracted will be
2n + 1 cells wide and high, centered on the cell into which the supplied point of interest falls.
Note that for datasets that have many points within a small area, it will be more efficient to download rasters covering the dataset bounding box before extracting point summaries using existing
raster package functions.
Service and coverage level metadata for soil and landscape data can be retrieved with
metadata_lscape(). For example,