gpt4 book ai didi

r - 计算后续位置之间的欧几里得距离

转载 作者:行者123 更新时间:2023-12-04 10:55:51 25 4
gpt4 key购买 nike

我有由 X 和 Y 坐标对组成的大型数据框,并希望计算连续坐标之间的欧几里得距离(最小尺寸约为 2000 对坐标)。

因此,我想计算第 1 行到第 2 行、第 2 行到第 3 行、第 3 行到第 4 行等的距离。This question很好地展示了如何计算轨迹数据的第一个点和最后一个点之间的欧几里得距离,但我的数据更接近:

dff <- structure(list(A = c(0L, 0L, 0L, 0L, 0L, 0L), T = 0:5, X = c(668L, 670L, 672L, 674L, 676L, 678L), Y = c(259L, 259L, 259L, 259L, 259L, 260L), V = c(NA, 0, 0, 0, 0, 0)), .Names = c("A", "T", "X", "Y", "V"), row.names = c(NA, 6L), class = "data.frame")

似乎应该有一种方法可以创建一个循环来执行此操作,但我不确定如何下标。使用 dist() 对这种大小的数据集的计算要求很高,无论如何我也不确定如何从对角线中提取一次性矩阵元素。

最佳答案

类似

sqrt(diff(dff$X)^2 + diff(dff$Y)^2)

应该可以。这里的关键是 diff 函数,它给出向量中连续项之间的差异

关于r - 计算后续位置之间的欧几里得距离,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18340318/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com