xy shape field type
An xy shape field type contains a shape, such as a polygon or a collection of xy points. It is based on the Lucene XYShape field type. To index an xy shape, Lucenia tessellates the shape into a triangular mesh and stores each triangle in a BKD tree (a set of balanced k-dimensional trees). This provides a 10-7decimal degree of precision, which represents near-perfect spatial resolution.
The xy shape field type is similar to the geoshape field type, but it represents shapes on the Cartesian plane, which is not based on the Earth-fixed terrestrial reference system. The coordinates of an xy shape are single-precision floating-point values. For information about the range and precision of floating-point values, see Numeric field types.
Example
Create a mapping with an xy shape field type:
PUT testindex
{
"mappings": {
"properties": {
"location": {
"type": "xy_shape"
}
}
}
}
Formats
xy shapes can be indexed in the following formats:
In both GeoJSON and WKT, the coordinates must be specified in the x, y
order within coordinate arrays.
xy shape types
The following table describes the possible xy shape types and their relationship to the GeoJSON and WKT types.
Lucenia type | GeoJSON type | WKT type | Description |
---|---|---|---|
point | Point | POINT | A geographic point specified by the x and y coordinates. |
linestring | LineString | LINESTRING | A line specified by two or more points. May be a straight line or a path of connected line segments. |
polygon | Polygon | POLYGON | A polygon specified by a list of vertices in coordinate form. The polygon must be closed, meaning the last point must be the same as the first point. Therefore, to create an n-gon, n+1 vertices are required. The minimum number of vertices is four, which creates a triangle. |
multipoint | MultiPoint | MULTIPOINT | An array of discrete related points that are not connected. |
multilinestring | MultiLineString | MULTILINESTRING | An array of linestrings. |
multipolygon | MultiPolygon | MULTIPOLYGON | An array of polygons. |
geometrycollection | GeometryCollection | GEOMETRYCOLLECTION | A collection of xy shapes that may be of different types. |
envelope | N/A | BBOX | A bounding rectangle specified by upper-left and lower-right vertices. |
Point
A point is specified by a single pair of coordinates.
Index a point in GeoJSON format:
PUT testindex/_doc/1
{
"location" : {
"type" : "point",
"coordinates" : [0.5, 4.5]
}
}
Index a point in WKT format:
PUT testindex/_doc/1
{
"location" : "POINT (0.5 4.5)"
}
Linestring
A linestring is a line specified by two or more points. If the points are collinear, the linestring is a straight line. Otherwise, the linestring represents a path made of line segments.
Index a linestring in GeoJSON format:
PUT testindex/_doc/2
{
"location" : {
"type" : "linestring",
"coordinates" : [[0.5, 4.5], [-1.5, 2.3]]
}
}
Index a linestring in WKT format:
PUT testindex/_doc/2
{
"location" : "LINESTRING (0.5 4.5, -1.5 2.3)"
}
Polygon
A polygon is specified by a list of vertices in coordinate form. The polygon must be closed, meaning the last point must be the same as the first point. In the following example, a triangle is created using four points.
GeoJSON requires that you list the vertices of the polygon counterclockwise. WKT does not impose a specific order on vertices.
Index a polygon (triangle) in GeoJSON format:
PUT testindex/_doc/3
{
"location" : {
"type" : "polygon",
"coordinates" : [
[[0.5, 4.5],
[2.5, 6.0],
[1.5, 2.0],
[0.5, 4.5]]
]
}
}
Index a polygon (triangle) in WKT format:
PUT testindex/_doc/3
{
"location" : "POLYGON ((0.5 4.5, 2.5 6.0, 1.5 2.0, 0.5 4.5))"
}
The polygon may have holes inside. In this case, the coordinates
field will contain multiple arrays. The first array represents the outer polygon, and each subsequent array represents a hole. Holes are represented as polygons and specified as arrays of coordinates.
GeoJSON requires that you list the vertices of the polygon counterclockwise and the vertices of the hole clockwise. WKT does not impose a specific order on vertices.
Index a polygon (triangle) with a triangular hole in GeoJSON format:
PUT testindex/_doc/4
{
"location" : {
"type" : "polygon",
"coordinates" : [
[[0.5, 4.5],
[2.5, 6.0],
[1.5, 2.0],
[0.5, 4.5]],
[[1.0, 4.5],
[1.5, 4.5],
[1.5, 4.0],
[1.0, 4.5]]
]
}
}
Index a polygon (triangle) with a triangular hole in WKT format:
PUT testindex/_doc/4
{
"location" : "POLYGON ((0.5 4.5, 2.5 6.0, 1.5 2.0, 0.5 4.5), (1.0 4.5, 1.5 4.5, 1.5 4.0, 1.0 4.5))"
}
By default, the vertices of the polygon are traversed in a counterclockwise order. You can define an orientation
parameter to specify the vertex traversal order at mapping time:
PUT testindex
{
"mappings": {
"properties": {
"location": {
"type": "xy_shape",
"orientation" : "left"
}
}
}
}
Subsequently indexed documents can override the orientation
setting:
PUT testindex/_doc/3
{
"location" : {
"type" : "polygon",
"orientation" : "cw",
"coordinates" : [
[[0.5, 4.5],
[2.5, 6.0],
[1.5, 2.0],
[0.5, 4.5]]
]
}
}
Multipoint
A multipoint is an array of discrete related points that are not connected.
Index a multipoint in GeoJSON format:
PUT testindex/_doc/6
{
"location" : {
"type" : "multipoint",
"coordinates" : [
[0.5, 4.5],
[2.5, 6.0]
]
}
}
Index a multipoint in WKT format:
PUT testindex/_doc/6
{
"location" : "MULTIPOINT (0.5 4.5, 2.5 6.0)"
}
Multilinestring
A multilinestring is an array of linestrings.
Index a multilinestring in GeoJSON format:
PUT testindex/_doc/2
{
"location" : {
"type" : "multilinestring",
"coordinates" : [
[[0.5, 4.5], [2.5, 6.0]],
[[1.5, 2.0], [3.5, 3.5]]
]
}
}
Index a linestring in WKT format:
PUT testindex/_doc/2
{
"location" : "MULTILINESTRING ((0.5 4.5, 2.5 6.0), (1.5 2.0, 3.5 3.5))"
}
Multipolygon
A multipolygon is an array of polygons. In this example, the first polygon contains a hole, and the second does not.
Index a multipolygon in GeoJSON format:
PUT testindex/_doc/4
{
"location" : {
"type" : "multipolygon",
"coordinates" : [
[
[[0.5, 4.5],
[2.5, 6.0],
[1.5, 2.0],
[0.5, 4.5]],
[[1.0, 4.5],
[1.5, 4.5],
[1.5, 4.0],
[1.0, 4.5]]
],
[
[[2.0, 0.0],
[1.0, 2.0],
[3.0, 1.0],
[2.0, 0.0]]
]
]
}
}
Index a multipolygon in WKT format:
PUT testindex/_doc/4
{
"location" : "MULTIPOLYGON (((0.5 4.5, 2.5 6.0, 1.5 2.0, 0.5 4.5), (1.0 4.5, 1.5 4.5, 1.5 4.0, 1.0 4.5)), ((2.0 0.0, 1.0 2.0, 3.0 1.0, 2.0 0.0)))"
}
Geometry collection
A geometry collection is a collection of xy shapes that may be of different types.
Index a geometry collection in GeoJSON format:
PUT testindex/_doc/7
{
"location" : {
"type": "geometrycollection",
"geometries": [
{
"type": "point",
"coordinates": [0.5, 4.5]
},
{
"type": "linestring",
"coordinates": [[2.5, 6.0], [1.5, 2.0]]
}
]
}
}
Index a geometry collection in WKT format:
PUT testindex/_doc/7
{
"location" : "GEOMETRYCOLLECTION (POINT (0.5 4.5), LINESTRING(2.5 6.0, 1.5 2.0))"
}
Envelope
An envelope is a bounding rectangle specified by upper-left and lower-right vertices. The GeoJSON format is [[minX, maxY], [maxX, minY]]
.
Index an envelope in GeoJSON format:
PUT testindex/_doc/2
{
"location" : {
"type" : "envelope",
"coordinates" : [[3.0, 2.0], [6.0, 0.0]]
}
}
In WKT format, use BBOX (minX, maxY, maxX, minY)
.
Index an envelope in WKT BBOX format:
PUT testindex/_doc/8
{
"location" : "BBOX (3.0, 2.0, 6.0, 0.0)"
}
Parameters
The following table lists the parameters accepted by xy shape field types. All parameters are optional.
Parameter | Description |
---|---|
coerce | A Boolean value that specifies whether to automatically close unclosed linear rings. Default is false . |
ignore_malformed | A Boolean value that specifies to ignore malformed GeoJSON or WKT xy shapes and not to throw an exception. Default is false (throw an exception when xy shapes are malformed). |
ignore_z_value | Specific to points with three coordinates. If ignore_z_value is true , the third coordinate is not indexed but is still stored in the _source field. If ignore_z_value is false , an exception is thrown. Default is true . |
orientation | Specifies the traversal order of the vertices in the xy shape’s list of coordinates. orientation takes the following values: 1. RIGHT: counterclockwise. Specify RIGHT orientation by using one of the following strings (uppercase or lowercase): right , counterclockwise , ccw . 2. LEFT: clockwise. Specify LEFT orientation by using one of the following strings (uppercase or lowercase): left , clockwise , cw . This value can be overridden by individual documents.Default is RIGHT . |