Takes 2D GIS datasets (eg topographical datasets) and "3dfies" them (as in "making them three-dimensional") by lifting every polygon to 3D. The elevation is obtained from a point cloud (we support LAS/LAZ at this moment), and the semantics of every polygon is used to perform the lifting. That is, water polygons are extruded to horizontal polygons, buildings to LOD1 blocks, roads as smooth surfaces, etc. Every polygon is triangulated (constrained Delaunay triangulation) and the lifted polygons are "stitched" together so that one digital surface model (DSM) is constructed. Our aim is to obtain one DSM that is error-free, ie no intersecting triangles, no holes (the surface is watertight), where buildings are integrated in the surface, etc. This surface will then be used as input in simulation software for instance.
The lifting options can be configured in the YAML file (myconfig.yml
) provided.
Any 2D input (which should be a planar partition) can be used as input, and each class must be mapped to one of the following:
- Building
- Terrain
- Road
- Water
- Forest
- Bridge
- Separation (used for concrete slabs used along canals for instance, surely very "Dutch")
It is possible to define new classes, although that would require a bit of programming.
Output is at this moment in either OBJ or CityGML (and CVS for buildings only, ie their ID and height (ground+roof) are output). The ID of each polygon is preserved, and there is a 1-to-1 mapping between the input and the output.
Notice that this version is very much a beta version, although it is in our opinion usable. If you use it, feedback is very much appreciated.
We expect the LAS/LAZ to be classified according to the ASPRS Standard LIDAR Point Classes v1.4 (Table 4.9 of this PDF), and at a minimum these should be defined:
- 0-1 : Created, never classified and/or Unclassified
- 2 : Ground
- 3-5: Vegetation
If the vegetation is not classified or not filtered out, then buildings will be taller and there will be artefacts in the terrain.
To build you'll normally do (from 3dfier root directory):
mkdir build && cd build
cmake ..
make
The dependencies that are necessary (under Mac we suggest using Homebrew):
- LIBLAS with LASzip support (
brew install liblas --with-laszip
) - GDAL (
brew install gdal
) - Boost (
brew install boost
) - CGAL (
brew install cgal
) - yaml-cpp (
brew install yaml-cpp
)
$ ./3dfier myconfig.yml > output.obj
In the folder example_data
there is a small part of the BGT datasets (2D 1:1k topographic datasets of the Netherlands) and a part of the AHN3 LIDAR dataset that can be used for testing.
The resulting model (in OBJ) can be seen in example_data/output/test_area.obj