squareform#
- scipy.spatial.distance.squareform(X, force='no', checks=True)[source]#
将向量形式的距离向量转换为方阵形式的距离矩阵,反之亦然。
- 参数:
- Xarray_like
压缩或冗余距离矩阵。
- forcestr, 可选
与 MATLAB(TM) 一样,如果 force 等于
'tovector'
或'tomatrix'
,则输入将分别被视为距离矩阵或距离向量。- checksbool, 可选
如果设置为 False,则不会对矩阵的对称性或零对角线进行检查。如果已知
X - X.T1
很小,并且diag(X)
接近于零,这将很有用。无论如何,这些值都会被忽略,因此不会干扰 squareform 变换。
- 返回值:
- Yndarray
如果传递压缩距离矩阵,则返回冗余矩阵,或者如果传递冗余矩阵,则返回压缩距离矩阵。
备注
v = squareform(X)
给定一个 n×n 对称距离矩阵
X
,v = squareform(X)
返回一个大小为n * (n-1) / 2
(即二项式系数 n 选择 2)的向量 v,其中 \(v[{n \choose 2} - {n-i \choose 2} + (j-i-1)]\) 是不同点i
和j
之间的距离。如果X
不是方阵或非对称,则会引发错误。X = squareform(v)
给定一个大小为
n * (n-1) / 2
的向量v
(对于某个整数n >= 1
),该向量以描述的方式编码距离,X = squareform(v)
返回一个 n×n 距离矩阵X
。X[i, j]
和X[j, i]
的值设置为 \(v[{n \choose 2} - {n-i \choose 2} + (j-i-1)]\),所有对角线元素均为零。
在 SciPy 0.19.0 中,
squareform
停止将所有输入类型强制转换为 float64,并开始返回与输入相同数据类型的数组。示例
>>> import numpy as np >>> from scipy.spatial.distance import pdist, squareform
x
是一个在三维空间中的五个点的数组。>>> x = np.array([[2, 0, 2], [2, 2, 3], [-2, 4, 5], [0, 1, 9], [2, 2, 4]])
pdist(x)
计算x
中每对点之间的欧几里得距离。这些距离在一个长度为5*(5 - 1)/2 = 10
的一维数组中返回。>>> distvec = pdist(x) >>> distvec array([2.23606798, 6.40312424, 7.34846923, 2.82842712, 4.89897949, 6.40312424, 1. , 5.38516481, 4.58257569, 5.47722558])
squareform(distvec)
返回 5×5 距离矩阵。>>> m = squareform(distvec) >>> m array([[0. , 2.23606798, 6.40312424, 7.34846923, 2.82842712], [2.23606798, 0. , 4.89897949, 6.40312424, 1. ], [6.40312424, 4.89897949, 0. , 5.38516481, 4.58257569], [7.34846923, 6.40312424, 5.38516481, 0. , 5.47722558], [2.82842712, 1. , 4.58257569, 5.47722558, 0. ]])
当给定一个方阵距离矩阵
m
时,squareform(m)
返回与矩阵关联的一维压缩距离向量。在这种情况下,我们将恢复distvec
。>>> squareform(m) array([2.23606798, 6.40312424, 7.34846923, 2.82842712, 4.89897949, 6.40312424, 1. , 5.38516481, 4.58257569, 5.47722558])