Calculate the homogeneity feature or metric for a gray-level co-occurrence matrix. For definition and application, see Lofstedt et al. (2019) doi:10.1371/journal.pone.0212110 .
homogeneity(x, ...)
# S3 method for default
homogeneity(x, ...)
# S3 method for matrix
homogeneity(x, ...)
# S3 method for FitLandDF
homogeneity(x, nlevels, ...)
gray-level co-occurrence matrix
additional parameters
desired number of discrete gray levels
homogeneity metric of x
## calculate homogeneity of arbitrary GLCM
# define arbitrary GLCM
x <- matrix(1:16, nrow = 4)
# normalize
n_x <- normalize_glcm(x)
# calculate homogeneity
homogeneity(n_x)
#> [1] 0.5
## calculate homogeneity of arbitrary fitness landscape
# create fitness landscape using FitLandDF object
vals <- runif(64)
vals <- array(vals, dim = rep(4, 3))
my_landscape <- fitscape::FitLandDF(vals)
# calculate homogeneity of fitness landscape, assuming 2 discrete gray levels
homogeneity(my_landscape, nlevels = 2)
#> [1] 0.7479675
## confirm value of homogeneity for fitness landscape
# extract normalized GLCM from fitness landscape
my_glcm <- get_comatrix(my_landscape, discrete = equal_discrete(2))
# calculate homogeneity of extracted GLCM
homogeneity(my_glcm) # should match value of above homogeneity function call
#> [1] 0.7479675