Installation and Dependencies ============================= .. raw:: html Dependencies ------------ 1. The following dependencies are required for Nek5000 - FORTRAN 77 compilers - C and C++ compilers - MPI 2. The following dependencies are required for ADIOS2 - CMake In a super computer such as `Dardel `__ at PDC in Stockholm, loading the following modules is enough for compilation and execution: .. code:: sh module swap PrgEnv-cray PrgEnv-gnu module load PDC module load CMake/3.21.2 module swap craype-network-ofi craype-network-ucx module swap cray-mpich cray-ucx module load cray-mpich-ucx Installation and Usage ---------------------- Linking Nek5000 with ADIOS2 ~~~~~~~~~~~~~~~~~~~~~~~~~~~ In this repository we include a `Nek5000 `__ version that has been modified for linking with the ADIOS2 library. For the sake of convenience, we have included a tested version of ADIOS2 under the `/Nek5000/3rd_party/adios2 `__ that can be easily installed by executing the ``install.sh`` script in the folder or at Nek5000 compile time (see sections below). If a user wish to use their own version of Nek5000, some files in the source need to be modified for the linking to occur. Such files can be readily checked and copied from the Nek5000 version shipped in this repository. The following files were modified in the `core `_: * `drive.f `__ * `makenek.inc `__ * `makefile.template `__ The following files were added to the `3rd_party `__ folder and contain the ADIOS2 subroutines. * `nek_in_situ.f `__ * `adios2.f `__ * `nek_adios2.cpp `__ Compiling Nek5000 with ADIOS2 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ .. raw:: html Just as for any other used-defined function in Nek5000, 3 main files must be modified to be able to use the toolbox: 1. :ref:`compile_script` 2. :ref:`makefile_usr_inc` 3. :ref:`casename_usr` Templates of the modified files can be found at the `DCTB `__ and `examples `__ folders, however, a list of modifications to the files can be found by using the hyperlinks. Having modified all the files accordingly, compilation follows by ensuring that the ``SIZE`` file is present in the folder and executing the command: .. code:: sh ./compile_script --all If ``ADIOS2`` has not been compiled, the following message will prompt and ADIOS2 will be compiled: .. code:: sh compression requires ADIOS2 to be build before compilation of Nek5000 Turning to -build-dep mode building 3rd-party dependencies In this case, after the compilation of ``ADIOS2``, Nek5000 will not automatically restart the compilation of the case, therefore after all the 3rd party libraries have been compiled, the user must run ``./compile_script --all`` once again to compile the case. If the process is succesful, the executable ``Nek5000`` and the folder ``config`` will be added to the ``compile`` sub-directory. Running Nek5000 with ADIOS2 ~~~~~~~~~~~~~~~~~~~~~~~~~~~ Prior to running, the behaviour of the compression toolbox can be modified by changing the runtime parameters that need to be included in the ``.par`` file. A template of the of the aditions to this file can be found in the `DCTB `__ and `examples `__ folder and a description of each parameter can be found following :ref:`casename_par` To run Nek5000 it is necesary that the ``Nek5000`` executable and the ``config`` folder are copied from the compilation folder to the run folder. Executing Nek5000 with the data compression toolbox enabled is as simple as executing, for example: .. code:: sh mpirun -n 4 ./nek5000