As GUDHI is a header only library, there is no need to install the library.
Examples of GUDHI headers inclusion can be found in Utilities and examples.
The library uses c++17 and requires Boost ≥ 1.71.0 and CMake ≥ 3.8. It is a multi-platform library and compiles on Linux, Mac OSX and Visual Studio 2017.
To build the utilities, run the following commands in a terminal:
cd /path-to-gudhi/ mkdir build cd build/ cmake -DCMAKE_BUILD_TYPE=Release .. make
By default, examples are disabled. You can activate their compilation with ccmake (on Linux and Mac OSX), cmake-gui (on Windows) or by modifying the cmake command as follows :
cmake -DCMAKE_BUILD_TYPE=Release -DWITH_GUDHI_EXAMPLE=ON .. make
A list of utilities and examples is available here.
To install the library (headers and activated utilities), run the following command in a terminal:
make install
This action may require to be in the sudoer or administrator of the machine in function of the operating system and of CMAKE_INSTALL_PREFIX.
make
command, but make install
will not install it. Please refer to the Python module installation documentation.To test your build, run the following command in a terminal:
make test
make test
is using Ctest (CMake test driver program). If some of the tests are failing, please send us the result of the following command:
ctest --output-on-failure
Testing fetching datasets feature requires the use of the internet and is disabled by default. If you want to include this test, set WITH_GUDHI_REMOTE_TEST to ON when building in the previous step (note that this test is included in the python module):
cmake -DCMAKE_BUILD_TYPE=Release -DWITH_GUDHI_TEST=ON -DWITH_GUDHI_REMOTE_TEST=ON --DWITH_GUDHI_PYTHON=ON ..
To generate the C++ documentation, the doxygen program is required (version ≥ 1.9.5 is advised). Run the following command in a terminal:
make doxygen
Documentation will be generated in a folder named html
.
In case there is not a full setup present and only the documentation should be build the following command sequence can be used:
cmake -DWITH_GUDHI_THIRD_PARTY=OFF .. make doxygen
The Hello world for GUDHI project is an example to help developers to make their own C++ project on top of the GUDHI library.
The multi-field persistent homology algorithm requires GMP which is a free library for arbitrary-precision arithmetic, operating on signed integers, rational numbers, and floating point numbers.
The following example requires the GNU Multiple Precision Arithmetic Library (GMP) and will not be built if GMP is not installed:
Having GMP version 4.2 or higher installed is recommended.
Some GUDHI modules (cf. modules list), and few examples require CGAL, a C++ library that provides easy access to efficient and reliable geometric algorithms.
cmake -DCMAKE_BUILD_TYPE=Release . && make
CGAL (or even cmake -DCMAKE_BUILD_TYPE=Release -DCGAL_HEADER_ONLY=ON .
), thereafter you will be able to compile GUDHI by calling cmake -DCMAKE_BUILD_TYPE=Release -DCGAL_DIR=/your/path/to/CGAL-X.Y .. && make
The procedure to install this library according to your operating system is detailed here http://doc.cgal.org/latest/Manual/installation.html
The following examples/utilities require the Computational Geometry Algorithms Library (CGAL [46]) and will not be built if CGAL version 5.1.0 or higher is not installed:
Some GUDHI modules (cf. modules list), and few examples require Eigen is a C++ template library for linear algebra: matrices, vectors, numerical solvers, and related algorithms.
The following examples/utilities require the Eigen and will not be built if Eigen version 3.3.0 or higher is not installed:
Intel® oneAPI TBB lets you easily write parallel C++ programs that take full advantage of multicore performance, that are portable and composable, and that have future-proof scalability.
Having Intel® oneAPI TBB (version 20.19.7 or higher) installed is recommended to parallelize and accelerate some GUDHI computations.
The following examples/utilities are using Intel® oneAPI TBB if installed:
Please help us improving the quality of the GUDHI library. You may report bugs or contact us for any suggestions.
GUDHI is open to external contributions. If you want to join our development team, please take some time to read our contributing guide.