Opened 4 months ago
Closed 4 months ago
#5777 closed defect (fixed)
st_intersects() throws exception when using geometrycollection as first argument
Reported by: | cfischer | Owned by: | pramsey |
---|---|---|---|
Priority: | medium | Milestone: | PostGIS GEOS |
Component: | postgis | Version: | 3.4.x |
Keywords: | relate st_intersects TopologyException | Cc: | cfischer |
Description (last modified by ) ¶
PostGIS throws an exception with st_intersects on geometry collection as first parameter
SQL Error [XX000]: ERROR: GEOSIntersects: TopologyException: side location conflict at 725217.59322033904 6176386.5423728814. This can occur if the input geometry is invalid.
A have isolated the problem, shown below. The order of the arguments to st_intersects appears to be signifikant.
- geom_1 : is a point
- geom_2 : is a geometrycollection, containing two triangles
- geom_3 : is a multipolygon-version of geom_2
- st_intersects (geom_1, geom_2) → SUCCESS
- st_intersects (geom_2, geom_1) → FAILS
- st_intersects (geom_1, geom_3) → SUCCESS
- st_intersects (geom_3, geom_1) → SUCCESS
WITH geom_1 AS ( SELECT st_point(725220, 6176385, 25832) AS geom ), geom_2 AS ( SELECT st_geometryfromtext( 'GEOMETRYCOLLECTION ( POLYGON ((725210 6176386, 725220 6176382, 725224 6176387, 725210 6176386)), POLYGON ((725215 6176390, 725218 6176386, 725225 6176385, 725215 6176390)) )' , 25832) AS geom ), geom_3 AS ( SELECT st_geometryfromtext( 'MULTIPOLYGON ( ((725210 6176386, 725220 6176382, 725224 6176387, 725210 6176386)), ((725215 6176390, 725218 6176386, 725225 6176385, 725215 6176390)) )' , 25832) AS geom ) SELECT * FROM geom_1 JOIN geom_2 ON (st_intersects(geom_2.geom, geom_1.geom)) -- fails -- JOIN geom_2 ON (st_intersects(geom_1.geom, geom_2.geom)) -- works -- JOIN geom_3 ON (st_intersects(geom_1.geom, geom_3.geom)) -- works -- JOIN geom_3 ON (st_intersects(geom_3.geom, geom_1.geom)) -- works
SELECT postgis_full_version(); POSTGIS="3.4.0 0874ea3" [EXTENSION] PGSQL="160" GEOS="3.12.0-CAPI-1.18.0" PROJ="8.0.1 NETWORK_ENABLED=OFF URL_ENDPOINT=https://cdn.proj.org USER_WRITABLE_DIRECTORY=/tmp/proj DATABASE_PATH=/rdsdbbin/postgres-16.1.R2/share/proj/proj.db" LIBXML="2.9.1" LIBJSON="0.15" LIBPROTOBUF="1.3.2" WAGYU="0.5.0 (Internal)"
Change History (6)
comment:1 by , 4 months ago
Description: | modified (diff) |
---|
comment:2 by , 4 months ago
Milestone: | PostGIS 3.4.3 → PostGIS 3.4.4 |
---|
follow-up: 4 comment:3 by , 4 months ago
Milestone: | PostGIS 3.4.4 → PostGIS GEOS |
---|
follow-up: 5 comment:4 by , 4 months ago
Replying to pramsey:
This exists in GEOS 3.12, but not in GEOS 3.13.
geosop \ -a "GEOMETRYCOLLECTION (POLYGON ((725210 6176386, 725220 6176382, 725224 6176387, 725210 6176386)), POLYGON ((725215 6176390, 725218 6176386, 725225 6176385, 725215 6176390)))" \ -b "POINT(725220 6176385)" \ intersectsThe fix will end up being upgrading GEOS.
You mean the other way around I hope — exists in GEOS 3.13 and not in 3.12 and below
Now that GEOS 3.13 is released, is there a reason to keep this ticket open?
comment:5 by , 4 months ago
Replying to robe:
Replying to pramsey:
This exists in GEOS 3.12, but not in GEOS 3.13.
You mean the other way around I hope — exists in GEOS 3.13 and not in 3.12 and below
He means that the problem exists in GEOS 3.12 but not in 3.13.
Now that GEOS 3.13 is released, is there a reason to keep this ticket open?
Probably not.
comment:6 by , 4 months ago
Resolution: | → fixed |
---|---|
Status: | new → closed |
This exists in GEOS 3.12, but not in GEOS 3.13.
The fix will end up being upgrading GEOS.