Функции для работы с Geohash
Geohash
Geohash — это система геокодов, которая делит поверхность Земли на ячейки в виде сетки и кодирует каждую ячейку в короткую строку букв и цифр. Это иерархическая структура данных, поэтому чем длиннее строка geohash, тем точнее будет географическое положение.
Если вам нужно вручную конвертировать географические координаты в строки geohash, вы можете использовать geohash.org
geohashEncode
Кодирует широту и долготу в строку geohash.
Синтаксис
Входные значения
longitude
— Долгота координаты, которую вы хотите закодировать. Число с плавающей запятой в диапазоне[-180°, 180°]
. Float.latitude
— Широта координаты, которую вы хотите закодировать. Число с плавающей запятой в диапазоне[-90°, 90°]
. Float.precision
(необязательный) — Длина результирующей закодированной строки. По умолчанию12
. Целое число в диапазоне[1, 12]
. Int8.
- Все параметры координат должны быть одного типа: либо
Float32
, либоFloat64
. - Для параметра
precision
любое значение меньше1
или больше12
тихо преобразуется в12
.
Возвращаемые значения
- Алфавитно-цифровая строка закодированной координаты (используется модифицированная версия алфавита base32). String.
Пример
Запрос:
Результат:
geohashDecode
Декодирует любую строку, закодированную geohash, в долготу и широту.
Синтаксис
Входные значения
hash_str
— Закодированная строка geohash.
Возвращаемые значения
Пример
geohashesInBox
Возвращает массив строк, закодированных geohash с заданной точностью, которые попадают внутрь и пересекают границы заданного прямоугольника, фактически это 2D сетка, преобразованная в массив.
Синтаксис
Аргументы
longitude_min
— Минимальная долгота. Диапазон:[-180°, 180°]
. Float.latitude_min
— Минимальная широта. Диапазон:[-90°, 90°]
. Float.longitude_max
— Максимальная долгота. Диапазон:[-180°, 180°]
. Float.latitude_max
— Максимальная широта. Диапазон:[-90°, 90°]
. Float.precision
— Точность geohash. Диапазон:[1, 12]
. UInt8.
Все параметры координат должны быть одного типа: либо Float32
, либо Float64
.
Возвращаемые значения
- Массив строк geohash заданной длины, покрывающих предоставленную область, не следует полагаться на порядок элементов. Array(String).
[]
- Пустой массив, если минимальные значения широты и долготы не меньше соответствующих максимальных значений.
Функция выбрасывает исключение, если результирующий массив превышает 10'000'000 элементов.
Пример
Запрос:
Результат: