VoroCrust-Meshing is the first provably correct algorithm for conforming Voronoi meshing of non-convex and non-manifold domains with guarantees on the quality of both surface and volume elements.
VoroCrust-Meshing is SCR 2820.0. It was approved for open source release 8/30/2022.
$ cmake --version
can be run to get the version of the currently installed
version of CMake.sudo yum install cmake
brew install cmake
. module load sems-env && module load sems-cmake/3.12.2
OpenMP : The OpenMP library is required by VoroCrust. Most modern compilers will have openmp installed already. If it is installed then CMake should detect it automatically.
NOTE: If using homebrew on computer with Monterey and an M1 chip: Go into gcc bin directory (e.g /opt/homebrew/Cellar/gcc/12.1.0/bin) and set up aliases for c++, cpp, g++, and gcc using the commands:
ln -s c++-12 c++
ln -s cpp-12 cpp
etc.,
or vc-meshing will not find the correct compilers.
Once you have all the required prerequisites installed for VoroCrust, you can build it.
We will use the following directory structure for our example of how to properly build VoroCrust-meshing. You are not required to use this folder structure but some automated testing may not work if you choose a different layout.
Generally speaking, we would create a directory called vorocrust-meshing
into
which we will clone the VoroCrust git repositories, and we create a build
directory in the vorocrust source folder.
The directory hierarchy should look something like this:
vorocrust-meshing/
|
+--- vorocrust-meshing/
| |
| + build/
|
+--- vorocrust-data/
|
+--- vorocrust-workshop/
Note: the vorocrust-data and vorocrust-workshop directories aren't required for building at this time. We are currently working on populating the vorocrust-data repository with sample meshes, etc. The vorocrust-workshop repository contains some powerpoint presentations from previous workshops, etc. We split this into a separate repository because the files can be quite large.
Clone Vorocrust-Meshing
$ mkdir vorocrust-meshing
$ cd vorocrust-meshing
$ git clone git@github.com:sandialabs/vorocrust-meshing.git
Create your build directory
$ cd vorocrust-meshing
$ mkdir build
$ cd build
Configure
$ cmake ../.
On Macs with M1 chips it may be necessary to force cmake to find the correct compilers using
$ cmake -D CMAKE_CXX_COMPILER=g++ -D CMAKE_C_COMPILER=gcc ../.
Build
$ make
Optionally you can add the arguments -j N
to use N cores in a parallel
build on your computer. This can speed up builds.
If you would like to see the exact commands from the build, you can also
run make VERBOSE=1
to increase the verbosity of the makefile.
Test
$ make test
Currently, cmake expects vorocrust-data to be checked out in the same directory as the vorocrust repository. See the preferred directory structure above.
We are working on a website that provides more detailed steps on building VoroCrust-Meshing for Windows. When that is available we will add a link here.
There are quite a number of CMake options for VoroCrust-Meshing that can be used to configure the build. Here is a list of them:
CMake Option | Default Value | Advanced | Description |
---|---|---|---|
VOROCRUST_BUILD_MESH |
ON | NO | Include src/Mesh codes |
VOROCRUST_ENABLE_EXODUS |
OFF | NO | Build EXODUS mesh output capability (for Mesh) |
VOROCRUST_ENABLE_LONG_TESTS |
OFF | NO | Enables some longer-running tests. |
VOROCRUST_ENABLE_MPI |
OFF | NO | Enable MPI support and build with MPI compilers. |
VOROCRUST_ENABLE_OPENMP |
ON | NO | Enable OpenMP support. |
VOROCRUST_TPL_BUILD_OPENBLAS |
OFF | NO | Build OpenBLAS (ExternalProject) |
VOROCRUST_TPL_ENABLE_KOKKOS |
OFF | NO | Build with Kokkos (FetchContent) |
VOROCRUST_TPL_ENABLE_KOKKOSKERNELS |
OFF | NO | Build with KokkosKernels (FetchContent) |
VOROCRUST_TPL_USE_LAPACK |
OFF | NO | Build with LAPACK support. |
VOROCRUST_VERBOSE_CMAKE |
OFF | NO | Enable extra verbosity in CMake. |
VOROCRUST_ENABLE_TPL_TESTS |
OFF | YES | Run test suites for TPLs built via ExternalProject |
VOROCRUST_ENABLE_TPL_LOG_BUILD |
OFF | YES | Enable ExternalProject TPL build logging. |
VOROCRUST_ENABLE_TPL_LOG_CONF |
OFF | YES | Enable ExternalProject TPL configure logging. |
VOROCRUST_ENABLE_TPL_LOG_DOWNLOAD |
OFF | YES | Enable ExternalProject TPL download logging. |
VOROCRUST_ENABLE_TPL_LOG_INST |
OFF | YES | Enable ExternalProject TPL installation logging. |
VOROCRUST_ENABLE_TPL_LOG_TEST |
OFF | YES | Enable ExternalProject TPL test logging. |
VOROCRUST_ENABLE_WARNINGS |
OFF | YES | Enable extra C++ warnings (i.e., -Wall) |
VOROCRUST_ENABLE_TUCKERMPI |
OFF | YES | Enable TuckerMPI (EXPERIMENTAL!!!) |
VOROCRUST_TPL_BUILD_HDF5 |
OFF | YES | Builds the HDF5 TPL. Requires ZLib. (ExternalProject) |
VOROCRUST_TPL_BUILD_NETCDF |
OFF | YES | Builds the NetCDF TPL. Requires HDF5. (ExternalProject) |
VOROCRUST_TPL_BUILD_SEACAS |
OFF | YES | Builds the SEACAS TPL. Requires NetCDF. (ExternalProject) |
VOROCRUST_TPL_BUILD_OPENBLAS |
OFF | YES | Builds the OpenBLAS TPL (ExternalProject) |
VOROCRUST_TPL_BUILD_ZLIB |
OFF | YES | Builds the ZLib TPL (ExternalProject) |
VOROCRUST_TPL_KOKKOS_VERSION |
3.5.00 | YES | The 'release' version of Kokkos and Kokkos-Kernels to include. |
VOROCRUST_VERSION_USES_GIT_SHA1 |
OFF | YES | Attempt to find and use the current Git SHA1, commit date for version info. |
VOROCRUST_TPL_NO_DOWNLOAD |
ON | YES | If a TPL is available in the tpls/ dir use it rather than downloading. |
VOROCRUST_ENABLE_DEVTEST |
OFF | YES | Enable EXPERIMENTAL features that are guarded. Sometimes platform dependent. |
Notes
LAPACK
will make VoroCrust try and find installed BLAS and LAPACK libraries but if they can't
be found then it will attempt to build OpenBLAS.OPENBLAS
will also enable LAPACK
.LAPACK
and OPENBLAS
are enabled, then VoroCrust will skip detection of an installed LAPACK and will
build its own copy of OpenBLAS.EXODUS
will cause the following TPLs to be built and installed in the Build directory:
ENABLE_DEVTEST
flag to guard this in many cases so Devops can
enable a feature while testing it out while retaining cmake errors that will
prevent an experimental feature from being used outside of Devops testing.Please use the following BibTeX entry to cite VoroCrust:
@article{10.1145/3337680,
author = {Abdelkader, Ahmed and
Bajaj, Chandrajit L. and
Ebeida, Mohamed S. and
Mahmoud, Ahmed H. and
Mitchell, Scott A. and
Owens, John D. and
Rushdi, Ahmad A.},
title = {VoroCrust: Voronoi Meshing Without Clipping},
year = {2020},
issue_date = {May 2020},
publisher = {Association for Computing Machinery},
address = {New York, NY, USA},
volume = {39},
number = {3},
issn = {0730-0301},
url = {https://doi.org/10.1145/3337680},
doi = {10.1145/3337680},
journal = {ACM Trans. Graph.},
month = may,
articleno = {23},
numpages = {16},
keywords = {meshing, Voronoi,
sharp features,
refinement,
union of balls,
slivers,
Poisson-disk sampling}
}