-
Notifications
You must be signed in to change notification settings - Fork 247
Linux Build
You can find latest Kratos compilation instructions in Install.md
- Objectives:
- Tests kratos
To to tests the compilation, you can execute a simple python script containing this line:
from KratosMultiphysics import *
We strongly recommend you to run kratos scripts with the "runkratos" binary that will be generated inside your Kratos installation folder. You can also run them by using python (if you have compiled with python version 2.x.x), or python3 (if you have compiled with python version 3.x.x)
- runkratos test.py
- python test.py
- python3 test.py
If everething was ok you will see this message:
| / |
' / __| _` | __| _ \ __|
. \ | ( | | ( |\__ \
_|\_\_| \__,_|\__|\___/ ____/
Multi-Physics 3.3.11016
In this section we provide will try to provide solutions to the most common problems and issues that may appear during the compilation process
Make sure that LD_LIBRARY_PATH
and PYTHONPATH
are pointing to your kratos folder.
To make sure that the variables are set correctly, you can always print their value from the terminal by typing:
echo $LD_LIBRARY_PATH
echo $PYTHONPATH
echo $PATH
Some shell interpreters have issues with the separator token. If environment variables above listed are correctly set, try to remove the ":" if kratos is the only path there.
# This may cause problem
echo $PYTHONPATH
:path/to/kratos
# Should be
export PYTHONPATH=path/to/kratos
echo $PYTHONPATH
path/to/kratos
This errors appear if the version of python used to compile boost is not the same as the one used by Kratos.
There are several causes that may be causing this. Pleas try the following:
The most provable reason for this error to happend is a missmatch between the python versions used by Kratos and Boost. Please, double check you have the same version of python in the projet-config.jam (boost) and configure.sh (Kratos) files.
Please check that CMake version is 3.14 or newer. In general newer versions of Python will need newer versions of CMake to work.
It has been observed that compiling with IDE's ( QTCreator, Netbeans, ...) sometimes causes this error as well. If you are experiencing this problem, try to modify the configure.sh script and replace '''cmake''' by the absolute path of CMake 3.14 or the any newer version:
/path/to/correct/cmake .. \
-DCMAKE_C_COMPILER=/usr/bin/gcc \
...
If for some reason you have to use an older version of CMake you can manually add support for an outdated versiof of python by adding the version to these files:
/usr/share/cmake-3.x/Modules/FindPythonLibs.cmake
/usr/share/cmake-3.x/Modules/FindPythonInterp.cmake
Please add the version at the begining of the list:
SET(_PYTHON1_VERSIONS 1.6 1.5)
SET(_PYTHON2_VERSIONS 2.7 2.6 2.5 2.4 2.3 2.2 2.1 2.0)
SET(_PYTHON3_VERSIONS 3.4 3.3 3.2 3.1 3.0)
It is known that in some cases warnings appear while including boost files due to the fact that the flag "-Wunused-local-typedefs" is set by default in gcc.
This does not have any impact on the final code, but if you want a cleaner output you can add the flag "-Wno-unused-local-typedefs" to the configuration files:
-DCMAKE_CXX_FLAGS="${CMAKE_CXX_FLAGS} -msse3 -Wno-unused-local-typedefs" \
-DCMAKE_C_FLAGS="${CMAKE_C_FLAGS} -msse3 -Wno-unused-local-typedefs" \
If you want to compile the MPI-version of Kratos, you need to at least to
- Have a MPI installation (e.g. OpenMPI or Intel MPI). There are no known restrictions on which version to use.
- Set the flag
MPI_NEEDED
toON
in the configure-script
This will compile the core of Kratos with MPI (i.e. compile the MPI-Core) and provide basic features of MPI. Check here to see which functionalities are exposed to Python.
If you want to run Kratos in MPI together with e.g. the FluidDynamicsApplication
or the StructuralMechanicsApplication
, then you also need Trilinos for solving the distributed system of equations and Metis for partitioning of the problem.
In order to use them it is required to compile the TrilinosApplication
and the MetisApplication
respectively. These applications require to install the corresponding libraries first.
On Ubuntu 18.04, the following command installs the necessary files:
sudo apt-get install libmetis-dev
Compiling is straight-forward using the build-instructions that come with the download.
Afterwards add the following lines to your configure-script:
-DMETIS_APPLICATION=ON \
-DUSE_METIS_5=ON \
On Ubuntu 18.04, the following command installs the necessary files:
sudo apt-get install trilinos-all-dev
Add the following to your configure-script:
-DTRILINOS_INCLUDE_DIR="/usr/include/trilinos" \
-DTRILINOS_LIBRARY_DIR="/usr/lib/x86_64-linux-gnu" \
-DTRILINOS_LIBRARY_PREFIX="trilinos_" \
Some information on how to compile Trilinos (version 12.10.1) is provided in the following, but this might not be applicable for all systems. Please consult the build-instructions of Trilinos itself if needed or open an issue.
Add the following to your configure-script if you compile Trilinos yourself:
-DTRILINOS_ROOT="path/to/trilinos" \
Depending on the configuration it might also be necessary to specify TRILINOS_SOURCE
for CMake to find the correct trilinos-libraries.
It is recommended to create a build directory in the root folder of Trilinos. Inside this folder, create a do-configure.sh
to compile Trilinos.
If you use LAPACK 3.6 or newer, then you have to apply the following fixes: (sources: 1, 2):
In trilinos-12.10.1-Source/packages/epetra/src/Epetra_LAPACK_wrappers.h
Change
#define DGGSVD_F77 F77_BLAS_MANGLE(dggsvd,DGGSVD)
#define SGGSVD_F77 F77_BLAS_MANGLE(sggsvd,SGGSVD)
to
#define DGGSVD_F77 F77_BLAS_MANGLE(dggsvd3,DGGSVD3)
#define SGGSVD_F77 F77_BLAS_MANGLE(sggsvd3,SGGSVD3)
This is an example for a do-configure.sh
. Of course, the paths have to be adjusted
TRILINOS_ROOT="${HOME}/software/kratos/trilinos"
EXTRA_LINK_FLAGS=""
EXTRA_ARGS=$@
MPI_ROOT="${HOME}/software/ompi"
METIS_ROOT="{HOME}/software/kratos/parmetis/ParMetis-3.2.0"
LAPACK_ROOT="${HOME}/software/kratos/lapack/lapack-3.7.0"
rm CMakeCache.txt
rm -rf CMakeFiles
rm *.cmake
cmake \
-D CMAKE_INSTALL_PREFIX:FILEPATH="${TRILINOS_ROOT}" \
-D CMAKE_BUILD_TYPE:STRING=RELEASE \
-D Trilinos_SOURCE_DIR="${TRILINOS_SOURCE}" \
-D CMAKE_CXX_COMPILER=mpicxx \
-D CMAKE_C_COMPILER=mpicc \
-D CMAKE_Fortran_COMPILER=mpif90 \
-D TPL_ENABLE_MPI:BOOL=ON \
-D Trilinos_ENABLE_CXX11=ON\
-D MPI_BASE_DIR="${MPI_ROOT}" \
-D MPI_INCLUDE_DIRS:PATH="${MPI_ROOT}/include" \
-D BUILD_SHARED_LIBS:BOOL=ON \
-D BLAS_LIBRARY_DIRS:FILEPATH="${LAPACK_ROOT}" \
-D BLAS_LIBRARY_NAMES:STRING="librefblas.a" \
-D LAPACK_LIBRARY_DIRS:FILEPATH="${LAPACK_ROOT}" \
-D LAPACK_LIBRARY_NAMES:STRING="liblapack.a" \
-D TPL_ENABLE_ParMETIS:BOOL=ON \
-D ParMETIS_INCLUDE_DIRS:PATH="${METIS_ROOT}" \
-D ParMETIS_LIBRARY_NAMES:STRING="parmetis" \
-D ParMETIS_LIBRARY_DIRS:PATH="${METIS_ROOT}" \
-D TPL_ENABLE_METIS:BOOL=ON \
-D METIS_INCLUDE_DIRS:PATH="${METIS_ROOT}/METISLib" \
-D METIS_LIBRARY_NAMES:STRING="metis" \
-D METIS_LIBRARY_DIRS:PATH="${METIS_ROOT}" \
-D Trilinos_EXTRA_LINK_FLAGS:STRING="$EXTRA_LINK_FLAGS" \
-D Trilinos_ENABLE_Amesos:BOOL=ON \
-D Amesos_ENABLE_SuperLUDist:BOOL=ON \
-D Trilinos_ENABLE_Anasazi:BOOL=ON \
-D Trilinos_ENABLE_AztecOO:BOOL=ON \
-D AztecOO_ENABLE_Teuchos:BOOL=ON \
-D Trilinos_ENABLE_Didasko:BOOL=ON \
-D Trilinos_ENABLE_Epetra:BOOL=ON \
-D Trilinos_ENABLE_EpetraExt:BOOL=ON \
-D Trilinos_ENABLE_Galeri:BOOL=ON \
-D Trilinos_ENABLE_Ifpack:BOOL=ON \
-D Trilinos_ENABLE_ML:BOOL=ON \
-D Trilinos_ENABLE_PyTrilinos:BOOL=OFF \
-D Trilinos_ENABLE_Teuchos:BOOL=ON \
-D Trilinos_ENABLE_Triutils:BOOL=ON \
-D DART_TESTING_TIMEOUT:STRING=600 \
-D CMAKE_Fortran_FLAGS:STRING="-O5 -funroll-all-loops -fPIC" \
-D CMAKE_C_FLAGS:STRING="-O3 -fPIC -funroll-loops -march=native" \
-D CMAKE_CXX_FLAGS:STRING="-O3 -fPIC -funroll-loops -ffast-math -march=native -DMPICH_IGNORE_CXX_SEEK" \
$EXTRA_ARGS \
${TRILINOS_SOURCE}
Build Trilinos with:
sh do-configure.sh
make
make install
Afterwards add the following lines to your configure-script:
-DTRILINOS_APPLICATION=ON \
To to tests the compilation, you can execute a simple python script containing these lines:
from KratosMultiphysics import *
from KratosMultiphysics.mpi import *
from KratosMultiphysics.MetisApplication import *
from KratosMultiphysics.TrilinosApplication import *
To execute Kratos in parallel, you can for example use the mpiexec
command (running with 4 processes):
mpiexec -np 4 python3 MainKratos.py --using-mpi
- Getting Kratos (Last compiled Release)
- Compiling Kratos
- Running an example from GiD
- Kratos input files and I/O
- Data management
- Solving strategies
- Manipulating solution values
- Multiphysics
- Video tutorials
- Style Guide
- Authorship of Kratos files
- Configure .gitignore
- How to configure clang-format
- How to use smart pointer in Kratos
- How to define adjoint elements and response functions
- Visibility and Exposure
- Namespaces and Static Classes
Kratos structure
Conventions
Solvers
Debugging, profiling and testing
- Compiling Kratos in debug mode
- Debugging Kratos using GDB
- Cross-debugging Kratos under Windows
- Debugging Kratos C++ under Windows
- Checking memory usage with Valgind
- Profiling Kratos with MAQAO
- Creating unitary tests
- Using ThreadSanitizer to detect OMP data race bugs
- Debugging Memory with ASAN
HOW TOs
- How to create applications
- Python Tutorials
- Kratos For Dummies (I)
- List of classes and variables accessible via python
- How to use Logger
- How to Create a New Application using cmake
- How to write a JSON configuration file
- How to Access DataBase
- How to use quaternions in Kratos
- How to do Mapping between nonmatching meshes
- How to use Clang-Tidy to automatically correct code
- How to use the Constitutive Law class
- How to use Serialization
- How to use GlobalPointerCommunicator
- How to use PointerMapCommunicator
- How to use the Geometry
- How to use processes for BCs
- How to use Parallel Utilities in futureproofing the code
- Porting to Pybind11 (LEGACY CODE)
- Porting to AMatrix
- How to use Cotire
- Applications: Python-modules
- How to run multiple cases using PyCOMPSs
- How to apply a function to a list of variables
- How to use Kratos Native sparse linear algebra
Utilities
Kratos API
Kratos Structural Mechanics API