An S4 class to represent a co-occurrence matrix.

## Details

A co-occurrence matrix is a symmetric matrix with zeros on its main diagonal, which works out how many times (expressed in percent) each pairs of taxa/types occur together in at least one sample.

## Matrix ID

When a matrix is first created, an identifier is generated (UUID v4). This ID is preserved when coercing to another class. Thus, the object ID is unique within the same class, but two objects of different classes can have the same ID. This makes it possible to identify objects representing the same initial data and associate them with the results of specific computations (e. g. seriation).

## Get and set

In the code snippets below, x is a *Matrix object.

get_id(x)

Get the ID of x.

## Access

In the code snippets below, x is a *Matrix object.

dim(x)

Returns the dimension of x.

nrow(x)

Returns the number of rows present in x.

ncol(x)

Returns the number of columns present in x.

dimnames(x), dimnames(x) <- value

Retrieves or sets the row dimnames of x according to value.

rownames(x), rownames(x) <- value

Retrieves or sets the row names of x according to value.

colnames(x), colnames(x) <- value

Retrieves or sets the column names of x according to value.

## Subset

In the code snippets below, x is a *Matrix object.

x[i, j]

Extracts elements selected by subscripts i and j. Indices are numeric, integer or character vectors or empty (missing) or NULL. Numeric values are coerced to integer as by as.integer (and hence truncated towards zero). Character vectors will be matched to the name of the elements. An empty index (a comma separated blank) indicates that all entries in that dimension are selected. Returns an object of the same class as x.

x[[i]]

Extracts informations from a slot selected by subscript i. i should be one of "id" or NULL.

NumericMatrix

Other abundance matrix: CountMatrix-class, FrequencyMatrix-class

Other matrix: CountMatrix-class, FrequencyMatrix-class, IncidenceMatrix-class, LogicalMatrix-class, Matrix-class, NumericMatrix-class, SimilarityMatrix-class, coerce

## Examples

## Create a count data matrix
A1 <- CountMatrix(data = sample(0:10, 100, TRUE),
nrow = 10, ncol = 10, byrow = TRUE)

## Access
get_id(A1)#> [1] "88ea7fa6-4d31-4b8e-9b81-f02aa1ae34a1"dim(A1) # Get the matrix dimensions#> [1] 10 10colnames(A1) # Get the column names#>  [1] "V1"  "V2"  "V3"  "V4"  "V5"  "V6"  "V7"  "V8"  "V9"  "V10"colnames(A1) <- letters[11:20] # Set the column names
rownames(A1) # Get the rownames#>  [1] "1"  "2"  "3"  "4"  "5"  "6"  "7"  "8"  "9"  "10"rownames(A1) <- LETTERS[1:10] # Set the row names

## Subset
A1[["id"]] # Get the matrix ID#> [1] "88ea7fa6-4d31-4b8e-9b81-f02aa1ae34a1"A1[, ] # Get all values#>   k  l  m n  o p  q  r s  t
#> A 9  0 10 9  4 4 10  6 6  7
#> B 4 10  5 1  4 4  0  4 8  9
#> C 3 10  5 9  2 2  0  7 4  8
#> D 3  2  8 9  8 0  7  5 9  5
#> E 7  2  4 8  5 9  0  8 3  5
#> F 5  0 10 2 10 0  8 10 0  9
#> G 1  7  9 9  0 3  8 10 0  1
#> H 2  1  0 7  8 6  4  1 6  9
#> I 6  9  9 1 10 3  9  1 7 10
#> J 7  3  7 8  1 3  4  7 4  7A1[1, ] # Get the first row#>  k  l  m  n  o  p  q  r  s  t
#>  9  0 10  9  4  4 10  6  6  7 A1[c("A", "B", "C"), ] # Get the first three rows#>   k  l  m n o p  q r s t
#> A 9  0 10 9 4 4 10 6 6 7
#> B 4 10  5 1 4 4  0 4 8 9
#> C 3 10  5 9 2 2  0 7 4 8A1[c("A", "B", "C"), 1] # Get the first three rows of the first column#> A B C
#> 9 4 3 A1[, 1, drop = FALSE] # Get the first column#>   k
#> A 9
#> B 4
#> C 3
#> D 3
#> E 7
#> F 5
#> G 1
#> H 2
#> I 6
#> J 7
## Coerce counts to frequencies
B <- as_frequency(A1)
## Row sums are internally stored before coercing to a frequency matrix
get_totals(B) # Get row sums#>  A  B  C  D  E  F  G  H  I  J
#> 65 49 50 56 51 54 48 44 65 51 ## This allows to restore the source data
A2 <- as_count(B)
all(A1 == A2)#> [1] TRUE