-
Notifications
You must be signed in to change notification settings - Fork 365
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update GEOS algorithms to support XY CoordinateSequence #872
Comments
What about representing single coordinates using a structure wide enough to hold all potential ordinates? (Probably |
For XY coordinate sequences, imposing an XYZM struct on top would read out of bounds for the last coordinates X and M values. For internally managed buffers we could just always make our buffers slightly larger than necessary, but for external buffers we'd be in a pickle. |
That's the issue with using references to Coordinate references, I guess. Is that really so much more efficient? Or perhaps a hybrid approach, where some access is done just be reference, but if the coordinate will form part of a new geometry, it is copied fully. |
How about using |
Why go through all this trouble to maintain dimensions beyond XY for what is essentially "user" data for each and every coordinate? |
|
The
CoordinateSequence
implementation introduced in #799 allows aCoordinateSequence
to be backed by any of the Coordinate types: XY, XYZ, XYM, and XYZM. However, most of the GEOS library accesses coordinates usingCoordinateSequence::getAt<Coordinate>()
, which requires assumes theCoordinateSequence
is backed by XYZ or XYZM Coordinates. So for now, GEOS pads XY and XYM sequences with Z values, forcing them into XYZ or XYZM.I made certain parts of the GEOS code base "2D safe" (most of
geos::algorithm
andgeos::operation::valid
) by removing XYZ access (usingCoordinateSequence::getAt<CoordinateXY>
instead ofCoordinateSequence::getAt()
. As long as we only run these algorithms, this allows removal of theGEOS_COORDSEQ_PADZ
define inCoordinateSequence.cpp
, so that 2D geometries geometries are backed by XY coordinates rather than XYZ coordinates. I did some performance benchmarking withGEOSisValid
and not find a compelling performance benefit. However, enabling the code to function with XY-backed sequences may have benefits for memory-constrained users and would make #747 usable for the most common case of an external XYXY buffer. Running the test suite withGEOS_COORDSEQ_PADZ
removed will give some idea of the extent of GEOS code that is "2D safe".Making 2D algorithms only use 2D access as described above is a fairly easy problem. A trickier issue is the handling of algorithms such as convex hull, distance, and Delaunary triangulation that do not require Z coordinates but preserve them if they are available. When adding M support to overlay, I used a helper function to dispatch to
LineIntersector
methods that are templated for the correct types. This allows us to contain the use of templates to a single point in the overlay algorithm (IntersectionAdder
is not templated). And as a side effect, parts of the overlay code also support XY-backed sequences (and avoid wasted Z interpolation of NaNs).Dispatch helper:
geos/include/geos/geom/CoordinateSequences.h
Lines 42 to 72 in 3cab6cb
Example usage:
geos/src/algorithm/LineIntersector.cpp
Lines 175 to 213 in 3cab6cb
Other algorithms, such as convex hull, nearest points and Delaunay triangulation, might require different techniques. One way might be to perform the algorithm using
CoordinateXY
references and then construct a result by castingCoordinateXY*
back to whatever the actual backing type was (e.g.,CoordinateXYM*
).I'm not sure the effort to make these changes is worth it, but wanted to leave some breadcrumbs for anyone who wants to pursue this farther.
The text was updated successfully, but these errors were encountered: