我正在尝试在二进制视频帧中跟踪检测到的对象。因此,我将检测到的物体(红色小汽车)的质心存储在出队中,并使用scypi空间距离使用以下代码计算两个连续质心之间的距离:
import scipy.spatial.distance
from collections import deque
#defining the Centroid
centroids=deque(maxlen=40)
.
.
.
centroids.appendleft(center)
#center comes from detection process. e.g centroids=[(120,130), (125,132),...
Distance=scipy.spatial.distance.cdist(center[0],center[1)]
print('Distance ",Distance)
运行代码时,出现以下错误:
raise ValueError('XA must be a 2-dimensional array.')
ValueError: XA must be a 2-dimensional array.
错误是逻辑上的,因为存储的质心是汽车中心的点向量
所以我的问题是:
如何以这种方式进行这项工作,以便获得每两个连续的质心之间的距离差?
答案 0 :(得分:0)
scipy.spatial.distance.cdist()
需要两个二维数组作为输入,但是通过提供center[0]
和center[1]
,您将为其提供两个1维数组。
如果您想一次馈送centroids
的元素,则scipy.spatial.distance
包含一个称为euclidean
的函数,该函数可测量两个一维数组之间的距离。
要以这种方式获取每对连续质心之间的距离,您可以像这样循环遍历所有质心:
distances = []
for i in range(len(centroids) - 1):
distances.append(euclidean(centroids[i], centroids[i+1]))