Я только что написал метод Ruby, который расширяет Random
, чтобы обеспечить это.
Предостережение : Все точки лежат в рамке, а не в круге.
class Random
def location(lat, lng, max_dist_meters)
Это называется с Random.new.location(mid_lat, mid_lng, dist)
.Он вернет точку, которая вероятно в пределах max_dist_meters
от средней точки.
max_radius = Math.sqrt((max_dist_meters ** 2) / 2.0)
Без корректировки на max_radius
мы получили бы точки внутри квадрата за пределами круга(то есть в углах), где расстояние будет больше, чем max_dist_meters
.Это ограничивает нас квадратом внутри круга, который, вероятно, больше того, что вы хотите.
lat_offset = rand(10 ** (Math.log10(max_radius / 1.11)-5))
lng_offset = rand(10 ** (Math.log10(max_radius / 1.11)-5))
1.11
и 5
взяты из здесь .
lat += [1,-1].sample * lat_offset
lng += [1,-1].sample * lng_offset
lat = [[-90, lat].max, 90].min
lng = [[-180, lng].max, 180].min
Мы, вероятно, должны обернуться здесь вместо того, чтобы просто фиксировать значение, исправления приветствуются.
[lat, lng]
end
end
Комментарии / очистка приветствуются!
Пример вывода здесь , которыйВы можете хорошо видеть, если вы вставите широту / ширину здесь .