skbio.stats.distance.SymmetricMatrix#
- class skbio.stats.distance.SymmetricMatrix(data, ids=None, validate=True, condensed=False, diagonal=None)[source]#
 Store symmetric pairwise relationships between objects.
A
SymmetricMatrixis aPairwiseMatrixwith the additional requirement that the matrix data is symmetric (i.e., upper and lower triangles mirror each other). There are additional methods made available that take advantage of this symmetry.Added in version 0.7.1.
- Parameters:
 - data1-D or 2-D array_like, or PairwiseMatrix
 A square 2-D array of pairwise relationships between objects, or a 1-D array representing its condensed form. Can instead be an instance of
PairwiseMatrixor its subclass, in which case its data and IDs will be directly used.- idssequence of str, optional
 IDs of the objects. Must match the number of objects in
data. If None (default) anddatadoes not contain IDs, IDs will be monotonically-increasing integers cast as strings, starting from zero (i.e., ‘0’, ‘1’, ‘2’, ‘3’, …).- validatebool, optional
 If True (default) and
datais not aSymmetricMatrixobject, the input data will be validated.- condensedbool, optional
 Store the data in a 2-D redundant form (False, default) or a 1-D condensed form (True).
- diagonal1-D array_like or float, optional
 Values along the diagonal of the matrix. Can be a vector matching the number of objects in
data, or a single number representing a uniform diagonal. Default is zero. Can be provided whendatais in condensed form. Otherwise, an error will be raised.
Attributes
Attributes (inherited)
Array of pairwise relationships.
Data type of the matrix values.
Tuple of object IDs.
Two-element tuple containing the redundant form matrix dimensions.
Total number of elements in the underlying data structure.
Methods
Return a condensed form deep copy of the matrix.
Return a redundant form deep copy of the matrix.
Return an array of distances in condensed format.
copy()Return a deep copy of the symmetric matrix.
from_iterable(iterable, metric[, key, keys, ...])Create a symmetric matrix from an iterable given a metric.
permute([condensed, seed])Randomly permute both rows and columns in the matrix.
Return an array of values in redundant format.
Return the transpose of the matrix.
Methods (inherited)
between(from_, to_[, allow_overlap])Obtain the pairwise values between the two groups of IDs.
filter(ids[, strict])Filter the matrix by IDs.
index(lookup_id)Return the index of the specified ID.
plot([cmap, title])Create a heatmap of the matrix.
read([format])Create a new
SymmetricMatrixinstance from a file.rename(mapper[, strict])Rename IDs in the matrix.
Create a pandas DataFrame from this matrix.
within(ids)Obtain all the pairwise values among the set of IDs.
write(file[, format])Write an instance of
SymmetricMatrixto a file.Special methods
__getitem__(index)Slice into data by object ID or NumPy indexing.
Special methods (inherited)
__contains__(lookup_id)Check if the specified ID is in the matrix.
__eq__(other)Compare this matrix to another for equality.
__ge__(value, /)Return self>=value.
__getstate__(/)Helper for pickle.
__gt__(value, /)Return self>value.
__le__(value, /)Return self<=value.
__lt__(value, /)Return self<value.
__ne__(other)Determine whether two matrices are not equal.
__str__()Return a string representation of the matrix.
Details
- T#
 Transpose of the matrix.
If the matrix is in condensed form, a redundant form matrix will be returned.
See also
- diagonal#
 Diagonal value(s) of the matrix.
If diagonal is a float, this value is repeated along the diagonal of the matrix. If diagonal is an array, it represents the full diagonal of the matrix.
- __getitem__(index)[source]#
 Slice into data by object ID or NumPy indexing.
Extracts data from the matrix by object ID, a pair of IDs, or NumPy indexing/slicing.
- Parameters:
 - indexstr, two-tuple of str, or NumPy index
 Can be one of the following:
A string: Returns the row vector of this ID.
A tuple of two strings: Returns the value between the first ID (row) and the second ID (column).
Otherwise,
indexwill be passed through to.data.__getitem__, allowing for standard indexing of a NumPy array (e.g., slicing).
- Returns:
 - ndarray or scalar
 Indexed data, where return type depends on the form of
index(see description ofindexfor more details).
- Raises:
 - MissingIDError
 If the ID(s) specified in
indexare not in the matrix.
Notes
The lookup based on ID(s) is quick. NumPy indexing (slicing) on condensed form matrices will convert them to redundant, roughly doubling their memory requirement.