Methods
area
Compute the area of a geospatial value.
as_binary
Get the geometry as well-known bytes (WKB) without the SRID data.
as_ewkb
Get the geometry as well-known bytes (WKB) with the SRID data.
as_ewkt
Get the geometry as well-known text (WKT) with the SRID data.
as_text
Get the geometry as well-known text (WKT) without the SRID data.
azimuth
Return the angle in radians from the horizontal of the vector defined by the inputs.
buffer
Return all points whose distance from this geometry is less than or equal to radius
.
centroid
Returns the centroid of the geometry.
contains
Check if the geometry contains the right
.
contains_properly
Check if the first geometry contains the second one.
convert
Transform a geometry into a new SRID (CRS).
covered_by
Check if the first geometry is covered by the second one.
covers
Check if the first geometry covers the second one.
crosses
Check if the geometries have at least one, but not all, interior points in common.
d_fully_within
Check if self
is entirely within distance
from right
.
d_within
Check if self
is partially within distance
from right
.
difference
Return the difference of two geometries.
disjoint
Check if the geometries have no points in common.
distance
Compute the distance between two geospatial expressions.
end_point
Return the last point of a LINESTRING
geometry as a POINT
.
envelope
Returns a geometry representing the bounding box of self
.
flip_coordinates
Flip coordinates of a geometry so that x = y and y = x.
geo_equals
Check if the geometries are equal.
geometry_n
Get the 1-based Nth geometry of a multi geometry.
geometry_type
Get the type of a geometry.
intersection
Return the intersection of two geometries.
intersects
Check if the geometries share any points.
is_valid
Check if the geometry is valid.
length
Compute the length of a geospatial expression.
line_locate_point
Locate the distance a point falls along the length of a line.
line_merge
Merge a MultiLineString
into a LineString
.
line_substring
Clip a substring from a LineString.
max_distance
Returns the 2-dimensional max distance between two geometries in projected units.
n_points
Return the number of points in a geometry. Works for all geometries.
n_rings
Return the number of rings for polygons and multipolygons.
ordering_equals
Check if two geometries are equal and have the same point ordering.
overlaps
Check if the geometries share space, have the same dimension, and are not completely contained by each other.
perimeter
Compute the perimeter of a geospatial expression.
point_n
Return the Nth point in a single linestring in the geometry.
set_srid
Set the spatial reference identifier for the ST_Geometry
.
simplify
Simplify a given geometry.
srid
Return the spatial reference identifier for the ST_Geometry.
start_point
Return the first point of a LINESTRING
geometry as a POINT
.
touches
Check if the geometries have at least one point in common, but do not intersect.
transform
Transform a geometry into a new SRID.
union
Merge two geometries into a union geometry.
within
Check if the first geometry is completely inside of the second.
x
Return the X coordinate of self
, or NULL if not available.
x_max
Return the X maxima of a geometry.
x_min
Return the X minima of a geometry.
y
Return the Y coordinate of self
, or NULL if not available.
y_max
Return the Y maxima of a geometry.
y_min
Return the Y minima of a geometry.
area
Compute the area of a geospatial value.
Returns
FloatingValue
The area of self
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> t.geom.area()
┏━━━━━━━━━━━━━━━┓
┃ GeoArea(geom) ┃
┡━━━━━━━━━━━━━━━┩
│ float64 │
├───────────────┤
│ 7.903953e+07 │
│ 1.439095e+08 │
│ 3.168508e+07 │
│ 8.023733e+06 │
│ 5.041488e+07 │
│ 4.093479e+07 │
│ 3.934104e+07 │
│ 2.682802e+06 │
│ 3.416422e+07 │
│ 4.404143e+07 │
│ … │
└───────────────┘
as_binary
Get the geometry as well-known bytes (WKB) without the SRID data.
as_ewkb
Get the geometry as well-known bytes (WKB) with the SRID data.
as_ewkt
Get the geometry as well-known text (WKT) with the SRID data.
as_text
Get the geometry as well-known text (WKT) without the SRID data.
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> t.geom.as_text()
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ GeoAsText(geom) ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ string │
├──────────────────────────────────────────────────────────────────────────────────┤
│ POLYGON ((933100.9183527103 192536.08569720192, 933091.0114800561 192572.175261… │
│ MULTIPOLYGON (((1033269.2435912937 172126.0078125, 1033439.6426391453 170883.94… │
│ POLYGON ((1026308.7695066631 256767.6975403726, 1026495.5934945047 256638.61561… │
│ POLYGON ((992073.4667968601 203714.07598876953, 992068.6669922024 203711.502197… │
│ POLYGON ((935843.3104932606 144283.33585065603, 936046.5648079664 144173.417798… │
│ POLYGON ((966568.7466657609 158679.85468779504, 966615.255504474 158662.2924831… │
│ POLYGON ((1010804.2179628164 218919.64069513977, 1011049.1648243815 218914.0828… │
│ POLYGON ((1005482.2763733566 221686.46616631746, 1005304.8982993066 221499.1169… │
│ POLYGON ((1043803.993348822 216615.9250395149, 1043849.7083857208 216473.162647… │
│ POLYGON ((1044355.0717166215 190734.32089698315, 1044612.1216432452 190156.8184… │
│ … │
└──────────────────────────────────────────────────────────────────────────────────┘
azimuth
Return the angle in radians from the horizontal of the vector defined by the inputs.
Angle is computed clockwise from down-to-up on the clock: 12=0; 3=PI/2; 6=PI; 9=3PI/2.
buffer
Return all points whose distance from this geometry is less than or equal to radius
.
Calculations are in the Spatial Reference System of this Geometry.
Parameters
radius
float | ir
.FloatingValue
Floating expression
required
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> p = t.x_cent.point(t.y_cent)
>>> p.buffer (10 ) # note buff.area.mean() ~ pi * r^2
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ GeoBuffer(GeoPoint(x_cent, y_cent), 10.0) ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ geospatial:geometry │
├──────────────────────────────────────────────────────────────────────────────────┤
│ < POLYGON (( 936006.821 191376.75 , 936006.629 191374.799 , 936006.06 191372.923 ... > │
│ < POLYGON (( 1031095.719 164018.754 , 1031095.526 164016.803 , 1031094.957 16401 ... > │
│ < POLYGON (( 1026462.617 254265.479 , 1026462.425 254263.528 , 1026461.856 25426 ... > │
│ < POLYGON (( 990643.981 202959.782 , 990643.788 202957.831 , 990643.219 202955.9 ... > │
│ < POLYGON (( 931881.37 140681.351 , 931881.178 140679.4 , 931880.609 140677.525 , ... > │
│ < POLYGON (( 964329.735 157998.936 , 964329.543 157996.985 , 964328.974 157995.1 ... > │
│ < POLYGON (( 1006506.679 216719.218 , 1006506.487 216717.267 , 1006505.918 21671 ... > │
│ < POLYGON (( 1005561.571 222936.088 , 1005561.379 222934.137 , 1005560.81 222932 ... > │
│ < POLYGON (( 1043012.677 212969.849 , 1043012.485 212967.898 , 1043011.916 21296 ... > │
│ < POLYGON (( 1042233.605 186706.496 , 1042233.413 186704.546 , 1042232.844 18670 ... > │
│ … │
└──────────────────────────────────────────────────────────────────────────────────┘
centroid
Returns the centroid of the geometry.
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> t.geom.centroid()
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ GeoCentroid(geom) ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ point:geometry │
├──────────────────────────────────┤
│ < POINT ( 935996.821 191376.75 ) > │
│ < POINT ( 1031085.719 164018.754 ) > │
│ < POINT ( 1026452.617 254265.479 ) > │
│ < POINT ( 990633.981 202959.782 ) > │
│ < POINT ( 931871.37 140681.351 ) > │
│ < POINT ( 964319.735 157998.936 ) > │
│ < POINT ( 1006496.679 216719.218 ) > │
│ < POINT ( 1005551.571 222936.088 ) > │
│ < POINT ( 1043002.677 212969.849 ) > │
│ < POINT ( 1042223.605 186706.496 ) > │
│ … │
└──────────────────────────────────┘
contains
Check if the geometry contains the right
.
Returns
BooleanValue
Whether self
contains right
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> import shapely
>>> t = ibis.examples.zones.fetch()
>>> p = shapely.Point(935996.821 , 191376.75 ) # centroid for zone 1
>>> plit = ibis.literal(p, "geometry" )
>>> t.geom.contains(plit).name("contains" )
┏━━━━━━━━━━┓
┃ contains ┃
┡━━━━━━━━━━┩
│ boolean │
├──────────┤
│ True │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ … │
└──────────┘
contains_properly
Check if the first geometry contains the second one.
Excludes common border points.
Returns
BooleanValue
Whether self contains right excluding border points.
convert
Transform a geometry into a new SRID (CRS).
Coordinates are assumed to always be XY (Longitude-Latitude).
Parameters
source
ir
.StringValue
CRS/SRID of input geometry
required
target
ir
.StringValue
| ir
.IntegerValue
Target CRS/SRID
required
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
Data is originally in epsg:2263
>>> t.geom.convert("EPSG:2263" , "EPSG:4326" )
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ GeoConvert(geom) ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ geospatial:geometry │
├──────────────────────────────────────────────────────────────────────────────────┤
│ < POLYGON (( -74.184 40.695 , -74.184 40.695 , -74.184 40.695 , -74.184 40.696 , - ... > │
│ < MULTIPOLYGON ((( -73.823 40.639 , -73.823 40.636 , -73.823 40.635 , -73.823 40 ... . > │
│ < POLYGON (( -73.848 40.871 , -73.847 40.871 , -73.847 40.871 , -73.846 40.871 , - ... > │
│ < POLYGON (( -73.972 40.726 , -73.972 40.726 , -73.972 40.726 , -73.972 40.726 , - ... > │
│ < POLYGON (( -74.174 40.563 , -74.173 40.562 , -74.172 40.562 , -74.172 40.562 , - ... > │
│ < POLYGON (( -74.064 40.602 , -74.064 40.602 , -74.064 40.603 , -74.065 40.604 , - ... > │
│ < POLYGON (( -73.904 40.768 , -73.903 40.768 , -73.903 40.768 , -73.903 40.768 , - ... > │
│ < POLYGON (( -73.923 40.775 , -73.924 40.775 , -73.925 40.775 , -73.925 40.775 , - ... > │
│ < POLYGON (( -73.785 40.761 , -73.785 40.761 , -73.785 40.76 , -73.784 40.76 , -73 ... > │
│ < POLYGON (( -73.783 40.69 , -73.782 40.688 , -73.781 40.689 , -73.781 40.687 , -7 ... > │
│ … │
└──────────────────────────────────────────────────────────────────────────────────┘
covered_by
Check if the first geometry is covered by the second one.
Returns
BooleanValue
Whether self
is covered by right
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> import shapely
>>> t = ibis.examples.zones.fetch()
Polygon area center in zone 1
>>> pol_big = shapely.Point(935996.821 , 191376.75 ).buffer (10000 )
>>> pol_big_lit = ibis.literal(pol_big, "geometry" )
>>> t.geom.covered_by(pol_big_lit).name("covered_by" )
┏━━━━━━━━━━━━┓
┃ covered_by ┃
┡━━━━━━━━━━━━┩
│ boolean │
├────────────┤
│ True │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ … │
└────────────┘
>>> pol_small = shapely.Point(935996.821 , 191376.75 ).buffer (100 )
>>> pol_small_lit = ibis.literal(pol_small, "geometry" )
>>> t.geom.covered_by(pol_small_lit).name("covered_by" )
┏━━━━━━━━━━━━┓
┃ covered_by ┃
┡━━━━━━━━━━━━┩
│ boolean │
├────────────┤
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ … │
└────────────┘
covers
Check if the first geometry covers the second one.
Returns
BooleanValue
Whether self
covers right
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> import shapely
>>> t = ibis.examples.zones.fetch()
Polygon area center in zone 1
>>> z1_ctr_buff = shapely.Point(935996.821 , 191376.75 ).buffer (10 )
>>> z1_ctr_buff_lit = ibis.literal(z1_ctr_buff, "geometry" )
>>> t.geom.covers(z1_ctr_buff_lit).name("covers" )
┏━━━━━━━━━┓
┃ covers ┃
┡━━━━━━━━━┩
│ boolean │
├─────────┤
│ True │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ … │
└─────────┘
crosses
Check if the geometries have at least one, but not all, interior points in common.
Returns
BooleanValue
Whether self
and right
have at least one common interior point.
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> import shapely
>>> t = ibis.examples.zones.fetch()
Line from center of zone 1 to center of zone 2
>>> line = shapely.LineString([[935996.821 , 191376.75 ], [1031085.719 , 164018.754 ]])
>>> line_lit = ibis.literal(line, "geometry" )
>>> t.geom.crosses(line_lit).name("crosses" )
┏━━━━━━━━━┓
┃ crosses ┃
┡━━━━━━━━━┩
│ boolean │
├─────────┤
│ True │
│ True │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ … │
└─────────┘
>>> t.filter (t.geom.crosses(line_lit))[["zone" , "LocationID" ]]
┏━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━┓
┃ zone ┃ LocationID ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━┩
│ string │ int32 │
├────────────────────────┼────────────┤
│ Newark Airport │ 1 │
│ Jamaica Bay │ 2 │
│ Canarsie │ 39 │
│ East Flatbush/Farragut │ 71 │
│ Erasmus │ 85 │
│ Flatbush/Ditmas Park │ 89 │
│ Flatlands │ 91 │
│ Green-Wood Cemetery │ 111 │
│ Sunset Park West │ 228 │
│ Windsor Terrace │ 257 │
└────────────────────────┴────────────┘
d_fully_within
d_fully_within(right, distance)
Check if self
is entirely within distance
from right
.
Parameters
right
GeoSpatialValue
Right geometry
required
distance
ir
.FloatingValue
Distance to check
required
Returns
BooleanValue
Whether self
is within a specified distance from right
.
d_within
d_within(right, distance)
Check if self
is partially within distance
from right
.
Parameters
right
GeoSpatialValue
Right geometry
required
distance
ir
.FloatingValue
Distance to check
required
Returns
BooleanValue
Whether self
is partially within distance
from right
.
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> import shapely
>>> t = ibis.examples.zones.fetch()
>>> penn_station = shapely.Point(986345.399 , 211974.446 )
>>> penn_lit = ibis.literal(penn_station, "geometry" )
Check zones within 1000ft of Penn Station centroid
>>> t.geom.d_within(penn_lit, 1000 ).name("d_within_1000" )
┏━━━━━━━━━━━━━━━┓
┃ d_within_1000 ┃
┡━━━━━━━━━━━━━━━┩
│ boolean │
├───────────────┤
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ … │
└───────────────┘
>>> t.filter (t.geom.d_within(penn_lit, 1000 ))[["zone" ]]
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ zone ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ string │
├──────────────────────────────┤
│ East Chelsea │
│ Midtown South │
│ Penn Station/Madison Sq West │
└──────────────────────────────┘
difference
Return the difference of two geometries.
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> t.geom.difference(t.geom.centroid())
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ GeoDifference(geom, GeoCentroid(geom)) ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ geospatial:geometry │
├──────────────────────────────────────────────────────────────────────────────────┤
│ < POLYGON (( 933091.011 192572.175 , 933088.585 192604.97 , 933121.56 192857.382 ... > │
│ < MULTIPOLYGON ((( 1033439.643 170883.946 , 1033473.265 170808.208 , 1033504.66 ... > │
│ < POLYGON (( 1026495.593 256638.616 , 1026567.23 256589.859 , 1026729.235 256481 ... > │
│ < POLYGON (( 992068.667 203711.502 , 992061.716 203711.772 , 992049.866 203627.2 ... > │
│ < POLYGON (( 936046.565 144173.418 , 936387.922 143967.756 , 936481.134 143911.7 ... > │
│ < POLYGON (( 966615.256 158662.292 , 966524.882 158822.266 , 966153.394 159414.4 ... > │
│ < POLYGON (( 1011049.165 218914.083 , 1011117.534 218916.104 , 1011186.09 218913 ... > │
│ < POLYGON (( 1005304.898 221499.117 , 1004958.187 221747.929 , 1004935.368 22176 ... > │
│ < POLYGON (( 1043849.708 216473.163 , 1043900.798 216332.234 , 1043957.136 21619 ... > │
│ < POLYGON (( 1044612.122 190156.818 , 1044849.742 190262.973 , 1045120.559 18965 ... > │
│ … │
└──────────────────────────────────────────────────────────────────────────────────┘
disjoint
Check if the geometries have no points in common.
Returns
BooleanValue
Whether self
and right
are disjoint
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> import shapely
>>> t = ibis.examples.zones.fetch()
>>> p = shapely.Point(935996.821 , 191376.75 ) # zone 1 centroid
>>> plit = ibis.literal(p, "geometry" )
>>> t.geom.disjoint(plit).name("disjoint" )
┏━━━━━━━━━━┓
┃ disjoint ┃
┡━━━━━━━━━━┩
│ boolean │
├──────────┤
│ False │
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ … │
└──────────┘
distance
Compute the distance between two geospatial expressions.
Returns
FloatingValue
Distance between self
and right
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> import shapely
>>> t = ibis.examples.zones.fetch()
Penn station zone centroid
>>> penn_station = shapely.Point(986345.399 , 211974.446 )
>>> penn_lit = ibis.literal(penn_station, "geometry" )
>>> t.geom.distance(penn_lit).name("distance_penn" )
┏━━━━━━━━━━━━━━━┓
┃ distance_penn ┃
┡━━━━━━━━━━━━━━━┩
│ float64 │
├───────────────┤
│ 47224.139856 │
│ 55992.665470 │
│ 54850.880098 │
│ 8011.846870 │
│ 84371.995209 │
│ 54196.904809 │
│ 15965.509896 │
│ 20566.442476 │
│ 54070.543584 │
│ 56994.826531 │
│ … │
└───────────────┘
end_point
Return the last point of a LINESTRING
geometry as a POINT
.
Return NULL
if the input parameter is not a LINESTRING
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> con = ibis.get_backend()
>>> con.load_extension("spatial" )
>>> import shapely
>>> line = shapely.LineString([[0 , 0 ], [1 , 0 ], [1 , 1 ]])
>>> line_lit = ibis.literal(line, type = "geometry" )
>>> line_lit.end_point()
┌───────────────┐
│ < POINT ( 1 1 ) > │
└───────────────┘
envelope
Returns a geometry representing the bounding box of self
.
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> t.geom.envelope()
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ GeoEnvelope(geom) ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ polygon:geometry │
├──────────────────────────────────────────────────────────────────────────────────┤
│ < POLYGON (( 931553.491 183788.05 , 941810.009 183788.05 , 941810.009 197256.211 ... > │
│ < POLYGON (( 1018052.359 151230.391 , 1049019.806 151230.391 , 1049019.806 17247 ... > │
│ < POLYGON (( 1022540.66 251648.652 , 1031732.164 251648.652 , 1031732.164 257811 ... > │
│ < POLYGON (( 988733.885 201170.618 , 992114.154 201170.618 , 992114.154 205029.4 ... > │
│ < POLYGON (( 927766.539 134554.848 , 936499.881 134554.848 , 936499.881 145354.2 ... > │
│ < POLYGON (( 958451.703 153868.426 , 969746.332 153868.426 , 969746.332 161198.9 ... > │
│ < POLYGON (( 1001260.812 213309.301 , 1011389.066 213309.301 , 1011389.066 21982 ... > │
│ < POLYGON (( 1004114.386 221499.117 , 1006968.78 221499.117 , 1006968.78 224422 ... . > │
│ < POLYGON (( 1040414.414 208318.344 , 1046392.971 208318.344 , 1046392.971 22002 ... > │
│ < POLYGON (( 1038120.442 182170.756 , 1047431.161 182170.756 , 1047431.161 19073 ... > │
│ … │
└──────────────────────────────────────────────────────────────────────────────────┘
flip_coordinates
Flip coordinates of a geometry so that x = y and y = x.
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> t.geom.centroid().flip_coordinates()
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ GeoFlipCoordinates(GeoCentroid(geom)) ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ geospatial:geometry │
├───────────────────────────────────────┤
│ < POINT ( 191376.75 935996.821 ) > │
│ < POINT ( 164018.754 1031085.719 ) > │
│ < POINT ( 254265.479 1026452.617 ) > │
│ < POINT ( 202959.782 990633.981 ) > │
│ < POINT ( 140681.351 931871.37 ) > │
│ < POINT ( 157998.936 964319.735 ) > │
│ < POINT ( 216719.218 1006496.679 ) > │
│ < POINT ( 222936.088 1005551.571 ) > │
│ < POINT ( 212969.849 1043002.677 ) > │
│ < POINT ( 186706.496 1042223.605 ) > │
│ … │
└───────────────────────────────────────┘
geo_equals
Check if the geometries are equal.
Returns
BooleanValue
Whether self
equals right
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> t.geom.geo_equals(t.geom)
┏━━━━━━━━━━━━━━━━━━━━━━━┓
┃ GeoEquals(geom, geom) ┃
┡━━━━━━━━━━━━━━━━━━━━━━━┩
│ boolean │
├───────────────────────┤
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ … │
└───────────────────────┘
geometry_n
Get the 1-based Nth geometry of a multi geometry.
Parameters
n
int | ir
.IntegerValue
Nth geometry index
required
geometry_type
Get the type of a geometry.
Returns
StringValue
String representing the type of self
.
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> t.geom.geometry_type()
┏━━━━━━━━━━━━━━━━━━━━━━━┓
┃ GeoGeometryType(geom) ┃
┡━━━━━━━━━━━━━━━━━━━━━━━┩
│ string │
├───────────────────────┤
│ POLYGON │
│ MULTIPOLYGON │
│ POLYGON │
│ POLYGON │
│ POLYGON │
│ POLYGON │
│ POLYGON │
│ POLYGON │
│ POLYGON │
│ POLYGON │
│ … │
└───────────────────────┘
intersection
Return the intersection of two geometries.
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> t.geom.intersection(t.geom.centroid())
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ GeoIntersection(geom, GeoCentroid(geom)) ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ geospatial:geometry │
├──────────────────────────────────────────┤
│ < POINT ( 935996.821 191376.75 ) > │
│ < POINT ( 1031085.719 164018.754 ) > │
│ < POINT ( 1026452.617 254265.479 ) > │
│ < POINT ( 990633.981 202959.782 ) > │
│ < POINT ( 931871.37 140681.351 ) > │
│ < POINT ( 964319.735 157998.936 ) > │
│ < POINT ( 1006496.679 216719.218 ) > │
│ < POINT ( 1005551.571 222936.088 ) > │
│ < POINT ( 1043002.677 212969.849 ) > │
│ < POINT ( 1042223.605 186706.496 ) > │
│ … │
└──────────────────────────────────────────┘
intersects
Check if the geometries share any points.
Returns
BooleanValue
Whether self
intersects right
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> import shapely
>>> t = ibis.examples.zones.fetch()
>>> p = shapely.Point(935996.821 , 191376.75 ) # zone 1 centroid
>>> plit = ibis.literal(p, "geometry" )
>>> t.geom.intersects(plit).name("intersects" )
┏━━━━━━━━━━━━┓
┃ intersects ┃
┡━━━━━━━━━━━━┩
│ boolean │
├────────────┤
│ True │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ … │
└────────────┘
is_valid
Check if the geometry is valid.
Returns
BooleanValue
Whether self
is valid
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> t.geom.is_valid()
┏━━━━━━━━━━━━━━━━━━┓
┃ GeoIsValid(geom) ┃
┡━━━━━━━━━━━━━━━━━━┩
│ boolean │
├──────────────────┤
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ True │
│ … │
└──────────────────┘
length
Compute the length of a geospatial expression.
Returns zero for polygons.
Returns
FloatingValue
Length of self
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> con = ibis.get_backend()
>>> con.load_extension("spatial" )
>>> import shapely
>>> line = shapely.LineString([[0 , 0 ], [1 , 0 ], [1 , 1 ]])
>>> line_lit = ibis.literal(line, type = "geometry" )
>>> line_lit.length()
>>> t = ibis.examples.zones.fetch()
>>> t.geom.length()
┏━━━━━━━━━━━━━━━━━┓
┃ GeoLength(geom) ┃
┡━━━━━━━━━━━━━━━━━┩
│ float64 │
├─────────────────┤
│ 0.0 │
│ 0.0 │
│ 0.0 │
│ 0.0 │
│ 0.0 │
│ 0.0 │
│ 0.0 │
│ 0.0 │
│ 0.0 │
│ 0.0 │
│ … │
└─────────────────┘
line_locate_point
Locate the distance a point falls along the length of a line.
Returns a float between zero and one representing the location of the closest point on the linestring to the given point, as a fraction of the total 2d line length.
Parameters
right
PointValue
Point geometry
required
Returns
FloatingValue
Fraction of the total line length
line_merge
Merge a MultiLineString
into a LineString
.
Returns a (set of) LineString(s) formed by sewing together the constituent line work of a MultiLineString. If a geometry other than a LineString or MultiLineString is given, this will return an empty geometry collection.
line_substring
line_substring(start, end)
Clip a substring from a LineString.
Returns a linestring that is a substring of the input one, starting and ending at the given fractions of the total 2d length. The second and third arguments are floating point values between zero and one. This only works with linestrings.
Parameters
start
ir
.FloatingValue
Start value
required
end
ir
.FloatingValue
End value
required
Returns
LineStringValue
Clipped linestring
max_distance
Returns the 2-dimensional max distance between two geometries in projected units.
If self
and right
are the same geometry the function will return the distance between the two vertices most far from each other in that geometry.
Returns
FloatingValue
Maximum distance
n_points
Return the number of points in a geometry. Works for all geometries.
Returns
IntegerValue
Number of points
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> t.geom.n_points()
┏━━━━━━━━━━━━━━━━━━┓
┃ GeoNPoints(geom) ┃
┡━━━━━━━━━━━━━━━━━━┩
│ int64 │
├──────────────────┤
│ 232 │
│ 2954 │
│ 121 │
│ 88 │
│ 170 │
│ 277 │
│ 182 │
│ 40 │
│ 189 │
│ 157 │
│ … │
└──────────────────┘
n_rings
Return the number of rings for polygons and multipolygons.
Outer rings are counted as well.
Returns
IntegerValue
Number of rings
ordering_equals
Check if two geometries are equal and have the same point ordering.
Returns true if the two geometries are equal and the coordinates are in the same order.
Returns
BooleanValue
Whether points and orderings are equal.
overlaps
Check if the geometries share space, have the same dimension, and are not completely contained by each other.
Returns
BooleanValue
Overlaps indicator
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> import shapely
>>> t = ibis.examples.zones.fetch()
Polygon center in an edge point of zone 1
>>> p_edge_buffer = shapely.Point(933100.918 , 192536.086 ).buffer (100 )
>>> buff_lit = ibis.literal(p_edge_buffer, "geometry" )
>>> t.geom.overlaps(buff_lit).name("overlaps" )
┏━━━━━━━━━━┓
┃ overlaps ┃
┡━━━━━━━━━━┩
│ boolean │
├──────────┤
│ True │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ … │
└──────────┘
perimeter
Compute the perimeter of a geospatial expression.
Returns
FloatingValue
Perimeter of self
point_n
Return the Nth point in a single linestring in the geometry.
Negative values are counted backwards from the end of the LineString, so that -1 is the last point. Returns NULL if there is no linestring in the geometry.
Parameters
n
ir
.IntegerValue
Nth point index
required
Returns
PointValue
Nth point in self
set_srid
Set the spatial reference identifier for the ST_Geometry
.
Parameters
srid
ir
.IntegerValue
SRID integer value
required
simplify
simplify(tolerance, preserve_collapsed)
Simplify a given geometry.
Parameters
tolerance
ir
.FloatingValue
Tolerance
required
preserve_collapsed
ir
.BooleanValue
Whether to preserve collapsed geometries
required
srid
Return the spatial reference identifier for the ST_Geometry.
start_point
Return the first point of a LINESTRING
geometry as a POINT
.
Return NULL
if the input parameter is not a LINESTRING
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> con = ibis.get_backend()
>>> con.load_extension("spatial" )
>>> import shapely
>>> line = shapely.LineString([[0 , 0 ], [1 , 0 ], [1 , 1 ]])
>>> line_lit = ibis.literal(line, type = "geometry" )
>>> line_lit.start_point()
┌───────────────┐
│ < POINT ( 0 0 ) > │
└───────────────┘
touches
Check if the geometries have at least one point in common, but do not intersect.
Returns
BooleanValue
Whether self and right are touching
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> import shapely
>>> t = ibis.examples.zones.fetch()
Edge point of zone 1
>>> p_edge = shapely.Point(933100.9183527103 , 192536.08569720192 )
>>> p_edge_lit = ibis.literal(p_edge, "geometry" )
>>> t.geom.touches(p_edge_lit).name("touches" )
┏━━━━━━━━━┓
┃ touches ┃
┡━━━━━━━━━┩
│ boolean │
├─────────┤
│ True │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ False │
│ … │
└─────────┘
union
Merge two geometries into a union geometry.
Returns the pointwise union of the two geometries.
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> import shapely
>>> t = ibis.examples.zones.fetch()
Penn station zone centroid
>>> penn_station = shapely.Point(986345.399 , 211974.446 )
>>> penn_lit = ibis.literal(penn_station, "geometry" )
>>> t.geom.centroid().union(penn_lit).name("union_centroid_penn" )
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ union_centroid_penn ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ geospatial:geometry │
├──────────────────────────────────────────────────────────────┤
│ < MULTIPOINT ( 935996.821 191376.75 , 986345.399 211974.446 ) > │
│ < MULTIPOINT ( 1031085.719 164018.754 , 986345.399 211974.446 ) > │
│ < MULTIPOINT ( 1026452.617 254265.479 , 986345.399 211974.446 ) > │
│ < MULTIPOINT ( 990633.981 202959.782 , 986345.399 211974.446 ) > │
│ < MULTIPOINT ( 931871.37 140681.351 , 986345.399 211974.446 ) > │
│ < MULTIPOINT ( 964319.735 157998.936 , 986345.399 211974.446 ) > │
│ < MULTIPOINT ( 1006496.679 216719.218 , 986345.399 211974.446 ) > │
│ < MULTIPOINT ( 1005551.571 222936.088 , 986345.399 211974.446 ) > │
│ < MULTIPOINT ( 1043002.677 212969.849 , 986345.399 211974.446 ) > │
│ < MULTIPOINT ( 1042223.605 186706.496 , 986345.399 211974.446 ) > │
│ … │
└──────────────────────────────────────────────────────────────┘
within
Check if the first geometry is completely inside of the second.
Returns
BooleanValue
Whether self
is in right
.
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> import shapely
>>> t = ibis.examples.zones.fetch()
>>> penn_station_buff = shapely.Point(986345.399 , 211974.446 ).buffer (5000 )
>>> penn_lit = ibis.literal(penn_station_buff, "geometry" )
>>> t.filter (t.geom.within(penn_lit))["zone" ]
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ zone ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ string │
├──────────────────────────────┤
│ East Chelsea │
│ Flatiron │
│ Garment District │
│ Midtown South │
│ Penn Station/Madison Sq West │
└──────────────────────────────┘
x
Return the X coordinate of self
, or NULL if not available.
Input must be a point.
Returns
FloatingValue
X coordinate of self
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> t.geom.centroid().x()
┏━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ GeoX(GeoCentroid(geom)) ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ float64 │
├─────────────────────────┤
│ 9.359968e+05 │
│ 1.031086e+06 │
│ 1.026453e+06 │
│ 9.906340e+05 │
│ 9.318714e+05 │
│ 9.643197e+05 │
│ 1.006497e+06 │
│ 1.005552e+06 │
│ 1.043003e+06 │
│ 1.042224e+06 │
│ … │
└─────────────────────────┘
x_max
Return the X maxima of a geometry.
x_min
Return the X minima of a geometry.
y
Return the Y coordinate of self
, or NULL if not available.
Input must be a point.
Returns
FloatingValue
Y coordinate of self
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.zones.fetch()
>>> t.geom.centroid().y()
┏━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ GeoY(GeoCentroid(geom)) ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ float64 │
├─────────────────────────┤
│ 191376.749531 │
│ 164018.754403 │
│ 254265.478659 │
│ 202959.782391 │
│ 140681.351376 │
│ 157998.935612 │
│ 216719.218169 │
│ 222936.087552 │
│ 212969.849014 │
│ 186706.496469 │
│ … │
└─────────────────────────┘
y_max
Return the Y maxima of a geometry.
y_min
Return the Y minima of a geometry.