bundles / scipy latest / scipy / cluster / hierarchy / centroid
function
scipy.cluster.hierarchy:centroid
source: /scipy/cluster/hierarchy.py :507
Signature
def centroid ( y ) Summary
Perform centroid/UPGMC linkage.
Extended Summary
See linkage for more information on the input matrix, return structure, and algorithm.
The following are common calling conventions:
Z = centroid(y)Performs centroid/UPGMC linkage on the condensed distance matrix
y.Z = centroid(X)Performs centroid/UPGMC linkage on the observation matrix
Xusing Euclidean distance as the distance metric.
Parameters
y: ndarrayA condensed distance matrix. A condensed distance matrix is a flat array containing the upper triangular of the distance matrix. This is the form that
pdistreturns. Alternatively, a collection of m observation vectors in n dimensions may be passed as an m by n array.
Returns
Z: ndarrayA linkage matrix containing the hierarchical clustering. See the
linkagefunction documentation for more information on its structure.
Notes
Array API Standard Support
centroid has experimental support for Python Array API Standard compatible backends in addition to NumPy. Please consider testing these features by setting an environment variable SCIPY_ARRAY_API=1 and providing CuPy, PyTorch, JAX, or Dask arrays as array arguments. The following combinations of backend and device (or other capability) are supported.
==================== ==================== ==================== Library CPU GPU ==================== ==================== ==================== NumPy ✅ n/a CuPy n/a ⛔ PyTorch ✅ ⛔ JAX ✅ ⛔ Dask ⚠️ merges chunks n/a ==================== ==================== ====================
See
dev-arrayapifor more information.
Examples
from scipy.cluster.hierarchy import centroid, fcluster from scipy.spatial.distance import pdist✓
X = [[0, 0], [0, 1], [1, 0], [0, 4], [0, 3], [1, 4], [4, 0], [3, 0], [4, 1], [4, 4], [3, 4], [4, 3]]✓
y = pdist(X)
✓Z = centroid(y)
✓Z
✗fcluster(Z, 0.9, criterion='distance') fcluster(Z, 1.1, criterion='distance') fcluster(Z, 2, criterion='distance')✗
fcluster(Z, 4, criterion='distance')
✓See also
- linkage
for advanced creation of hierarchical clusterings.
- scipy.spatial.distance.pdist
pairwise distance metrics
Aliases
-
scipy.cluster.hierarchy.centroid