Функции для работы с 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 с заданной точностью, которые находятся внутри и пересекают границы указанного прямоугольника, по сути представляя собой двумерную сетку, свернутую в массив.
Синтаксис
Аргументы
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.
:::note
Все параметры координат должны быть одного типа: либо Float32, либо Float64.
:::
Возвращаемые значения
- Массив строк геохеш-боксов длиной
precision, покрывающих указанную область; на порядок элементов полагаться не следует. Array(String). []— Пустой массив, если минимальные значения широты и долготы не меньше соответствующих максимальных значений.
:::note
Функция генерирует исключение, если результирующий массив содержит более 10'000'000 элементов.
:::
Пример
Запрос:
Результат: