r - 如何使用 R 计算多个 lon lat 向量之间的距离

标签 r ggmap

我的数据集如下 -

a
Location   loc.Lon   loc.Lat  Pincode      pin.lon     pin.lat
SPM        79.94533 12.97025 "602105"   79.95285     12.96752
SPM        79.94533 12.97025 "602106"   79.88568     12.91943

我想使用 ggmap 包计算两个 pin 码的 (loc.Lon, loc.Lat) 和 (pin.lon, pin.lat) 之间的距离。

当我运行下面的代码时,我得到了想要的结果 -

mapdist(c(a$loc.Lon[2], a$loc.Lat[2]), c(a$pin.lon[2],a$pin.lat[2]), mode = "driving") 

但是当我对整个数据集 a 运行以下查询时,出现错误 -

a$dist = mapdist(c(a$loc.Lon, a$loc.Lat), c(a$pin.lon,a$pin.lat), mode = "driving")

我得到的错误是 -

Error: is.character(from) is not TRUE

请帮我解决这个问题。

最佳答案

mapdist 接受 fromto 参数的向量,因此您可以转换它们并将此函数应用于数据集的每一行.

假设您想要公里距离:

get_km_from_mapdist <- function(i) {
  mapdist(as.numeric(a[i, c('loc.Lon','loc.Lat')]), 
          as.numeric(a[i, c('pin.lon','pin.lat')]), 
          mode='driving')$km
}

a$dists = sapply(1:nrow(a), get_km_from_mapdist)

关于r - 如何使用 R 计算多个 lon lat 向量之间的距离,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36616308/

相关文章:

r - 将工具提示格式化为货币并打开比较模式

r - 在 Ubuntu 14.04.1 LTS 上安装 R (3.1.0) 包插入符号时出错

r - 无论位置如何,寻找独特的组合

r - 绘制等高线图时出现错误(如果(任何(h <= 0))停止 ("bandwidths must be strictly positive"错误): in R

r - 带有 ggmap 的 R 中自定义属性的地理热图

r - 在 spatstat 中使用 sf 多边形对象作为窗口

java - 如何将R包 "spatstat"中的示例数据集转换成shapefile

javascript - 谷歌地图 : get user's location like google

r - 如何使用 GGMAP 在空间可视化中绘制矢量数据?

r - 有什么方法可以在 map 上绘制多个条形图?