<div dir="ltr">The RectTree work hiding in lilwgeom has much of this already, just not hooked up or (most importantly) tested. I have always resisted picking it back up because of the knowledge of how much testing and perfection it would require. Unfortunately I found quite a few cases in my geography implementation where the tree based and brute force approaches differed (though the approaches were quite different, so I can see more opportunities for it to fail).<div><br></div><div>One thing that I think turned out to be a mistake in the geography implementation was doing the work as a cached implementation like prepgeom. Basically, first pass you get a brute force answer, second pass you get a tree answer. The tree is actually faster for most non-trivial inputs, so ... still probably need some kind of threashold on whether to use the treed version or not.</div><div><br></div><div>The only upside of the cache implementation is that (yes) it did shake out yet more cases where the tree algorithm failed. People would notice getting different results on the same pairing, depending on where that pairing showed up in the query result set.</div><div><br></div><div>Anyways: yes, no reason not to complete it. And with the stuff in liblwgeom, I do have support for arc primitives, (got distracted from doing the tree in order to support the arcs) though that leaves some semi-difficult stuff like point-in-polygon for compoundcurve evaluated on the tree.</div><div><br></div><div>ATB,</div><div><br>P</div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Nov 1, 2016 at 5:54 AM, Daniel Baston <span dir="ltr"><<a href="mailto:dbaston@gmail.com" target="_blank">dbaston@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Not as a strict port from JTS, no. The IndexedFacetSequence class<br>
gives us the two closest FacetSequences only. If the two closest<br>
points are needed, it should be possible to add a<br>
FacetSequence::closestPoints method. If you're comparing two<br>
collections and need to know the two closest components, it's possible<br>
that you could work this out from the CoordinateSequence pointers held<br>
by each FacetSequence.<br>
<br>
Dan<br>
<div class="HOEnZb"><div class="h5"><br>
On Mon, Oct 31, 2016 at 6:36 PM, Sandro Santilli <<a href="mailto:strk@kbt.io">strk@kbt.io</a>> wrote:<br>
> On Mon, Oct 31, 2016 at 06:17:34PM -0400, Daniel Baston wrote:<br>
>> I recently ported the IndexedFacetDistance class from JTS to GEOS.<br>
>> This class provides optimized distance routines that work by<br>
>> constructing Rtree indexes over both of the input geometries, and<br>
>> performing distance calculations only between the nearest portions<br>
>> (facets) of the two inputs. This can produce massive performance<br>
>> improvements on distance calculations. (An example discussed in trac<br>
>> #3587 goes from about 42 seconds to 0.1 seconds.) Additionally, the<br>
>> indexes can be retained (much like a PreparedGeometry), for the case<br>
>> where many inputs need to be tested against a single large geometry<br>
>> (this last bit hasn't been exposed in the C API).<br>
>><br>
>> Is this something we should explore using in ST_Distance / ST_DWithin,<br>
>> or maybe elsewhere in PostGIS? It would have to be limited to types<br>
>> supported by GEOS (2D only, no curves), and we'd probably need to find<br>
>> some heuristics about when it's worth the effort (rather than a<br>
>> standard lwgeom_mindistance2d).<br>
><br>
> I've been working with distances recently, for a new snap algorithm<br>
> in librttopo, and found myself in need of not just a distance value<br>
> but also which element was closest (to a point, in my case).<br>
> The liblwgeom functions (in measures.c) seem to be returning the<br>
> detail in terms of "closest points", but that's still not enough<br>
> detail for what I needed.<br>
><br>
> Could the yet-to-be-exposed part of the API give additional details ?<br>
> To which level ?<br>
><br>
> --strk;<br>
> ______________________________<wbr>_________________<br>
> postgis-devel mailing list<br>
> <a href="mailto:postgis-devel@lists.osgeo.org">postgis-devel@lists.osgeo.org</a><br>
> <a href="http://lists.osgeo.org/mailman/listinfo/postgis-devel" rel="noreferrer" target="_blank">http://lists.osgeo.org/<wbr>mailman/listinfo/postgis-devel</a><br>
______________________________<wbr>_________________<br>
postgis-devel mailing list<br>
<a href="mailto:postgis-devel@lists.osgeo.org">postgis-devel@lists.osgeo.org</a><br>
<a href="http://lists.osgeo.org/mailman/listinfo/postgis-devel" rel="noreferrer" target="_blank">http://lists.osgeo.org/<wbr>mailman/listinfo/postgis-devel</a></div></div></blockquote></div><br></div>