WikiDer > Geohash

Geohash

Geohash это всеобщее достояние система геокодирования изобретен в 2008 году Густаво Нимейером[1] и (аналогичная работа 1966 г.) Г. Мортон,[2] который кодирует географическое положение в короткую строку букв и цифр. Это иерархическая пространственная структура данных, которая подразделяет пространство на блоки сетка форма, которая является одним из многих приложений того, что известно как Кривая Z-порядка, и вообще кривые, заполняющие пространство.

Геохеши предлагают такие свойства, как произвольная точность и возможность постепенного удаления символов из конца кода, чтобы уменьшить его размер (и постепенно терять точность). Геохеширование гарантирует, что чем длиннее общий префикс между двумя геохешами, тем пространственно они ближе друг к другу. Обратное этому не гарантируется, поскольку две точки могут быть очень близкими, но иметь короткий общий префикс или не иметь общего префикса.

История

Основная часть алгоритма Geohash и первая инициатива по созданию подобного решения были задокументированы в отчете G.M. Мортон в 1966 году, "Компьютерная база геодезических данных и новый метод упорядочивания файлов".[2] Работа Мортона была использована для эффективной реализации Кривая Z-порядка, как в эта современная (2014) версия Geohash-integer, основанный на прямом чередовании 64-битные целые числа. Но его геокодировать предложение не было человек читаемый и не пользовался популярностью.

Судя по всему, в конце 2000-х Г. Нимейер еще не знал о работе Мортона и изобрел ее заново, добавив использование base32 представление. В феврале 2008 года вместе с анонсом системы,[1] он запустил сайт http://geohash.org, который позволяет пользователям преобразовывать географические координаты в краткие URL которые однозначно идентифицируют позиции на земной шар, так что ссылаясь на них в электронные письма, форумы, и веб-сайты удобнее.

Было разработано множество вариаций, в том числе OpenStreetMapс короткая ссылка[3] (с помощью base64 вместо base32) в 2009 г. 64-битный Geohash[4] в 2014 году экзотика Гильберт-Геохаш[5][6] в 2016 г. и др.

Типичное и основное использование

Чтобы получить Geohash, пользователь предоставляет адрес, который будет геокодированный, или же широта и долгота координаты в одном поле ввода (принимаются наиболее часто используемые форматы для пар широты и долготы) и выполняет запрос.

Помимо отображения широты и долготы, соответствующих данному Geohash, пользователям, которые переходят к Geohash на сайте geohash.org, также представлена ​​встроенная карта, и они могут загрузить GPX файл или передать путевую точку непосредственно в определенный GPS приемники. Также предоставляются ссылки на внешние сайты, которые могут предоставить дополнительную информацию о указанном местоположении.

Например, координатная пара 57.64911,10.40744 (возле кончика полуостров из Ютландия, Дания) производит немного более короткий хэш u4pruydqqvj.

Основное использование геохешей:

  • Как уникальный идентификатор.
  • Для представления точечных данных, например в базах данных.

Геохеши также предлагалось использовать для геотегирование.

При использовании в базе данных структура геохешированных данных имеет два преимущества. Во-первых, данные, проиндексированные геохешем, будут иметь все точки для данной прямоугольной области в смежных срезах (количество срезов зависит от требуемой точности и наличия «линий разломов» геохеша). Это особенно полезно в системах баз данных, где запросы по одному индексу намного проще или быстрее, чем запросы с несколькими индексами. Во-вторых, эту структуру индекса можно использовать для быстрого поиска близости: самые близкие точки часто находятся среди ближайших геохешей.

Техническое описание

Формальное описание вычислительных и математических представлений.

Текстовое представление

Для точного перевода широты и долготы Geohash - это пространственный индекс из база 4, потому что он преобразует непрерывные пространственные координаты широты и долготы в иерархическую дискретную сетку, используя повторяющееся разделение пространства на четыре части. Чтобы быть компактным кодом, он использует база 32 и представляет свои значения следующим алфавитом, что является «стандартным текстовым представлением».

Десятичный0123456789101112131415
База 320123456789бcdежграмм
 
Десятичный16171819202122232425262728293031
База 32часjkмппqрsттыvшИксуz

В алфавите Geohash (32ghs) используются все цифры 0-9 и почти все строчные буквы, кроме «a», «i», «l» и «o».

Например, используя приведенную выше таблицу и константу , Geohash ezs42 может быть преобразовано в десятичное представление обычным позиционная запись:

[ezs42]32гс =
=
=
= =

Геометрическое представление

Геометрия Geohash имеет смешанное пространственное представление:

  • Геохеши с 2, 4, 6, ... е цифры (четное цифры) представлены Кривая Z-порядка в "регулярной сетке", где декодированная пара (широта, долгота) имеет однородную неопределенность, действительную как Geo URI.
  • Геохеши с 1, 3, 5, ... d цифры (нечетные цифры) представлены «кривой И-порядка». Широта и долгота декодированной пары имеют разную неопределенность (долгота усечена).
Geohash-OddEvenDigits.png
Кривая сетки из 32 ячеек была получена путем слияния 2 на 2 ячейки «следующего уровня» (сетка из 64 ячеек, проиллюстрированная здесь), чтобы получить геометрическое представление «нечетного Geohash».

Можно построить «кривую И-порядка» из Z-порядка, объединяя соседние ячейки и индексируя полученную прямоугольную сетку функцией j=этаж(я ÷ 2). На боковой иллюстрации показано, как получить сетку из 32 прямоугольных ячеек из сетки из 64 квадратных ячеек.

Самым важным свойством Geohash для человека является то, что он сохраняет пространственная иерархия в кодовые префиксы.
Например, на иллюстрации 32 прямоугольников "1-значная сетка Geohash" пространственная область кода е (прямоугольник серо-синего круга в позиции 4,3) сохраняется с префиксом е в "двузначной сетке" из 1024 прямоугольников (масштаб, показывающий Эм и серо-зеленые на синие круги на сетке).

Алгоритм и пример

Использование хеша ezs42 в качестве примера, вот как это декодируется в десятичные значения широты и долготы. Первый шаг - расшифровать его из текстового "база 32 гг.", как показано выше, для получения двоичного представления:

.

Эта операция приводит к биты 01101 11111 11000 00100 00010. Предполагая, что отсчет начинается с 0 в левой части, нечетные биты берутся для кода долготы (0111110000000), а за код широты (101111001001).

Затем каждый двоичный код используется в серии делений, рассматриваемых по одному биту за раз, снова слева направо. Для значения широты интервал от -90 до +90 делится на 2, в результате получается два интервала: от -90 до 0 и от 0 до +90. Поскольку первый бит равен 1, выбирается более высокий интервал, который становится текущим интервалом. Процедура повторяется для всех битов кода. Наконец, значение широты является центром результирующего интервала. Значения долготы обрабатываются аналогичным образом с учетом того, что начальный интервал составляет от -180 до +180.

Например, в коде широты 101111001001, первый бит равен 1, поэтому мы знаем, что наша широта находится где-то между 0 и 90. Без дополнительных битов мы бы предположили, что широта была 45, что дает нам ошибку ± 45. Поскольку доступно больше бит, мы можем продолжить со следующего бита, и каждый последующий бит уменьшает эту ошибку вдвое. В этой таблице показано влияние каждого бита. На каждом этапе соответствующая половина диапазона выделяется зеленым цветом; младший бит выбирает нижний диапазон, старший бит выбирает верхний диапазон.

Столбец «среднее значение» показывает широту, просто среднее значение диапазона. Каждый последующий бит делает это значение более точным.

Код широты 101111001001
битовая позициябитовое значениеминсерединаМаксимумсреднее значениемаксимальная ошибка
01-90.0000.00090.00045.00045.000
100.00045.00090.00022.50022.500
210.00022.50045.00033.75011.250
3122.50033.75045.00039.3755.625
4133.75039.37545.00042.1882.813
5139.37542.18845.00043.5941.406
6042.18843.59445.00042.8910.703
7042.18842.89143.59442.5390.352
8142.18842.53942.89142.7150.176
9042.53942.71542.89142.6270.088
10042.53942.62742.71542.5830.044
11142.53942.58342.62742.6050.022
Код долготы 0111110000000
битовая позициябитовое значениеминсерединаМаксимумсреднее значениемаксимальная ошибка
00-180.0000.000180.000-90.00090.000
11-180.000-90.0000.000-45.00045.000
21-90.000-45.0000.000-22.50022.500
31-45.000-22.5000.000-11.25011.250
41-22.500-11.2500.000-5.6255.625
51-11.250-5.6250.000-2.8132.813
60-5.625-2.8130.000-4.2191.406
70-5.625-4.219-2.813-4.9220.703
80-5.625-4.922-4.219-5.2730.352
90-5.625-5.273-4.922-5.4490.176
100-5.625-5.449-5.273-5.5370.088
110-5.625-5.537-5.449-5.5810.044
120-5.625-5.581-5.537-5.6030.022

(Для ясности числа в приведенной выше таблице округлены до 3 десятичных знаков)

Окончательное округление следует производить осторожно, чтобы

Таким образом, округление 42,605 до 42,61 или 42,6 является правильным, а округление до 43 - нет.

Цифры и точность в км

длина геохешалат битыlng битыошибка широтыlng ошибкакм ошибка
123±23±23±2500
255±2.8±5.6±630
378±0.70±0.70±78
41010±0.087±0.18±20
51213±0.022±0.022±2.4
61515±0.0027±0.0055±0.61
71718±0.00068±0.00068±0.076
82020±0.000085±0.00017±0.019

Ограничения при использовании для определения близости

Пограничные случаи

Геохеши можно использовать для поиска точек в непосредственной близости друг от друга на основе общего префикса. Тем не мение, край случай местоположения, расположенные близко друг к другу, но на противоположных сторонах меридиана 180 градусов, приведут к кодам Geohash без общего префикса (разные долготы для близких физических местоположений). Точки, близкие к северному и южному полюсам, будут иметь очень разные геохеши (разные долготы для близких к физическому местоположению).

Два близких места по обе стороны от экватора (или гринвичского меридиана) не будут иметь длинного общего префикса, так как они принадлежат разным «половинам» мира. Проще говоря, двоичная широта (или долгота) одного местоположения будет 011111 ... а другого 100000 ...., поэтому у них не будет общего префикса, и большинство битов будут перевернуты. Это также можно рассматривать как следствие того, что Кривая Z-порядка (который в данном случае более уместно назвать посещением N-го порядка) для упорядочивания точек, поскольку две близлежащие точки могут быть посещены в очень разное время. Однако две точки с длинным общим префиксом будут рядом.

Чтобы выполнить поиск по близости, можно вычислить юго-западный угол (низкий геохеш с низкой широтой и долготой) и северо-восточный угол (высокий геохеш с высокой широтой и долготой) ограничивающей рамки и выполнить поиск геохешей между этими двумя. Этот поиск найдет все точки на кривой z-порядка между двумя углами, которых может быть слишком много точек. Этот метод также не работает на 180 меридианах и полюсах. Solr использует список фильтров префиксов, вычисляя префиксы ближайших квадратов, близких к геохешу. [2].

Нелинейность

Поскольку геохеш (в этой реализации) основан на координаты долготы и широты расстояние между двумя геохэшами отражает расстояние в координатах широта / долгота между двумя точками, которое не переводится в фактическое расстояние, см. Формула гаверсина.

Пример нелинейности для системы широта-долгота:

  • На экваторе (0 градусов) длина градуса долготы составляет 111,320 км, а градуса широты - 110,574 км, ошибка 0,67%.
  • На 30 градусах (средние широты) ошибка составляет 110,852 / 96,486 = 14,89%.
  • На 60 градусах (высокая Арктика) ошибка составляет 111,412 / 55,800 = 99,67%, достигая бесконечности на полюсах.

Обратите внимание, что эти ограничения возникают не из-за геохеширования и не из-за координат широты и долготы, а из-за сложности отображения координат на сфере (нелинейной и с переносом значений, аналогично арифметике по модулю) в двумерные координаты и сложность однородного исследования двухмерного пространства. Первый связан с Географическая система координат и Проекция карты, а другой - Кривая Гильберта и кривая z-порядка. После того, как будет найдена система координат, которая представляет точки линейно по расстоянию и закручивается по краям и может быть исследована равномерно, применение геохеширования к этим координатам не будет страдать от вышеуказанных ограничений.

Хотя можно применить геохеширование к области с Декартова система координат, тогда он будет применяться только к области, где применяется система координат.

Несмотря на эти проблемы, есть возможные обходные пути, и алгоритм успешно используется в Elasticsearch,[7] MongoDB,[8] HBase, Redis,[9] и Accumulo[10] для осуществления поиска по близости.

Подобные системы индексации

Альтернативой хранению геохешей в виде строк в базе данных являются Коды местонахождения, которые также называются пространственными ключами и похожи на QuadTiles.[11][12]

В некоторых географические информационные системы и Большое количество данных пространственные базы данных, a Кривая Гильберта индексация на основе может использоваться как альтернатива Кривая Z-порядка, как в Библиотека геометрии S2.[13]

В 2019 году фронтенд разработали QA Locate[14] в том, что они назвали GeohashPhrase[15] использовать фразы для кодирования геохешей для облегчения общения через разговорный английский язык. Были планы сделать GeohashPhrase открытым.[16]

Лицензирование

Алгоритм Geohash был помещен в всеобщее достояние его изобретателем в публичном заявлении от 26 февраля 2008 г.[17]

Хотя сопоставимые алгоритмы были успешно запатентованы[18] и заявлены авторские права,[19][20] GeoHash основан на совершенно другом алгоритме и подходе.

Смотрите также

Рекомендации

  1. ^ а б Доказательства на Wayback Machine (также с Записи об этой статье за ​​2008 год):
  2. ^ а б Дж. М. Мортон (1966)«Компьютерная база геодезических данных и новый метод упорядочивания файлов». Отчет в IBM Canada.
  3. ^ «Geohash binary 64 bit» имеет классические решения, так как yinqiwen / geohash-int, и оптимизированные решения, как mmcloughlin / geohash-сборка.
  4. ^ Тибор Вукович (2016), "Hilbert-Geohash - хеширование данных географических точек с использованием кривой заполнения гильбертова пространства". https://pdfs.semanticscholar.org/d23c/996f44b1443fca76276ce8d37239fb8fd6f9.pdf
  5. ^ https://github.com/tammoippen/geohash-hilbert
  6. ^ geo_shape Тип данных в Elasticsearch
  7. ^ Геопространственное индексирование в MongoDB
  8. ^ [1]
  9. ^ Пространственно-временное индексирование в нереляционных распределенных базах данных
  10. ^ Пространственные ключи
  11. ^ QuadTiles
  12. ^ «Библиотека геометрии S2» для оптимизации пространственной индексации, https://s2geometry.io
  13. ^ "QA Locate | Сила точного определения местоположения". QA Locate. Получено 2020-06-10.
  14. ^ "GeohashPhrase". QA Locate. 2019-09-17. Получено 2020-06-10.
  15. ^ thelittlenag (11.11.2019). «В QA Locate мы работаем над решением, которое мы называем GeohashPhrase | Hacker News». news.ycombinator.com. Получено 2020-06-10.
  16. ^ Сообщение с объявлением geohash.org на форуме groundpeak.com
  17. ^ Компактное текстовое кодирование координат широты / долготы - Патент 20050023524
  18. ^ Нарушает ли Microsoft систему кодирования природных территорий? В архиве 2010-12-28 на Wayback Machine
  19. ^ Система кодирования природных территорий - юридические и лицензионные

внешняя ссылка