Общеизвестное текстовое представление геометрии - Well-known text representation of geometry
Известный текст (WKT) это текст язык разметки для представления вектор геометрия объекты. А двоичный эквивалент, известный как хорошо известный двоичный (WKB) используется для передачи и хранения той же информации в более компактной форме, удобной для компьютерной обработки, но не читаемой человеком. Форматы были изначально определены Открытый геопространственный консорциум (OGC) и описаны в их Простой доступ к функциям.[1] Текущее стандартное определение содержится в стандарте ISO / IEC 13249-3: 2016.[2]
Геометрические объекты
WKT может представлять следующие различные геометрические объекты:
- Точка, MultiPoint
- LineString, MultiLineString
- Многоугольник, Мультиполигон, Треугольник
- МногогранникПоверхность
- БАНКА (Триангулированная нерегулярная сеть )
- GeometryCollection
Координаты геометрии могут быть двухмерными (Икс, у), 3D (Икс, у, z), 4D (Икс, у, z, м) с м ценность, которая является частью линейная система привязки или 2D с м ценить (Икс, у, м). Трехмерные геометрии обозначаются буквой Z после типа геометрии, а геометрии - линейная система привязки иметь букву "M" после типа геометрии. Пустые геометрии, не содержащие координат, можно указать с помощью символа ПУСТОЙ
после названия типа.
Геометрия WKT используется во всех спецификациях OGC и присутствует в приложениях, реализующих эти спецификации. Например, PostGIS содержит функции, которые могут преобразовывать геометрию в представление WKT и обратно, делая их удобочитаемыми.
Стандартное определение OGC требует, чтобы полигон был топологически замкнутым. В нем также говорится, что если внешнее линейное кольцо многоугольника определено против часовой стрелки, оно будет видно «сверху». Любые внутренние линейные кольца следует определять противоположным образом по сравнению с внешним кольцом, в данном случае по часовой стрелке.[3]
Тип | Примеры | |
---|---|---|
Точка | ТОЧКА (30 10) | |
LineString | ЛАЙНЕСТРИНГ (30 10, 10 30, 40 40) | |
Многоугольник | ПОЛИГОН ((30 10, 40 40, 20 40, 10 20, 30 10)) | |
ПОЛИГОН ((35 10, 45 45, 15 40, 10 20, 35 10), |
Тип | Примеры | |
---|---|---|
MultiPoint | МНОГОТОЧКА ((10 40), (40 30), (20 20), (30 10)) | |
МНОГОТОЧКА (10 40, 40 30, 20 20, 30 10) | ||
MultiLineString | МУЛЬТИЛИНЭСТРИНГ ((10 10, 20 20, 10 40), | |
Мультиполигон | МУЛЬТИПОЛИГОН (((30 20, 45 40, 10 40, 30 20)), | |
МУЛЬТИПОЛИГОН (((40 40, 20 45, 45 30, 40 40)), | ||
GeometryCollection | ГЕОМЕТРИКОЛЛЕКЦИЯ (ТОЧКА (40 10), |
Ниже приведены некоторые другие примеры геометрических строк WKT: (Примечание: каждый элемент ниже представляет собой отдельную геометрию.)
ГЕОМЕТРИКОЛЛЕКЦИЯ (ТОЧКА (4 6), ЛИНИЯ (4 6,7 10)) ТОЧКА ZM (1 1 5 60) ТОЧКА M (1 1 80) ТОЧКА ПУСТОЙ МУЛЬТИПОЛИГОН ПУСТОЙ ТРЕУГОЛЬНИК ((0 0 0,0 1 0,1 1 0,0 0 0)) TIN (((0 0 0, 0 0 1, 0 1 0, 0 0 0)), ((0 0 0, 0 1 0, 1 1 0, 0 0 0))) ПОЛИГЕДРАЛЬНАЯ ПОВЕРХНОСТЬ Z (ПАТЧИ ((0 0 0, 0 1 0, 1 1 0, 1 0 0, 0 0 0)), ((0 0 0, 0 1 0, 0 1 1, 0 0 1, 0 0 0)), (( 0 0 0, 1 0 0, 1 0 1, 0 0 1, 0 0 0)), ((1 1 1, 1 0 1, 0 0 1, 0 1 1, 1 1 1)), ((1 1 1, 1 0 1, 1 0 0, 1 1 0, 1 1 1)), ((1 1 1, 1 1 0, 0 1 0, 0 1 1, 1 1 1)))
Хорошо известный двоичный файл
Хорошо известные двоичные (WKB) представления обычно показаны в шестнадцатеричный струны.
Первый байт указывает на порядок байтов для данных:
00
: big endian01
: little endian
Следующие 4 байта - это 32-битное целое число без знака для типа геометрии, как описано ниже:
Тип | 2D | Z | M | ZM |
---|---|---|---|---|
Геометрия | 0000 | 1000 | 2000 | 3000 |
Точка | 0001 | 1001 | 2001 | 3001 |
LineString | 0002 | 1002 | 2002 | 3002 |
Многоугольник | 0003 | 1003 | 2003 | 3003 |
MultiPoint | 0004 | 1004 | 2004 | 3004 |
MultiLineString | 0005 | 1005 | 2005 | 3005 |
Мультиполигон | 0006 | 1006 | 2006 | 3006 |
GeometryCollection | 0007 | 1007 | 2007 | 3007 |
CircularString | 0008 | 1008 | 2008 | 3008 |
CompoundCurve | 0009 | 1009 | 2009 | 3009 |
КриваяПолигон | 0010 | 1010 | 2010 | 3010 |
MultiCurve | 0011 | 1011 | 2011 | 3011 |
MultiSurface | 0012 | 1012 | 2012 | 3012 |
Изгиб | 0013 | 1013 | 2013 | 3013 |
Поверхность | 0014 | 1014 | 2014 | 3014 |
МногогранникПоверхность | 0015 | 1015 | 2015 | 3015 |
БАНКА | 0016 | 1016 | 2016 | 3016 |
Треугольник | 0017 | 1017 | 2017 | 3017 |
Круг | 0018 | 1018 | 2018 | 3018 |
GeodesicString | 0019 | 1019 | 2019 | 3019 |
Эллиптическая кривая | 0020 | 1020 | 2020 | 3020 |
NurbsCurve | 0021 | 1021 | 2021 | 3021 |
Клотоид | 0022 | 1022 | 2022 | 3022 |
SpiralCurve | 0023 | 1023 | 2023 | 3023 |
СоставПоверхность | 0024 | 1024 | 2024 | 3024 |
BrepSolid |
| 1025 |
|
|
AffinePlacement | 102 | 1102 |
|
|
Каждый тип данных имеет уникальную структуру данных, такую как количество точек или линейных колец, за которыми следуют координаты в 64-битный двойной числа.
Например, геометрия ТОЧКА (2,0 4,0)
представлен как: 000000000140000000000000004010000000000000
, куда:
- 1-байтовое целое число
00
или 0: с прямым порядком байтов - 4-байтовое целое число
00000001
или 1: ТОЧКА (2D) - 8-байтное число с плавающей запятой
4000000000000000
или 2.0: Икс-координат - 8-байтное число с плавающей запятой
4010000000000000
или 4.0: у-координат
Варианты формата
- EWKT и EWKB – Расширенный общеизвестный текст / двоичный файл
- А PostGIS -специфический формат, который включает идентификатор системы пространственной привязки (SRID) и до 4 значений ординат (XYZM).[4][5] Например:
SRID = 4326; ТОЧКА (-44,3 60,1)
найти координату долготы / широты с помощью WGS 84 справочная система координат. - Текст AGF – Autodesk Формат геометрии
- Расширение к OGC Стандарт (в то время), чтобы включать изогнутые элементы; наиболее заметно используется в MapGuide.[6]
Поддержка программного обеспечения
СУБД
- Amazon Redshift с 21 ноября 2019 г.[7]
- Apache Drill поддерживает полный спектр геопространственных запросов, начиная с версии 1.12, а также чтение файлов ESRI Shape (SHP).
- Apache Solr поисковый сервер предприятия с 4.0[8] через СТС
- Elasticsearch распределенная система поиска и аналитики RESTful с версии 6.2[9]
- Google BigQuery поддерживает географические информационные системы BigQuery с апреля 2019 года.
- GigaSpaces InsightEdge[10]
- PostgreSQL с PostGIS Модуль 2.0
- Кинетика База данных геопространственных данных с ускорением на GPU
- Oracle Spatial 9i, 10г, 11г
- OmniSci с 4.0
- MarkLogic Server с 4.2[11]
- MemSQL с 4[12]
- MySQL с 4.1[13]
- MariaDB, все версии
- Neo4j[14]
- OrientDB[15]
- IBM DB2 LUW 9, 10, 11.1 с пространственным удлинителем; 11.5 с помощью Spatial Analytics или Spatial Extender[16]
- IBM DB2 для z / OS 9, 10 с пространственной поддержкой
- IBM Netezza с Netezza Spatial
- IBM Informix 9,10,11 с модулем пространственных данных
- Microsoft SQL Server с 2008 R2[17]
- Snowflake Inc.
- SpatiaLite
- Терадата 6.1, 6.2, 12, 13 (встроенный в 13 через надстройку в предыдущих версиях)
- Ingres GeoSpatial
- Altibase 5.x
- SQL Anywhere 12
- SAP HANA SP07, SP08
- H2 с 1.3.173 (2013-07-28)[18]
- Vertica с 7.1.0[19]
- VoltDB начиная с V6.0[20]
API
- Библиотеки Boost C ++ (C ++): см. Геометрия io / wkt заголовки
- Esri geometry-api-java
- GEOS (C / C ++)
- Стройный (Python): см. Элегантная документация и Изящно в PyPI
- GeoPHP (PHP)
- ГДАЛ (C / C ++ с привязкой к Java, Python и др.)
- GeoRust: rust-wkt (Наручники из ржавчины)
- Пакет топологии JTS (Ява)
- Spatial4j (Ява)
- NetTopologySuite (.СЕТЬ)
- OpenLayers (JavaScript)
- OpenScales (ActionScript)
- Parsewkt (Python) - это парсер привязки от WKT к словарям Python
- пигеоиф (Python) анализирует wkt с помощью регулярных выражений
- rgeo (Рубин)
- нф (Р)
- Терраформер (JavaScript)
- WellKnownLib (C # .Net) Известный текстовый и двоичный синтаксический анализатор
Протоколы
Смотрите также
Рекомендации
- ^ Херринг, Джон Р., изд. (2011-05-28), Стандарт реализации OpenGIS® для географической информации - Простой доступ к функциям - Часть 1: Общая архитектура, Открытый геопространственный консорциум, получено 2019-01-28
- ^ Информационные технологии. Языки баз данных. Мультимедиа и пакеты приложений SQL. Часть 3. Пространственные. (5-е изд.), ISO, 2016-01-15, получено 2019-01-28
- ^ См. Географическую информацию в спецификации реализации OGC - простой доступ к функциям, раздел 6.1.11.1. http://www.opengeospatial.org/standards/sfa
- ^ https://github.com/postgis/postgis/blob/2.1.0/doc/ZMSgeoms.txt
- ^ http://postgis.org/docs/ST_GeomFromEWKT.html
- ^ http://e-logistic-plans.gdfsuez.com/mapguide/help/webapi/da/dc0/group___agf_text.htm
- ^ Amazon Redshift объявляет о поддержке пространственных данных
- ^ Поддержка Solr GEO
- ^ Тип ввода Well-Known Text (WKT) в документации Elasticsearch
- ^ «Геопространственные запросы». docs.gigaspaces.com. Получено 2020-06-02.
- ^ https://docs.marklogic.com/guide/search-dev/geospatial
- ^ http://docs.memsql.com/docs/geospatial-guide
- ^ Формат общеизвестного текста (WKT), Документация MySQL
- ^ https://neo4j-contrib.github.io/spatial/
- ^ https://orientdb.com/docs/3.1.x/indexing/Spatial-Index.html
- ^ https://www.ibm.com/support/knowledgecenter/SSEPGG_11.5.0/com.ibm.db2.luw.spatial.topics.doc/doc/db2sb03.html
- ^ https://docs.microsoft.com/en-us/previous-versions/sql/sql-server-2008-r2/bb933970(v=sql.105)
- ^ H2 создать документацию по пространственному индексу
- ^ «Примечания к выпуску HP Vertica 7.1.x». my.vertica.com. Получено 2018-03-21.
- ^ https://www.voltdb.com/company/press-releases/voltdb-adds-geospatial-query-support-industrys-innovative-fast-data-platform/