[geos-devel] [GEOS] #1036: GeomDifference with Overlay turned on goes into infinite look in PostGIS ST_WrapX
GEOS
geos-trac at osgeo.org
Thu Jul 30 09:52:10 PDT 2020
#1036: GeomDifference with Overlay turned on goes into infinite look in PostGIS
ST_WrapX
------------------------+---------------------------
Reporter: robe | Owner: geos-devel@…
Type: defect | Status: new
Priority: blocker | Milestone: 3.9.0
Component: Default | Version: master
Severity: Unassigned | Resolution:
Keywords: |
------------------------+---------------------------
Description changed by robe:
Old description:
> This is related to https://trac.osgeo.org/postgis/ticket/4731.
> Which after much input has been determined to be an issue with the new
> GEOS 3.9 overlay logic.
>
> The crashing example in PostGIS
>
> {{{
> SELECT ST_WrapX('LINESTRING(-11.1111111 70,70 -11.1111111)'::geometry,
> 20.1,20.1);
> }}}
>
> Related IRC discussion
>
> {{{
> 15:30:30 Algunenano: ReginaObe[m]: WrapX uses split by line,
> which uses GEOSUnion
> 15:30:39 Algunenano: Maybe it's that?
> 15:30:57 ReginaObe[m]: ah Algunenano so I guess we got to update
> the docs too to reflect it uses GEOS
> 15:31:14 ReginaObe[m]: who would have thunk it :)
> 15:31:37 PaulRamsey[m]: you have a winner, it crashed for me too
> 15:31:42 ReginaObe[m]: Paul Ramsey: well that's a crasher
> 15:33:19 PaulRamsey[m]: It does eventually call GEOSDifference
> 15:33:28 PaulRamsey[m]: after 25000 frames of recursion?
> 15:33:41 PaulRamsey[m]: I mean, something non-geos broken in
> there?
> 15:33:48 PaulRamsey[m]: weird
> 15:36:20 PaulRamsey[m]: probably in ` split =
> lwgeom_split(geom_in, blade);`
> 15:36:34 Algunenano: It looks like an infinite loop. Has the
> geometry type changed? Maybe line -> multiline?
> 15:38:35 Algunenano: It seems that, for some reason,
> lwgeom_split_wrapx calls lwcollection_wrapx over the result, so it it
> returns a multiline (with a single line) it might be going to infinity
> and beyond
> 15:39:34 PaulRamsey[m]: yeah, not sure why it tries to wrap the
> components of the split...
> 15:39:50 PaulRamsey[m]: but if the components were slightly
> shifted, like enough to hit the blade again
> 15:39:57 PaulRamsey[m]: it would split over and over and over
> 15:45:54 ReginaObe[m]: Hmm ST_Split also doesn't note dependency
> on GEOS
> 15:46:09 ReginaObe[m]: which version of GEOS are required for
> these
> 15:46:35 PaulRamsey[m]: it uses difference, so pretty much all of
> them
> 15:47:06 PaulRamsey[m]: once martin implements a splitter over
> the new overlay all the splitting code can get simpler and more
> reliable.. right now it's a hack on difference
> 15:49:35 PaulRamsey[m]: found it, @algunano
> }}}
>
> {{{
> 15:49:35 PaulRamsey[m]: found it, @algunano
>
> select st_astext(st_difference('LINESTRING(-11.1111111 70,70
> -11.1111111)'::geometry, 'LINESTRING (20.1 90, 20.1 -90)'::geometry));
> st_astext
> -----------------------------------------------------------
> LINESTRING(-11.1111111 70,20.1 38.7888889,70 -11.1111111)
> (1 row)
> }}}
New description:
This is related to https://trac.osgeo.org/postgis/ticket/4731.
Which after much input has been determined to be an issue with the new
GEOS 3.9 overlay logic.
The crashing example in PostGIS
{{{
SELECT ST_WrapX('LINESTRING(-11.1111111 70,70 -11.1111111)'::geometry,
20.1,20.1);
}}}
Related IRC discussion
{{{
15:30:30 Algunenano: ReginaObe[m]: WrapX uses split by line,
which uses GEOSUnion
15:30:39 Algunenano: Maybe it's that?
15:30:57 ReginaObe[m]: ah Algunenano so I guess we got to update
the docs too to reflect it uses GEOS
15:31:14 ReginaObe[m]: who would have thunk it :)
15:31:37 PaulRamsey[m]: you have a winner, it crashed for me too
15:31:42 ReginaObe[m]: Paul Ramsey: well that's a crasher
15:33:19 PaulRamsey[m]: It does eventually call GEOSDifference
15:33:28 PaulRamsey[m]: after 25000 frames of recursion?
15:33:41 PaulRamsey[m]: I mean, something non-geos broken in
there?
15:33:48 PaulRamsey[m]: weird
15:36:20 PaulRamsey[m]: probably in ` split =
lwgeom_split(geom_in, blade);`
15:36:34 Algunenano: It looks like an infinite loop. Has the
geometry type changed? Maybe line -> multiline?
15:38:35 Algunenano: It seems that, for some reason,
lwgeom_split_wrapx calls lwcollection_wrapx over the result, so it it
returns a multiline (with a single line) it might be going to infinity and
beyond
15:39:34 PaulRamsey[m]: yeah, not sure why it tries to wrap the
components of the split...
15:39:50 PaulRamsey[m]: but if the components were slightly
shifted, like enough to hit the blade again
15:39:57 PaulRamsey[m]: it would split over and over and over
15:45:54 ReginaObe[m]: Hmm ST_Split also doesn't note dependency
on GEOS
15:46:09 ReginaObe[m]: which version of GEOS are required for
these
15:46:35 PaulRamsey[m]: it uses difference, so pretty much all of
them
15:47:06 PaulRamsey[m]: once martin implements a splitter over the
new overlay all the splitting code can get simpler and more reliable..
right now it's a hack on difference
15:49:35 PaulRamsey[m]: found it, @algunano
}}}
{{{
15:49:35 PaulRamsey[m]: found it, @algunano
select st_astext(st_difference('LINESTRING(-11.1111111 70,70
-11.1111111)'::geometry, 'LINESTRING (20.1 90, 20.1 -90)'::geometry));
st_astext
-----------------------------------------------------------
LINESTRING(-11.1111111 70,20.1 38.7888889,70 -11.1111111)
(1 row)
}}}
From related PostGIS ticket
----
The lwgeom_split_wrapx function expects a split (which under the covers is
a difference of a line away from an input) to return a collection, which
it then iterates on. Instead we hand it a unitary object... which it then
goes and tries to split again. Hence the infinite recursion. We need
probably the old behaviour back, so that a GEOS 3.9 install doesn't break
older software.
--
--
Ticket URL: <https://trac.osgeo.org/geos/ticket/1036#comment:1>
GEOS <http://trac.osgeo.org/geos>
GEOS (Geometry Engine - Open Source) is a C++ port of the Java Topology Suite (JTS).
More information about the geos-devel
mailing list