Skip to content

Commit

Permalink
updated docs to reflect new sigs of triangulation funcs
Browse files Browse the repository at this point in the history
  • Loading branch information
sllynn committed Nov 1, 2024
1 parent 380e441 commit a38dc21
Show file tree
Hide file tree
Showing 3 changed files with 52 additions and 19 deletions.
2 changes: 1 addition & 1 deletion docs/docs-requirements.txt
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
setuptools==68.1.2
setuptools>=70.0.0
Sphinx==6.1.3
sphinx-material==0.0.36
nbsphinx>=0.8.8
Expand Down
32 changes: 24 additions & 8 deletions docs/source/api/raster-functions.rst
Original file line number Diff line number Diff line change
Expand Up @@ -491,7 +491,7 @@ rst_derivedband
rst_dtmfromgeoms
****************

.. function:: rst_dtmfromgeoms(pointsArray, linesArray, mergeTolerance, snapTolerance, origin, xWidth, yWidth, xSize, ySize)
.. function:: rst_dtmfromgeoms(pointsArray, linesArray, mergeTolerance, snapTolerance, splitPointFinder, origin, xWidth, yWidth, xSize, ySize, noData)

Generate a raster with interpolated elevations across a grid of points described by:

Expand All @@ -518,6 +518,13 @@ rst_dtmfromgeoms
Setting this value to zero may result in the output triangle vertices being assigned a null Z value.
Both tolerance parameters are expressed in the same units as the projection of the input point geometries.

Additionally, you have control over the algorithm used to find split points on the constraint lines. The recommended
default option here is the "NONENCROACHING" algorithm. You can also use the "MIDPOINT" algorithm if you find the
constraint fitting process fails to converge. For full details of these options see the JTS reference
`here <https://locationtech.github.io/jts/javadoc/org/locationtech/jts/triangulate/ConstraintSplitPointFinder.html>`__.

The :code:`noData` value of the output raster can be set using the :code:`noData` parameter.

This is a generator expression and the resulting DataFrame will contain one row per point of the grid.

:param pointsArray: Array of geometries respresenting the points to be triangulated
Expand All @@ -528,6 +535,8 @@ rst_dtmfromgeoms
:type mergeTolerance: Column (DoubleType)
:param snapTolerance: A snapping tolerance used to relate created points to their corresponding lines for elevation interpolation.
:type snapTolerance: Column (DoubleType)
:param splitPointFinder: Algorithm used for finding split points on constraint lines. Options are "NONENCROACHING" and "MIDPOINT".
:type splitPointFinder: Column (StringType)
:param origin: A point geometry describing the bottom-left corner of the grid.
:type origin: Column (Geometry)
:param xWidth: The number of points in the grid in x direction.
Expand All @@ -538,6 +547,8 @@ rst_dtmfromgeoms
:type xSize: Column (DoubleType)
:param ySize: The spacing between each point on the grid's y-axis.
:type ySize: Column (DoubleType)
:param noData: The no-data value of the output raster.
:type noData: Column (DoubleType)
:rtype: Column (RasterTileType)

:example:
Expand Down Expand Up @@ -567,7 +578,8 @@ rst_dtmfromgeoms
df.select(
rst_dtmfromgeoms(
"masspoints", "breaklines", lit(0.0), lit(0.01),
"origin", "xWidth", "yWidth", "xSize", "ySize"
"origin", "xWidth", "yWidth", "xSize", "ySize",
split_point_finder="NONENCROACHING", no_data_value=-9999.0
)
).show(truncate=False)
+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
Expand All @@ -594,8 +606,10 @@ rst_dtmfromgeoms

df.select(
rst_dtmfromgeoms(
$"masspoints", $"breaklines", lit(0.0), lit(0.01),
$"origin", $"xWidth", $"yWidth", $"xSize", $"ySize"
$"masspoints", $"breaklines",
lit(0.0), lit(0.01), lit("NONENCROACHING")
$"origin", $"xWidth", $"yWidth",
$"xSize", $"ySize", lit(-9999.0)
)
).show(1, false)
+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
Expand All @@ -615,8 +629,9 @@ rst_dtmfromgeoms
"POINT Z (0 2 2)"
),
ARRAY("LINESTRING EMPTY"),
DOUBLE(0.0), DOUBLE(0.01),
"POINT (0.6 1.8)", 12, 6, DOUBLE(0.1), DOUBLE(0.1)
DOUBLE(0.0), DOUBLE(0.01), "NONENCROACHING",
"POINT (0.6 1.8)", 12, 6,
DOUBLE(0.1), DOUBLE(0.1), DOUBLE(-9999.0)
) AS tile
+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
|rst_dtmfromgeoms(masspoints, breaklines, 0.0, 0.01, origin, xWidth, yWidth, xSize, ySize) |
Expand All @@ -638,8 +653,9 @@ rst_dtmfromgeoms
sdf <- withColumn(sdf, "breaklines", expr("array('LINESTRING EMPTY')"))
sdf <- select(sdf, rst_dtmfromgeoms(
column("masspoints"), column("breaklines"),
lit(0.0), lit(0.01),
lit("POINT (0.6 1.8)"), lit(12L), lit(6L), lit(0.1), lit(0.1)
lit(0.0), lit(0.01), lit("NONENCROACHING"),
lit("POINT (0.6 1.8)"), lit(12L), lit(6L),
lit(0.1), lit(0.1), lit(-9999.0)
)
)
showDF(sdf, n=1, truncate=F)
Expand Down
37 changes: 27 additions & 10 deletions docs/source/api/spatial-functions.rst
Original file line number Diff line number Diff line change
Expand Up @@ -881,7 +881,7 @@ st_haversine
st_interpolateelevation
***********************

.. function:: st_interpolateelevation(pointsArray, linesArray, mergeTolerance, snapTolerance, origin, xWidth, yWidth, xSize, ySize)
.. function:: st_interpolateelevation(pointsArray, linesArray, mergeTolerance, snapTolerance, splitPointFinder, origin, xWidth, yWidth, xSize, ySize)

Compute interpolated elevations across a grid of points described by:

Expand All @@ -908,6 +908,11 @@ st_interpolateelevation
Setting this value to zero may result in the output triangle vertices being assigned a null Z value.
Both tolerance parameters are expressed in the same units as the projection of the input point geometries.

Additionally, you have control over the algorithm used to find split points on the constraint lines. The recommended
default option here is the "NONENCROACHING" algorithm. You can also use the "MIDPOINT" algorithm if you find the
constraint fitting process fails to converge. For full details of these options see the JTS reference
`here <https://locationtech.github.io/jts/javadoc/org/locationtech/jts/triangulate/ConstraintSplitPointFinder.html>`__.

This is a generator expression and the resulting DataFrame will contain one row per point of the grid.

:param pointsArray: Array of geometries respresenting the points to be triangulated
Expand All @@ -919,6 +924,8 @@ st_interpolateelevation
:param snapTolerance: A snapping tolerance used to relate created points to their corresponding lines for elevation interpolation.
:type snapTolerance: Column (DoubleType)
:param origin: A point geometry describing the bottom-left corner of the grid.
:param splitPointFinder: Algorithm used for finding split points on constraint lines. Options are "NONENCROACHING" and "MIDPOINT".
:type splitPointFinder: Column (StringType)
:type origin: Column (Geometry)
:param xWidth: The number of points in the grid in x direction.
:type xWidth: Column (IntegerType)
Expand Down Expand Up @@ -957,7 +964,8 @@ st_interpolateelevation
df.select(
st_interpolateelevation(
"masspoints", "breaklines", lit(0.0), lit(0.01),
"origin", "xWidth", "yWidth", "xSize", "ySize"
"origin", "xWidth", "yWidth", "xSize", "ySize",
split_point_finder="NONENCROACHING"
)
).show(4, truncate=False)
+--------------------------------------------------+
Expand Down Expand Up @@ -987,7 +995,8 @@ st_interpolateelevation

df.select(
st_interpolateelevation(
$"masspoints", $"breaklines", lit(0.0), lit(0.01),
$"masspoints", $"breaklines",
lit(0.0), lit(0.01), lit("NONENCROACHING"),
$"origin", $"xWidth", $"yWidth", $"xSize", $"ySize"
)
).show(4, false)
Expand All @@ -1011,7 +1020,7 @@ st_interpolateelevation
"POINT Z (0 2 2)"
),
ARRAY("LINESTRING EMPTY"),
DOUBLE(0.0), DOUBLE(0.01),
DOUBLE(0.0), DOUBLE(0.01), "NONENCROACHING",
"POINT (0.6 1.8)", 12, 6, DOUBLE(0.1), DOUBLE(0.1)
)
+--------------------------------------------------+
Expand All @@ -1037,7 +1046,7 @@ st_interpolateelevation
sdf <- withColumn(sdf, "breaklines", expr("array('LINESTRING EMPTY')"))
sdf <- select(sdf, st_interpolateelevation(
column("masspoints"), column("breaklines"),
lit(0.0), lit(0.01),
lit(0.0), lit(0.01), lit("NONENCROACHING"),
lit("POINT (0.6 1.8)"), lit(12L), lit(6L), lit(0.1), lit(0.1)
)
)
Expand Down Expand Up @@ -1757,7 +1766,7 @@ st_transform
st_triangulate
**************

.. function:: st_triangulate(pointsArray, linesArray, mergeTolerance, snapTolerance)
.. function:: st_triangulate(pointsArray, linesArray, mergeTolerance, snapTolerance, splitPointFinder)

Performs a conforming Delaunay triangulation using the points in :code:`pointsArray` including :code:`linesArray` as constraint / break lines.

Expand All @@ -1773,6 +1782,11 @@ st_triangulate
Setting this value to zero may result in the output triangle vertices being assigned a null Z value.
Both tolerance parameters are expressed in the same units as the projection of the input point geometries.

Additionally, you have control over the algorithm used to find split points on the constraint lines. The recommended
default option here is the "NONENCROACHING" algorithm. You can also use the "MIDPOINT" algorithm if you find the
constraint fitting process fails to converge. For full details of these options see the JTS reference
`here <https://locationtech.github.io/jts/javadoc/org/locationtech/jts/triangulate/ConstraintSplitPointFinder.html>`__.

This is a generator expression and the resulting DataFrame will contain one row per triangle returned by the algorithm.

:param pointsArray: Array of geometries respresenting the points to be triangulated
Expand All @@ -1783,6 +1797,8 @@ st_triangulate
:type mergeTolerance: Column (DoubleType)
:param snapTolerance: A snapping tolerance used to relate created points to their corresponding lines for elevation interpolation.
:type snapTolerance: Column (DoubleType)
:param splitPointFinder: Algorithm used for finding split points on constraint lines. Options are "NONENCROACHING" and "MIDPOINT".
:type splitPointFinder: Column (StringType)
:rtype: Column (Geometry)

:example:
Expand All @@ -1803,7 +1819,7 @@ st_triangulate
.groupBy()
.agg(collect_list("wkt").alias("masspoints"))
.withColumn("breaklines", array(lit("LINESTRING EMPTY")))
.withColumn("triangles", st_triangulate("masspoints", "breaklines", lit(0.0), lit(0.01))
.withColumn("triangles", st_triangulate("masspoints", "breaklines", lit(0.0), lit(0.01), "NONENCROACHING"))
)
df.show(2, False)
+---------------------------------------+
Expand All @@ -1826,7 +1842,7 @@ st_triangulate
.withColumn("triangles",
st_triangulate(
$"masspoints", $"breaklines",
lit(0.0), lit(0.01)
lit(0.0), lit(0.01), lit("NONENCROACHING")
)
)

Expand All @@ -1849,7 +1865,8 @@ st_triangulate
"POINT Z (0 2 2)"
),
ARRAY("LINESTRING EMPTY"),
DOUBLE(0.0), DOUBLE(0.01)
DOUBLE(0.0), DOUBLE(0.01),
"NONENCROACHING"
)
+---------------------------------------+
|triangles |
Expand All @@ -1872,7 +1889,7 @@ st_triangulate
sdf <- withColumn(sdf, "breaklines", expr("array('LINESTRING EMPTY')"))
result <- select(sdf, st_triangulate(
column("masspoints"), column("breaklines"),
lit(0.0), lit(0.01))
lit(0.0), lit(0.01), lit("NONENCROACHING")
)
showDF(result, truncate=F)
+---------------------------------------+
Expand Down

0 comments on commit a38dc21

Please sign in to comment.