The rust-lang source code of the map generator application that go through the alias pullauta which is available as binary executable for Linux, Mac and Windows (find attachment in each releases).
pullauta is an application designed to generate highly accurate maps out of LiDAR data input files that supports many file formats, namely LAS, LAZ, and XYZ files. It uses advanced algorithms for filtering, classification, and feature extraction, ensuring that users can generate highly accurate maps with ease.
Download the latest binary for your platform (Linux, Mac or Windows) from https://github.com/karttapullautin/karttapullautin/releases/latest and extract the files where you want to use them.
- You need first to install the rust toolchain.
-
Then download the latest code at https://github.com/karttapullautin/karttapullautin/releases/latest
-
Finally compile it
cargo build --releaseFor maximum performance, it is recommended to compile targeting the native cpu by specifying the
target-cpuflag. This makes sure that any instruction set extensions such as SIMD and FMA are used. This includes if your processor supports AVX, AVX2 and AVX512 (and NEON on ARM targets) as the default release binaries are compiled without these enabled to be as portable as possible. If you have a relatively recent CPU (eg. Intelskylakeor later) you should instead compile like this:RUSTFLAGS="-C target-cpu=native" cargo build --release -
The pullauta binary will be accessible in the
target/release/directory. You can proceed and copy it to your desired directory.
pullauta accepts .LAS, .LAZ or .XYZ file with classification (xyzc).
You can run the pullauta executable with the path to your file as argument:
./pullauta L3323H3.laz
Note: By defaut messages with the log level info will be printed to the console. To show more information (eg. timings of each operation), set the
RUST_LOGenvironment variable todebugor specify it on the command line like so:RUST_LOG=debug ./pullauta [..]Other log level available is
warn, in which no info of current run will be displayed,error, which will only show errors, andtracewhich will output a lot of log messages about small details during the processing.
As output Karttapullautin writes two 600 dpi png map images. One without depressions and one with purple depressions. It also writes contours and cliffs as dxf files to temp folder to be post processed, for example using Open Orienteering Mapper or OCAD.
You can re-render png map files (like with changed north line settings) by running the binary without arguments.
./pullauta
Karttapullautin can also render zip files containing shape files downloaded from differents sources. After normal process just run the binary with the zip(s) as arguments. You must define your configuration file describing the shape file content, in the ini file, parameter vectorconf (see osm.txt and fastighetskartan.txt).
./pullauta yourzipfile1.zip yourzipfile2.zip yourzipfile3.zip yourzipfile4.zip
For Finns: Karttapullautin render Maastotietokanta zip files (shape files) downloaded from the download site of Maanmittauslaitos without setting a configuration file. Just leave vectorconf parameter empty.
To print a map at right scale, you download for example IrfanView http://www.irfanview.com/ open png map, Image -> Information, set resolution 600 x 600 DPI and push "change" button and save. Then crop map if needed (Select area with mouse and Edit -> crop selection). Print using "Print size: Original Size srom DPI". Like this your map should end up 1:10000 scale on paper.
You can download OSM files from Open Street Map website https://www.openstreetmap.org/export in a form of a .osm file extension. To convert this file in something that can be used by karttapullautin you'll need the GDAL ogr2ogr program (Download from https://gdal.org/en/latest/download.html)
Run the following commands in your terminal
ogr2ogr --config OSM_USE_CUSTOM_INDEXING NO -skipfailures -f "ESRI Shapefile" output_shapes map.osm -overwrite -t_srs EPSG:3067
zip -r -j map.shp.zip output_shapes/*
Replace EPSG:3067 by the coordinates ESPG codename of that the LAZ file uses.
You will have a zip file map.shp.zip that you can use with karttapullautin.
Previously, Karttapullautin used regular text-based .xyz files to store the temporary files which could be opened and visualized by many external tools. But with the introduction of an internal (non-stable) binary format for increased performance and reduced disk usage, there is now a new command that can do the conversion into the previous format for you. This will, for example, convert the xyztemp.xyz.bin file into a regular xyztemp.xyz file (with one line per point) which can be opened by external tools:
./pullauta internal2xyz temp/xyztemp.xyz.bin temp/xyztemp.xyz
Note: this also works for the binary
.hmapfiles.
Similar as the XYZ files mentioned above, Karttapullautin previously used regular text-based .dxf files to store the temporary geometry which could be opened and visualized by many external tools. But with the introduction of an internal (non-stable) binary format for increased performance and reduced disk usage, there is now a new command that can do the conversion into DXF for you. Example usage:
./pullauta bin2dxf temp/c2g.dxf.bin temp/c2g.dxf
There is also a configuration option output_dxf which when set to 1 will output regular .dxf files next to the binary files at the expense of higher disk usage and performance.
pullauta creates a pullauta.ini file if it doesn't already exists. Your settings are there. For the second run you can change settings as you wish. Experiment with small file to find best settings for your taste/terrain/lidar data.
For Ini file configuration explanation, see ini file comments.
When the process is done and you find there is too much green or too small cliffs, you can make parts of the process again with different parameters without having to do it all again. To re-generate only vegetation type from command line:
./pullauta makevege
./pullauta
To make cliffs again:
./pullauta makecliffs xyztemp.xyz 1.0 1.15
./pullauta
In additon to the png raster map imges, Karttapullautin makes also vector contours and cliffs and also some raster vector files one might find intresting for mapping use. After the process you can find them in temp folder.
out2.dxf: final contours with 2.5 m intervaldotknolls.dxf: dot knolls and small U -depressions. Some are not rendered to png files for legibility reasons.c1g.dxf: small cliffsc2g.dxf: big cliffsvegetation.png + vegetation.pgw: generalized green/yellow as raster, same as at the background of final map png files.
For importing Maastotietokanta, try reading shape filed directly to your mapping app. Note that the dxf files need to be converted from the internal .bin.dxf format using the command bin2dxf as mentioned above.
Karttapulautin can also batch process all las/las files + Maastotietokanta zips in a directory. To do it, turn batch processing on in ini file. configure your input file directory and output directory for map tiles. Copy your input files to input directory and run ./pullauta. It starts processing las/laz files one by one until everything is done. If you have several cores
in your CPU, you can make use of all of them to process multiple file at once. you can configure it with processes parameter in ini file. Note, processes parameter effects only batch mode, in normal mode it uses just one worker process. You will also need lots of RAM to process simultaneously several large laser files. To re-process tiles in bach mode you need to remove previous png files from output folder.
You can merge png files in output folder with Karttapullautin.
Without the depressions
./pullauta pngmerge 1
and depression versions
./pullauta pngmergedepr 1
vegetation backround images (if saved, there is parameter for saving there)
./pullauta pngmergevege
The last paramameter (number) is scale factor. 2 reduces size to 50%, 4 to 25%, 20 to 5% and so on. Command writes out jpg and png versions. Note, you easily run out of memory if you try merging together too large area with too high resolution.
You can also merge dxf files (if saved, there is parameter for saving there)
./pullauta dxfmerge
Some commands from the original perl karttapullatin that are either obsolete or not necessary for the map generation are not supported by this new rust version:
They are:
cliffgeneralizegroundground2groundfixmakecliffsoldmakeheightvegeprofilexyzfixer
If you need to run one of those, you must use the original perl script https://www.routegadget.net/karttapullautin/ or https://github.com/linville/kartta-pack for mac and linux
Make your changes, then youd run:
cargo build --release
The new binary will be accessible in the target/release/ directory
@jagge @rphlo @antbern