From fcaf46788b1661fe6e9f89d51c39a1ad307b259d Mon Sep 17 00:00:00 2001 From: Pete Gadomski Date: Wed, 21 Aug 2024 15:40:49 -0600 Subject: [PATCH 1/2] docs: grammar, punctuation, and wording suggestions These suggestions came out of an initial review of the JOSS paper as a part of https://github.com/openjournals/joss-reviews/issues/7123. These are merely suggestions, and by no means are required to be taken up during the review process. I just thought I'd do a quick-once over while reading through. --- paper/paper.md | 37 +++++++++++++++++-------------------- 1 file changed, 17 insertions(+), 20 deletions(-) diff --git a/paper/paper.md b/paper/paper.md index df7d69a..bb7df16 100644 --- a/paper/paper.md +++ b/paper/paper.md @@ -20,56 +20,53 @@ bibliography: ref.bib # Summary -*startinpy* is a Python library for modelling and processing terrains using a 2D Delaunay triangulation (DT). +*startinpy* is a Python library for modelling and processing terrains using a two-dimensional (2D) Delaunay triangulation (DT). The triangulation is computed in 2D, but the z-elevation of the vertices is kept (which is referred to as 2.5D modelling). -Given a dataset formed of elevation samples (eg collected with lidar or photogrammetry), it allows us, among other things, to reconstruct a terrain, to remove points, to search efficiently in the triangulation, to attach attributes to the vertices, and to convert to a gridded terrain (a few spatial interpolation methods based on the DT and/or its dual structure, the Voronoi diagram, have been implemented: linear interpolation, natural neighbours [@Sibson81], and Laplace interpolation [@Belikov97]). +Given a dataset formed of elevation samples (e.g. collected with lidar or photogrammetry), startinpy allows us to reconstruct a terrain, to remove points, to search efficiently in the triangulation, to attach attributes to the vertices, and to convert to a gridded terrain +Additional functionality is provided, including a few spatial interpolation methods based on the DT and/or its dual structure, the Voronoi diagram, have been implemented: linear interpolation, natural neighbours [@Sibson81], and Laplace interpolation [@Belikov97]. -The core of the library is written in the language Rust (so it can process large datasets quickly), robust arithmetic is used for the updating of the DT (the robust predicates of @Shewchuk96 are used), and it uses NumPy for input/output of data, which allows it to integrate with other Python libraries used by researchers. +The core of the library is written in [Rust](https://www.rust-lang.org/) (so it can process large datasets quickly), robust arithmetic is used for the updating of the DT (the robust predicates of @Shewchuk96 are used), and it uses NumPy for input/output of data, which allows it to integrate with other Python libraries used by researchers. -The core of the library has been used recently to build a global coastal terrain using laser altimetric measurements from the space station [@Pronk24], and it has been used for a few projects dealing with aerial and space lidar datasets, eg @Meschin23 and @Kan24. +The core of the library has been used to build a global coastal terrain using laser altimetric measurements from the space station [@Pronk24], and it has been used for several projects dealing with aerial and space lidar datasets e.g. @Meschin23 and @Kan24. -While startinpy was developed primarily for terrains, it can be used as an easy-to-use and fast 2D Delaunay triangulator (and Voronoi diagram generator), which, as elaborated in @Aurenhammer12, are two structures that play an essential role in several disciplines: astronomy, geology, ecology, engineering, etc. +While startinpy was developed primarily to build terrains, it can be used as an easy-to-use and fast 2D Delaunay triangulator (and Voronoi diagram generator), which, as elaborated in @Aurenhammer12, are two structures that play an essential role in several disciplines: astronomy, geology, ecology, engineering, etc. ![A lidar dataset terrain reconstructed with startinpy and visualised with another Python library (Polyscope).](polyscope_gui.jpg) # Statement of need -While there exist many Python libraries for computing the DT in 2D (a search for "Delaunay triangulation" in the *Python Package Index* (PyPI) returns 227 packages), most of them are not fully suitable for the modelling of 2.5D triangulated terrain. +While there exist many Python libraries for computing the DT in 2D (a search for "Delaunay triangulation" in the [*Python Package Index* (PyPI)](https://pypi.org/search/?q=Delaunay+triangulation) returns over 200 packages), most of them are not fully suitable for the modelling of 2.5D triangulated terrain. startinpy has the following properties, which greatly improve the modelling and processing of 2.5D terrains. **It is fast for large datasets.** -With a recent lidar scanner, we can easily collect 50 samples/$m^2$, which means that a 1$km^2$ area will contain 50+ million samples. +With a modern lidar scanner, we can easily collect 50 samples/$m^2$, which means that a 1 $km^2$ area will contain 50+ million samples. Since constructing a DT requires several steps, if those steps are implemented in pure Python then the library becomes very slow. As can be seen in the [DT construction comparison](https://startinpy.readthedocs.io/latest/comparison.html), startinpy is faster than most other libraries for large datasets. -This is partly because it is 100% developed in Rust; the core library is called "startin" and its the source code is available at https://github.com/hugoledoux/startin. +This is partly because it is 100% developed in Rust; the core library is called "startin" and its the source code is available at . **Its data structure is exposed.** -Most libraries only return a list of vertices and triangles (triplets of vertex identifiers), which means that the user has to build an auxiliary graph to be able to find the adjacent triangles of a given one, or to find all the triangles that are incident to a given vertex (eg to calculate the normal). -The library's name comes from the fact that the data structure implemented is based on the concept of *stars* in a graph [@Blandford05], which allows us to store adjacency and incidence, and have a very compact data structure. -startinpy exposes methods to search triangles, to find the adjacent triangles of a triangle and the incident triangles to a vertex. - +Most libraries only return a list of vertices and triangles (triplets of vertex identifiers), which means that the user has to build an auxiliary graph to be able to find the adjacent triangles of a given one, or to find all the triangles that are incident to a given vertex (e.g. to calculate the normal). +This library's name comes from the fact that the data structure implemented is based on the concept of *stars* in a graph [@Blandford05], which allows us to store adjacency and incidence, and have a very compact data structure. +startinpy exposes methods to search triangles, find the adjacent triangles of a triangle, and find the incident triangles to a vertex. **The DT is incrementally constructed and deletion of vertices is possible.** -Unlike the majority of 2D DT implementations, startinpy implements an *incremental* insertion algorithm [@Lawson72], which allows for, for instance, constructing a simplified TIN that best approximates the original terrain with only 10% of the points, see @Garland95 for different strategies. -startinpy also implements a modification of the deletion algorithm in @Mostafavi03, I have extended it to allow the deletion of vertices on the boundary of the convex hull. +Unlike the majority of 2D DT implementations, startinpy implements an *incremental* insertion algorithm [@Lawson72], which allows for constructing a simplified TIN that best approximates the original terrain with only 10% of the points; see @Garland95 for different strategies. +startinpy also implements a modification of the deletion algorithm in @Mostafavi03, extended to allow the deletion of vertices on the boundary of the convex hull. The deletion of vertices in a DT is useful to remove outliers (which are detected by analysing neighbouring triangles in the DT) and for the implementation of the natural neighbours interpolation method [@Sibson81]. **The z-values are stored and xy-duplicates handled.** Some libraries allow us to attach extra information to a vertex, but most often one has to build an auxiliary data structure in Python to manage those. -Doing so is error-prone, tedious, and makes operations in 3D more complex (eg calculating the slope of an area, calculating the normal of a vertex, estimating the elevation with spatial interpolation, calculating volumes). -Furthermore, startinpy allows us to merge vertices that are close to each other (in the xy-plane; the tolerance can be defined by the user) and if there are xy-duplicates, then a user-defined z-value can be kept (eg lowest or highest, depending on the application). - +Doing so is error-prone, tedious, and makes operations in 3D more complex (e.g. calculating the slope of an area, calculating the normal of a vertex, estimating the elevation with spatial interpolation, calculating volumes). +By storing the z values, startinpy allows us to merge vertices that are close to each other (in the xy-plane; the tolerance can be defined by the user) and if there are xy-duplicates, then a user-defined z-value can be kept (e.g. lowest or highest, depending on the application). **Extra attributes can be stored in the DT.** It is possible to attach extra attributes with each vertex of the terrain. -This can be used to preserve the lidar properties of the input points (eg intensity, RGB, number of returns, etc.). - +This can be used to preserve the lidar properties of the input points (e.g. intensity, RGB, number of returns, etc.). The [documentation of startinpy](https://startinpy.rtfd.io) contains several examples of the library and how it can be used to prepare datasets for input to machine learning algorithms, to convert to different formats used in practice, to interpolate, etc. - # Acknowledgements I acknowledge the help of the students following the course [*Digital terrain modelling (GEO1015)* at TUDelft](https://3d.bk.tudelft.nl/courses/geo1015/) over the last few years. From 5be1b987ad1f143cab9ae95659f392a3d2a138bd Mon Sep 17 00:00:00 2001 From: Hugo Ledoux Date: Thu, 22 Aug 2024 14:46:28 +0200 Subject: [PATCH 2/2] Some corrections on the corrections of the paper --- paper/paper.md | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/paper/paper.md b/paper/paper.md index bb7df16..950f8df 100644 --- a/paper/paper.md +++ b/paper/paper.md @@ -23,14 +23,14 @@ bibliography: ref.bib *startinpy* is a Python library for modelling and processing terrains using a two-dimensional (2D) Delaunay triangulation (DT). The triangulation is computed in 2D, but the z-elevation of the vertices is kept (which is referred to as 2.5D modelling). -Given a dataset formed of elevation samples (e.g. collected with lidar or photogrammetry), startinpy allows us to reconstruct a terrain, to remove points, to search efficiently in the triangulation, to attach attributes to the vertices, and to convert to a gridded terrain +Given a dataset formed of elevation samples (eg collected with lidar or photogrammetry), startinpy allows us to reconstruct a terrain, to remove points, to search efficiently in the triangulation, to attach attributes to the vertices, and to convert to a gridded terrain. Additional functionality is provided, including a few spatial interpolation methods based on the DT and/or its dual structure, the Voronoi diagram, have been implemented: linear interpolation, natural neighbours [@Sibson81], and Laplace interpolation [@Belikov97]. The core of the library is written in [Rust](https://www.rust-lang.org/) (so it can process large datasets quickly), robust arithmetic is used for the updating of the DT (the robust predicates of @Shewchuk96 are used), and it uses NumPy for input/output of data, which allows it to integrate with other Python libraries used by researchers. -The core of the library has been used to build a global coastal terrain using laser altimetric measurements from the space station [@Pronk24], and it has been used for several projects dealing with aerial and space lidar datasets e.g. @Meschin23 and @Kan24. +The core of the library has been used to build a global coastal terrain using laser altimetric measurements from the space station [@Pronk24], and it has been used for several projects dealing with aerial and space lidar datasets, for instance @Meschin23 and @Kan24. -While startinpy was developed primarily to build terrains, it can be used as an easy-to-use and fast 2D Delaunay triangulator (and Voronoi diagram generator), which, as elaborated in @Aurenhammer12, are two structures that play an essential role in several disciplines: astronomy, geology, ecology, engineering, etc. +While startinpy was developed primarily to build and manipulate terrains, it can be used as an easy-to-use and fast 2D Delaunay triangulator (and Voronoi diagram generator), which, as elaborated in @Aurenhammer12, are two structures that play an essential role in several disciplines: astronomy, geology, ecology, engineering, etc. ![A lidar dataset terrain reconstructed with startinpy and visualised with another Python library (Polyscope).](polyscope_gui.jpg) @@ -47,7 +47,7 @@ As can be seen in the [DT construction comparison](https://startinpy.readthedocs This is partly because it is 100% developed in Rust; the core library is called "startin" and its the source code is available at . **Its data structure is exposed.** -Most libraries only return a list of vertices and triangles (triplets of vertex identifiers), which means that the user has to build an auxiliary graph to be able to find the adjacent triangles of a given one, or to find all the triangles that are incident to a given vertex (e.g. to calculate the normal). +Most libraries only return a list of vertices and triangles (triplets of vertex identifiers), which means that the user has to build an auxiliary graph to be able to find the adjacent triangles of a given one, or to find all the triangles that are incident to a given vertex (eg to calculate the normal). This library's name comes from the fact that the data structure implemented is based on the concept of *stars* in a graph [@Blandford05], which allows us to store adjacency and incidence, and have a very compact data structure. startinpy exposes methods to search triangles, find the adjacent triangles of a triangle, and find the incident triangles to a vertex. @@ -58,12 +58,12 @@ The deletion of vertices in a DT is useful to remove outliers (which are detecte **The z-values are stored and xy-duplicates handled.** Some libraries allow us to attach extra information to a vertex, but most often one has to build an auxiliary data structure in Python to manage those. -Doing so is error-prone, tedious, and makes operations in 3D more complex (e.g. calculating the slope of an area, calculating the normal of a vertex, estimating the elevation with spatial interpolation, calculating volumes). -By storing the z values, startinpy allows us to merge vertices that are close to each other (in the xy-plane; the tolerance can be defined by the user) and if there are xy-duplicates, then a user-defined z-value can be kept (e.g. lowest or highest, depending on the application). +Doing so is error-prone, tedious, and makes operations in 3D more complex (eg calculating the slope of an area, calculating the normal of a vertex, estimating the elevation with spatial interpolation, calculating volumes). +By storing the z values, startinpy allows us to merge vertices that are close to each other (in the xy-plane; the tolerance can be defined by the user) and if there are xy-duplicates, then a user-defined z-value can be kept (eg lowest or highest, depending on the application). **Extra attributes can be stored in the DT.** It is possible to attach extra attributes with each vertex of the terrain. -This can be used to preserve the lidar properties of the input points (e.g. intensity, RGB, number of returns, etc.). +This can be used to preserve the lidar properties of the input points (eg intensity, RGB, number of returns, etc.). The [documentation of startinpy](https://startinpy.rtfd.io) contains several examples of the library and how it can be used to prepare datasets for input to machine learning algorithms, to convert to different formats used in practice, to interpolate, etc.