Home > Software engineering >  Simulating Geographical Points Around the Eiffel Tower
Simulating Geographical Points Around the Eiffel Tower

Time:07-26

The coordinates of the Eiffel Tower are (Longitude: 48.8584° N, Latitude: 2.2945° E). I am interested in randomly generating 100 points that are located within a 12 KM radius of the Eiffel Tower. In other words, I would like to randomly generate 100 pairs of (Longitude, Latitude) that are located within a 12 KM radius of the Eiffel Tower.

According to this question here (enter image description here

I reduced the variance and now the points appear closer:

# reduce variance
id = 1:100
long = 2.2945   rnorm( 100, 0.1085246 , 0.01)
lat = 48.8584   rnorm( 100, 0.009036273 , 0.01)

my_data = data.frame(id, lat, long)

library(leaflet)
my_data %>% 
  leaflet() %>% 
  addTiles() %>% 
  addMarkers(clusterOption=markerClusterOptions())

enter image description here

But this of course required some guess work and playing around - ideally, I would like a more "mathematical approach".

  • Is there some standard formula I can use to make sure that no matter what initial coordinate I choose (e.g. Eiffel Tower, Statue of Liberty, etc.), the randomly generated points will always fall in a certain radius?

Thank you!

CodePudding user response:

One option is to use the sf package. The function st_buffer will allow you to create a 12 km circle around your starting point, and st_sample will allow you to take 100 random points within that circle.

Create the data

library(sf)
library(dplyr)

pt_sf <- data.frame(long = 2.2945, lat = 48.8584) %>%
  st_as_sf(coords = c("long", "lat"), crs = 4326)


buff <- pt_sf %>%
  st_buffer(dist = units::as_units(12, 'km'))

buff_sample <- st_sample(buff, 100)

Plot it

library(leaflet)

leaflet(pt_sf) %>% 
  addTiles() %>% 
  addCircleMarkers(color = 'red') %>%
  addPolygons(data = buff) %>%
  addMarkers(data = buff_sample, clusterOption=markerClusterOptions())

enter image description here

  • Related