Вычислите расстояние между 2 координатами в одной строке в R

#r #dataframe #sp #geosphere

Вопрос:

У меня есть фрейм данных [df], подобный этому:

 df<-structure(list(  Latitude = c(-23.8, -23.8, -23.9, -23.9), 
                     Longitude = c(-49.6, -49.3, -49.4, -49.8), 
                     Latitude1 = c(-23.4, -23.7, -23.4, -23.8), 
                     Longitude1 = c(-49.7, -49.4, -49.6, -49.7)),
                     class = "data.frame", row.names = c(NA, -4L))
 

Фрейм данных содержит GPS-координаты 2 точек, и я хотел бы рассчитать расстояние в метрах между этими 2 точками в каждой строке. Я хотел бы получить только расстояние между 2 точками в каждой строке, а не матрицу расстояний.

Желаемый результат будет выглядеть так:

 Latitude   Longitude   Latitude1   Longitude1   Distance_m
-23.8      -49.6       -23.4       -49.7        53
 

Я попробовал пакет geosphere, но не смог получить правильных результатов.

Есть ли какой-нибудь способ сделать это, пожалуйста?

Спасибо вам за любые предложения.

Ответ №1:

Проверьте distm функцию из geosphere пакета:

 apply(df, 1, function(x)distm(c(x[1],x[2]),c(x[3],x[4]),fun = distGeo))
 

Ответ №2:

tidyverse с помощью // не удалось воспроизвести желаемый результат 53, хотя… ?

 library(geosphere)
library(tidyverse)
df %>%
  mutate(distance = pmap(list(a = Longitude, 
                              b = Latitude, 
                              x = Longitude1,
                              y = Latitude1), 
                          ~ geosphere::distGeo( c(..1, ..2), c(..3, ..4))))

#   Latitude Longitude Latitude1 Longitude1 distance
# 1    -23.8     -49.6     -23.4      -49.7 45461.49
# 2    -23.8     -49.3     -23.7      -49.4 15053.19
# 3    -23.9     -49.4     -23.4      -49.6 59016.34
# 4    -23.9     -49.8     -23.8      -49.7 15048.01
 

Комментарии:

1. Спасибо вам за это, однако я всегда получаю эту ошибку: Ошибка в .pointsToMatrix(x) : долгота Мои долготы представлены в числовом формате, и ни одна из них на самом деле не ниже -360.