xy shape field type

    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 .

    Create a mapping with an xy shape field type:

    copy

    Formats

    xy shapes can be indexed in the following formats:

    In both GeoJSON and WKT, the coordinates must be specified in the 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.

    Point

    A point is specified by a single pair of coordinates.

    Index a point in GeoJSON format:

    1. PUT testindex/_doc/1
    2. {
    3. "location" : {
    4. "type" : "point",
    5. "coordinates" : [0.5, 4.5]
    6. }
    7. }

    copy

    Index a point in WKT format:

    1. PUT testindex/_doc/1
    2. {
    3. "location" : "POINT (0.5 4.5)"
    4. }

    copy

    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:

    1. PUT testindex/_doc/2
    2. {
    3. "location" : {
    4. "type" : "linestring",
    5. "coordinates" : [[0.5, 4.5], [-1.5, 2.3]]
    6. }
    7. }

    copy

    Index a linestring in WKT format:

    1. PUT testindex/_doc/2
    2. {
    3. "location" : "LINESTRING (0.5 4.5, -1.5 2.3)"
    4. }

    copy

    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:

    1. PUT testindex/_doc/3
    2. {
    3. "location" : {
    4. "type" : "polygon",
    5. "coordinates" : [
    6. [[0.5, 4.5],
    7. [2.5, 6.0],
    8. [1.5, 2.0],
    9. [0.5, 4.5]]
    10. ]
    11. }
    12. }

    Index a polygon (triangle) in WKT format:

    1. PUT testindex/_doc/3
    2. {
    3. "location" : "POLYGON ((0.5 4.5, 2.5 6.0, 1.5 2.0, 0.5 4.5))"
    4. }

    copy

    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:

    copy

    Index a polygon (triangle) with a triangular hole in WKT format:

    1. PUT testindex/_doc/4
    2. {
    3. }

    copy

    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:

    1. PUT testindex
    2. {
    3. "mappings": {
    4. "properties": {
    5. "location": {
    6. "type": "xy_shape",
    7. "orientation" : "left"
    8. }
    9. }
    10. }
    11. }

    copy

    Subsequently indexed documents can override the orientation setting:

    1. PUT testindex/_doc/3
    2. {
    3. "type" : "polygon",
    4. "orientation" : "cw",
    5. "coordinates" : [
    6. [[0.5, 4.5],
    7. [2.5, 6.0],
    8. [1.5, 2.0],
    9. [0.5, 4.5]]
    10. ]
    11. }
    12. }

    copy

    Multipoint

    A multipoint is an array of discrete related points that are not connected.

    Index a multipoint in GeoJSON format:

    1. PUT testindex/_doc/6
    2. {
    3. "location" : {
    4. "type" : "multipoint",
    5. "coordinates" : [
    6. [0.5, 4.5],
    7. [2.5, 6.0]
    8. ]
    9. }
    10. }

    copy

    Index a multipoint in WKT format:

    1. PUT testindex/_doc/6
    2. {
    3. "location" : "MULTIPOINT (0.5 4.5, 2.5 6.0)"
    4. }

    copy

    Multilinestring

    A multilinestring is an array of linestrings.

    Index a multilinestring in GeoJSON format:

    1. PUT testindex/_doc/2
    2. {
    3. "location" : {
    4. "type" : "multilinestring",
    5. "coordinates" : [
    6. [[0.5, 4.5], [2.5, 6.0]],
    7. [[1.5, 2.0], [3.5, 3.5]]
    8. ]
    9. }
    10. }

    Index a linestring in WKT format:

    copy

    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:

    1. PUT testindex/_doc/4
    2. {
    3. "location" : {
    4. "type" : "multipolygon",
    5. "coordinates" : [
    6. [[0.5, 4.5],
    7. [2.5, 6.0],
    8. [1.5, 2.0],
    9. [0.5, 4.5]],
    10. [[1.0, 4.5],
    11. [1.5, 4.5],
    12. [1.5, 4.0],
    13. [1.0, 4.5]]
    14. ],
    15. [
    16. [[2.0, 0.0],
    17. [1.0, 2.0],
    18. [3.0, 1.0],
    19. [2.0, 0.0]]
    20. ]
    21. ]
    22. }

    copy

    Index a multipolygon in WKT format:

    1. PUT testindex/_doc/4
    2. {
    3. "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)))"
    4. }

    copy

    Geometry collection

    A geometry collection is a collection of xy shapes that may be of different types.

    Index a geometry collection in GeoJSON format:

    1. PUT testindex/_doc/7
    2. {
    3. "location" : {
    4. "type": "geometrycollection",
    5. "geometries": [
    6. {
    7. "type": "point",
    8. "coordinates": [0.5, 4.5]
    9. },
    10. {
    11. "type": "linestring",
    12. "coordinates": [[2.5, 6.0], [1.5, 2.0]]
    13. }
    14. ]
    15. }
    16. }

    copy

    Index a geometry collection in WKT format:

    1. PUT testindex/_doc/7
    2. {
    3. "location" : "GEOMETRYCOLLECTION (POINT (0.5 4.5), LINESTRING(2.5 6.0, 1.5 2.0))"
    4. }

    copy

    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:

    1. PUT testindex/_doc/2
    2. {
    3. "location" : {
    4. "type" : "envelope",
    5. "coordinates" : [[3.0, 2.0], [6.0, 0.0]]
    6. }
    7. }

    copy

    In WKT format, use BBOX (minX, maxY, maxX, minY).

    Index an envelope in WKT BBOX format:

    1. PUT testindex/_doc/8
    2. {
    3. "location" : "BBOX (3.0, 2.0, 6.0, 0.0)"
    4. }

    copy

    Parameters

    The following table lists the parameters accepted by xy shape field types. All parameters are optional.

    ParameterDescription
    coerceA Boolean value that specifies whether to automatically close unclosed linear rings. Default is false.
    ignore_malformedA 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_valueSpecific 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.
    orientationSpecifies 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.