Title: | Gradient-Based Recognition of Spatial Patterns in Environmental Data |
---|---|
Description: | Provides algorithms for detection of spatial patterns from oceanographic data using image processing methods based on Gradient Recognition. |
Authors: | Wencheng Lau-Medrano [aut, cre] |
Maintainer: | Wencheng Lau-Medrano <[email protected]> |
License: | GPL (>= 3) |
Version: | 1.6.0 |
Built: | 2025-01-13 08:28:47 UTC |
Source: | https://github.com/cranhaven/cranhaven.r-universe.dev |
Surface chlorophyll maps downloaded from ERDDAP for running
examples with grec
functions.
chl
chl
A list
with chlorophyll information from February to April of
Aqua MODIS source.
ERDDAP website: https://coastwatch.pfeg.noaa.gov/erddap
Vector with 2000 colors generated from tim.colors
function.
colPalette
colPalette
A vector of 2000 colors in RGB format.
tim.colors
from fields package
This function empowers users to analyze data from various sources,
including numeric matrix
, array
s, XYZ-list
s,
SpatRaster
s, or RasterLayer
s*, by applying gradient-seeking
methodologies.
detectFronts(...)
detectFronts(...)
... |
Same arguments than getGradients. |
Since version 1.6.0, this function has been entirely replaced by
getGradients. As of version 2.0.0, detectFronts
will no longer
be available.
This function empowers users to analyze data from various sources,
including numeric matrix
, array
s, XYZ-list
s,
SpatRaster
s, or RasterLayer
s*, by applying gradient-seeking
methodologies.
## S3 method for class 'RasterLayer' getGradients(x, method = "BelkinOReilly2009", intermediate = FALSE, ...) ## S3 method for class 'SpatRaster' getGradients(x, method = "BelkinOReilly2009", intermediate = FALSE, ...) ## S3 method for class 'array' getGradients(x, method = "BelkinOReilly2009", intermediate = FALSE, ...) ## Default S3 method: getGradients( x, method = "BelkinOReilly2009", intermediate = FALSE, ConvolNormalization = FALSE, ... ) getGradients( x, method = c("BelkinOReilly2009", "median_filter", "Agenbag2003-1", "Agenbag2003-2"), intermediate = FALSE, ConvolNormalization = FALSE, ... ) ## S3 method for class 'list' getGradients(x, method = "BelkinOReilly2009", intermediate = FALSE, ...) ## S3 method for class 'matrix' getGradients(x, method = "BelkinOReilly2009", intermediate = FALSE, ...)
## S3 method for class 'RasterLayer' getGradients(x, method = "BelkinOReilly2009", intermediate = FALSE, ...) ## S3 method for class 'SpatRaster' getGradients(x, method = "BelkinOReilly2009", intermediate = FALSE, ...) ## S3 method for class 'array' getGradients(x, method = "BelkinOReilly2009", intermediate = FALSE, ...) ## Default S3 method: getGradients( x, method = "BelkinOReilly2009", intermediate = FALSE, ConvolNormalization = FALSE, ... ) getGradients( x, method = c("BelkinOReilly2009", "median_filter", "Agenbag2003-1", "Agenbag2003-2"), intermediate = FALSE, ConvolNormalization = FALSE, ... ) ## S3 method for class 'list' getGradients(x, method = "BelkinOReilly2009", intermediate = FALSE, ...) ## S3 method for class 'matrix' getGradients(x, method = "BelkinOReilly2009", intermediate = FALSE, ...)
x |
An object of class |
method |
|
intermediate |
|
... |
Extra arguments that will depend on the selected method. See Details. |
ConvolNormalization |
|
The grec package collaborates with the imagine package to execute and apply image processing algorithms for identifying oceanic gradients. imagine furnishes the foundational algorithms, developed efficiently utilizing C++ tools. Conversely, grec oversees the utilization of these coding instruments in the context of oceanic gradient recognition and handles the development of input/output methods. In this context, the available methods offered by grec are contingent on the installed grec-imagine versions.
(*) Due to the deprecation of the raster package, grec will not be
supporting the use of RasterLayer
in future versions. Instead,
grec will be incorporating support for SpatRaster-class,
a more recent and actively developed method for working with raster data.
This change will take effect as soon as raster is removed from CRAN.
Until the current version, grec
performs four methods:
BelkinOReilly2009
(default): Based on Belkin & O'Reilly (2009)
article, it uses a Contextual Median Filter (CMF) for smoothing the original
data before the applying of Sobel filters.
median_filter
: it uses a typical median filter (MF) for
smoothing the original data. It also allows the user to change the window
size for median filter (3 as default).
Agenbag2003-1
: Performs method 1 described on Agenbag et al.
(2003) paper, based on the equation:
Agenbag2003-2
: Performs method 2 described on Agenbag et al.
(2003) paper, calculating the the standard deviation of the 3x3 neighbor area
for each pixel.
The input data x
can be represented in various formats to accommodate
different data sources. It can be provided as a single numeric matrix
extracted from an environmental map. Alternatively, it can be represented as
a three-dimensional XYZ list
, where X
contains a vector of
longitudes, Y
contains a vector of latitudes, and Z
is a matrix
of dimensions length(x$X)
x length(x$Y)
. Additionally, it can
be specified as an array, SpatRaster
, or RasterLayer
* object.
If x
is an array
, it must have three dimensions: longitude (lon),
latitude (lat), and time. It is not mandatory to define the dimnames. The
output will maintain all the attributes of the input data.
...
allows the (advanced) users to modify some aspects of filter
application. Depending on the selected methodology, some parameters can be
modified:
numeric
. How many times do you want to apply
the filtering method?
A numeric
vector that will be used for
convolution to detect vertical and horizontal gradients.
numeric
. If median-filter method was
selected, it allows to change the window size of the filter.
Normalization is a standard practice in convolution to maintain the range of
output values consistent with the input data. This is achieved by dividing
the convolution output by the absolute value of the kernel. While
normalization is recommended to ensure consistent interpretation of results,
it is disabled by default and can be enabled by setting the
ConvolNormalization
parameter to TRUE
.
Finally, Belkin & O'Reilly's work suggests applying a logarithmic transformation to the gradient output. This step is not enabled by default, as it is primarily intended for chlorophyll data. Users are free to apply the transformation manually if it suits their specific needs.
The output will preserve the input class.
Belkin, I. M., & O'Reilly, J. E. (2009). An algorithm for oceanic front detection in chlorophyll and SST satellite imagery. Journal of Marine Systems, 78(3), 319-326 (doi:10.1016/j.jmarsys.2008.11.018).
Agenbag, J.J., A.J. Richardson, H. Demarcq, P. Freon, S. Weeks, and F.A. Shillington. "Estimating Environmental Preferences of South African Pelagic Fish Species Using Catch Size- and Remote Sensing Data". Progress in Oceanography 59, No 2-3 (October 2003): 275-300. (doi:10.1016/j.pocean.2003.07.004).
data(sst) exampleSSTData <- list(x = sst$longitude, y = sst$latitude, z = sst$sst[,,1]) data(chl) exampleChlData <- list(x = chl$longitude, y = chl$latitude, z = chl$chlorophyll[,,1]) # Simple application (over a XYZ list) out_sst <- getGradients(x = exampleSSTData) out_chl <- getGradients(x = exampleChlData) # External transformation for chl data out_chl$z <- log10(out_chl$z) par(mfrow = c(2, 2), mar = rep(0, 4), oma = rep(0, 4)) image(exampleSSTData, col = colPalette, axes = FALSE) mtext(text = "Original SST", side = 3, line = -2, adj = 0.99, cex = 1.2) image(out_sst, col = colPalette, axes = FALSE) mtext(text = "SST gradient", side = 3, line = -2, adj = 0.99, cex = 1.2) image(exampleChlData, col = colPalette, axes = FALSE) mtext(text = "Original Chlorophyll", side = 3, line = -2, adj = 0.99, cex = 1.2) image(out_chl, col = colPalette, axes = FALSE) mtext(text = "Chlorophyll gradient\n(log scale)", side = 3, line = -4, adj = 0.99, cex = 1.2)
data(sst) exampleSSTData <- list(x = sst$longitude, y = sst$latitude, z = sst$sst[,,1]) data(chl) exampleChlData <- list(x = chl$longitude, y = chl$latitude, z = chl$chlorophyll[,,1]) # Simple application (over a XYZ list) out_sst <- getGradients(x = exampleSSTData) out_chl <- getGradients(x = exampleChlData) # External transformation for chl data out_chl$z <- log10(out_chl$z) par(mfrow = c(2, 2), mar = rep(0, 4), oma = rep(0, 4)) image(exampleSSTData, col = colPalette, axes = FALSE) mtext(text = "Original SST", side = 3, line = -2, adj = 0.99, cex = 1.2) image(out_sst, col = colPalette, axes = FALSE) mtext(text = "SST gradient", side = 3, line = -2, adj = 0.99, cex = 1.2) image(exampleChlData, col = colPalette, axes = FALSE) mtext(text = "Original Chlorophyll", side = 3, line = -2, adj = 0.99, cex = 1.2) image(out_chl, col = colPalette, axes = FALSE) mtext(text = "Chlorophyll gradient\n(log scale)", side = 3, line = -4, adj = 0.99, cex = 1.2)
SST maps downloaded from ERDDAP for running examples with
grec
functions.
sst
sst
A list
with SST information from February to April of Aqua
MODIS source.
ERDDAP website: https://coastwatch.pfeg.noaa.gov/erddap