comm_handling_m.f90 Source File


Files dependent on this one

sourcefile~~comm_handling_m.f90~~AfferentGraph sourcefile~comm_handling_m.f90 comm_handling_m.f90 sourcefile~benchmark_helmholtz_solvers.f90 benchmark_helmholtz_solvers.f90 sourcefile~benchmark_helmholtz_solvers.f90->sourcefile~comm_handling_m.f90 sourcefile~device_handling_m.f90 device_handling_m.f90 sourcefile~benchmark_helmholtz_solvers.f90->sourcefile~device_handling_m.f90 sourcefile~equilibrium_factory_m.f90 equilibrium_factory_m.f90 sourcefile~benchmark_helmholtz_solvers.f90->sourcefile~equilibrium_factory_m.f90 sourcefile~error_handling_m.f90 error_handling_m.f90 sourcefile~benchmark_helmholtz_solvers.f90->sourcefile~error_handling_m.f90 sourcefile~helmholtz_netcdfio_m.f90 helmholtz_netcdfio_m.f90 sourcefile~benchmark_helmholtz_solvers.f90->sourcefile~helmholtz_netcdfio_m.f90 sourcefile~helmholtz_solver_factory_m.f90 helmholtz_solver_factory_m.f90 sourcefile~benchmark_helmholtz_solvers.f90->sourcefile~helmholtz_solver_factory_m.f90 sourcefile~mesh_cart_m.f90 mesh_cart_m.f90 sourcefile~benchmark_helmholtz_solvers.f90->sourcefile~mesh_cart_m.f90 sourcefile~multigrid_m.f90 multigrid_m.f90 sourcefile~benchmark_helmholtz_solvers.f90->sourcefile~multigrid_m.f90 sourcefile~perf_m.f90 perf_m.f90 sourcefile~benchmark_helmholtz_solvers.f90->sourcefile~perf_m.f90 sourcefile~testfunctions_m.f90 testfunctions_m.f90 sourcefile~benchmark_helmholtz_solvers.f90->sourcefile~testfunctions_m.f90 sourcefile~carthy_equilibrium_m.f90 carthy_equilibrium_m.f90 sourcefile~carthy_equilibrium_m.f90->sourcefile~comm_handling_m.f90 sourcefile~analytic_divertor_equilibrium_m.f90 analytic_divertor_equilibrium_m.f90 sourcefile~carthy_equilibrium_m.f90->sourcefile~analytic_divertor_equilibrium_m.f90 sourcefile~cerfons_equilibrium_m.f90 cerfons_equilibrium_m.f90 sourcefile~cerfons_equilibrium_m.f90->sourcefile~comm_handling_m.f90 sourcefile~cerfons_equilibrium_m.f90->sourcefile~analytic_divertor_equilibrium_m.f90 sourcefile~coords_polar_m.f90 coords_polar_m.f90 sourcefile~coords_polar_m.f90->sourcefile~comm_handling_m.f90 sourcefile~slab_equilibrium.f90 slab_equilibrium.f90 sourcefile~coords_polar_m.f90->sourcefile~slab_equilibrium.f90 sourcefile~device_handling_m.f90->sourcefile~comm_handling_m.f90 sourcefile~device_handling_m.f90->sourcefile~error_handling_m.f90 sourcefile~diagnose_poincare.f90 diagnose_poincare.f90 sourcefile~diagnose_poincare.f90->sourcefile~comm_handling_m.f90 sourcefile~diagnose_poincare.f90->sourcefile~coords_polar_m.f90 sourcefile~diagnose_poincare.f90->sourcefile~equilibrium_factory_m.f90 sourcefile~diagnose_poincare.f90->sourcefile~error_handling_m.f90 sourcefile~fieldline_tracer_m.f90 fieldline_tracer_m.f90 sourcefile~diagnose_poincare.f90->sourcefile~fieldline_tracer_m.f90 sourcefile~equilibrium_factory_m.f90->sourcefile~comm_handling_m.f90 sourcefile~equilibrium_factory_m.f90->sourcefile~carthy_equilibrium_m.f90 sourcefile~equilibrium_factory_m.f90->sourcefile~cerfons_equilibrium_m.f90 sourcefile~equilibrium_factory_m.f90->sourcefile~error_handling_m.f90 sourcefile~flare_equilibrium_m.f90 flare_equilibrium_m.f90 sourcefile~equilibrium_factory_m.f90->sourcefile~flare_equilibrium_m.f90 sourcefile~numerical_equilibrium_m.f90 numerical_equilibrium_m.f90 sourcefile~equilibrium_factory_m.f90->sourcefile~numerical_equilibrium_m.f90 sourcefile~salpha_equilibrium_m.f90 salpha_equilibrium_m.f90 sourcefile~equilibrium_factory_m.f90->sourcefile~salpha_equilibrium_m.f90 sourcefile~circular_equilibrium_m.f90 circular_equilibrium_m.f90 sourcefile~equilibrium_factory_m.f90->sourcefile~circular_equilibrium_m.f90 sourcefile~circular_toroidal_equilibrium_m.f90 circular_toroidal_equilibrium_m.f90 sourcefile~equilibrium_factory_m.f90->sourcefile~circular_toroidal_equilibrium_m.f90 sourcefile~dommaschk_equilibrium_m.f90 dommaschk_equilibrium_m.f90 sourcefile~equilibrium_factory_m.f90->sourcefile~dommaschk_equilibrium_m.f90 sourcefile~equilibrium_factory_m.f90->sourcefile~slab_equilibrium.f90 sourcefile~error_handling_m.f90->sourcefile~comm_handling_m.f90 sourcefile~fieldline_tracer_m.f90->sourcefile~comm_handling_m.f90 sourcefile~fieldline_tracer_m.f90->sourcefile~error_handling_m.f90 sourcefile~flare_equilibrium_m.f90->sourcefile~comm_handling_m.f90 sourcefile~flare_equilibrium_m.f90->sourcefile~error_handling_m.f90 sourcefile~polygon_m.f90 polygon_m.f90 sourcefile~flare_equilibrium_m.f90->sourcefile~polygon_m.f90 sourcefile~kisslinger_m.f90 kisslinger_m.f90 sourcefile~flare_equilibrium_m.f90->sourcefile~kisslinger_m.f90 sourcefile~params_equi_flare_m.f90 params_equi_flare_m.f90 sourcefile~flare_equilibrium_m.f90->sourcefile~params_equi_flare_m.f90 sourcefile~helmholtz_netcdfio_m.f90->sourcefile~comm_handling_m.f90 sourcefile~helmholtz_netcdfio_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~csrmat_m.f90 csrmat_m.f90 sourcefile~helmholtz_netcdfio_m.f90->sourcefile~csrmat_m.f90 sourcefile~helmholtz_operator_m.f90 helmholtz_operator_m.f90 sourcefile~helmholtz_netcdfio_m.f90->sourcefile~helmholtz_operator_m.f90 sourcefile~helmholtz_solver_factory_m.f90->sourcefile~comm_handling_m.f90 sourcefile~helmholtz_solver_factory_m.f90->sourcefile~device_handling_m.f90 sourcefile~helmholtz_solver_factory_m.f90->sourcefile~multigrid_m.f90 sourcefile~splitting_m.f90 splitting_m.f90 sourcefile~helmholtz_solver_factory_m.f90->sourcefile~splitting_m.f90 sourcefile~map_factory_s.f90 map_factory_s.f90 sourcefile~map_factory_s.f90->sourcefile~comm_handling_m.f90 sourcefile~map_factory_s.f90->sourcefile~fieldline_tracer_m.f90 sourcefile~map_factory_s.f90->sourcefile~dommaschk_equilibrium_m.f90 sourcefile~interpolation_m.f90 interpolation_m.f90 sourcefile~map_factory_s.f90->sourcefile~interpolation_m.f90 sourcefile~map_factory_m.f90 map_factory_m.f90 sourcefile~map_factory_s.f90->sourcefile~map_factory_m.f90 sourcefile~mpi_mapping_auxiliaries_m.f90 mpi_mapping_auxiliaries_m.f90 sourcefile~map_factory_s.f90->sourcefile~mpi_mapping_auxiliaries_m.f90 sourcefile~mesh_cart_m.f90->sourcefile~comm_handling_m.f90 sourcefile~mesh_cart_m.f90->sourcefile~error_handling_m.f90 sourcefile~mesh_cart_m.f90->sourcefile~slab_equilibrium.f90 sourcefile~multigrid_m.f90->sourcefile~comm_handling_m.f90 sourcefile~multigrid_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~boundaries_perp.f90 boundaries_perp.f90 sourcefile~multigrid_m.f90->sourcefile~boundaries_perp.f90 sourcefile~multigrid_m.f90->sourcefile~csrmat_m.f90 sourcefile~numerical_equilibrium_m.f90->sourcefile~comm_handling_m.f90 sourcefile~numerical_equilibrium_m.f90->sourcefile~polygon_m.f90 sourcefile~divertor_equilibrium_m.f90 divertor_equilibrium_m.f90 sourcefile~numerical_equilibrium_m.f90->sourcefile~divertor_equilibrium_m.f90 sourcefile~perf_m.f90->sourcefile~comm_handling_m.f90 sourcefile~polar_grid_m.f90 polar_grid_m.f90 sourcefile~polar_grid_m.f90->sourcefile~comm_handling_m.f90 sourcefile~polar_grid_m.f90->sourcefile~coords_polar_m.f90 sourcefile~polar_grid_m.f90->sourcefile~circular_equilibrium_m.f90 sourcefile~polar_grid_m.f90->sourcefile~slab_equilibrium.f90 sourcefile~polar_map_factory_m.f90 polar_map_factory_m.f90 sourcefile~polar_map_factory_m.f90->sourcefile~comm_handling_m.f90 sourcefile~polar_map_factory_m.f90->sourcefile~coords_polar_m.f90 sourcefile~polar_map_factory_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~polar_map_factory_m.f90->sourcefile~polar_grid_m.f90 sourcefile~polar_map_factory_m.f90->sourcefile~csrmat_m.f90 sourcefile~polar_map_factory_m.f90->sourcefile~interpolation_m.f90 sourcefile~polygon_m.f90->sourcefile~comm_handling_m.f90 sourcefile~safety_factor_m.f90 safety_factor_m.f90 sourcefile~safety_factor_m.f90->sourcefile~comm_handling_m.f90 sourcefile~safety_factor_m.f90->sourcefile~coords_polar_m.f90 sourcefile~salpha_equilibrium_m.f90->sourcefile~comm_handling_m.f90 sourcefile~salpha_equilibrium_m.f90->sourcefile~error_handling_m.f90 sourcefile~params_equi_salpha_m.f90 params_equi_salpha_m.f90 sourcefile~salpha_equilibrium_m.f90->sourcefile~params_equi_salpha_m.f90 sourcefile~solver3d_m.f90 solver3d_m.f90 sourcefile~solver3d_m.f90->sourcefile~comm_handling_m.f90 sourcefile~solver3d_m.f90->sourcefile~error_handling_m.f90 sourcefile~splitting_m.f90->sourcefile~comm_handling_m.f90 sourcefile~splitting_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~splitting_m.f90->sourcefile~csrmat_m.f90 sourcefile~test_diffusion.f90 test_diffusion.f90 sourcefile~test_diffusion.f90->sourcefile~comm_handling_m.f90 sourcefile~test_diffusion.f90->sourcefile~equilibrium_factory_m.f90 sourcefile~test_diffusion.f90->sourcefile~error_handling_m.f90 sourcefile~test_diffusion.f90->sourcefile~fieldline_tracer_m.f90 sourcefile~test_diffusion.f90->sourcefile~mesh_cart_m.f90 sourcefile~test_diffusion.f90->sourcefile~perf_m.f90 sourcefile~vis_vtk3d_m.f90 vis_vtk3d_m.f90 sourcefile~test_diffusion.f90->sourcefile~vis_vtk3d_m.f90 sourcefile~test_diffusion.f90->sourcefile~csrmat_m.f90 sourcefile~test_diffusion.f90->sourcefile~map_factory_m.f90 sourcefile~test_diffusion.f90->sourcefile~mpi_mapping_auxiliaries_m.f90 sourcefile~vis_vtk3d_m.f90->sourcefile~comm_handling_m.f90 sourcefile~vis_vtk3d_m.f90->sourcefile~fieldline_tracer_m.f90 sourcefile~vis_vtk3d_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~zonal_averages_factory_m.f90 zonal_averages_factory_m.f90 sourcefile~zonal_averages_factory_m.f90->sourcefile~comm_handling_m.f90 sourcefile~zonal_averages_factory_m.f90->sourcefile~coords_polar_m.f90 sourcefile~zonal_averages_factory_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~zonal_averages_factory_m.f90->sourcefile~polar_grid_m.f90 sourcefile~zonal_averages_factory_m.f90->sourcefile~csrmat_m.f90 sourcefile~boundaries_perp.f90->sourcefile~error_handling_m.f90 sourcefile~boundaries_perp.f90->sourcefile~mesh_cart_m.f90 sourcefile~circular_equilibrium_m.f90->sourcefile~error_handling_m.f90 sourcefile~params_equi_circular_m.f90 params_equi_circular_m.f90 sourcefile~circular_equilibrium_m.f90->sourcefile~params_equi_circular_m.f90 sourcefile~circular_toroidal_equilibrium_m.f90->sourcefile~error_handling_m.f90 sourcefile~circular_toroidal_equilibrium_m.f90->sourcefile~kisslinger_m.f90 sourcefile~params_equi_circular_toroidal_m.f90 params_equi_circular_toroidal_m.f90 sourcefile~circular_toroidal_equilibrium_m.f90->sourcefile~params_equi_circular_toroidal_m.f90 sourcefile~connection_length_m.f90 connection_length_m.f90 sourcefile~connection_length_m.f90->sourcefile~error_handling_m.f90 sourcefile~connection_length_m.f90->sourcefile~fieldline_tracer_m.f90 sourcefile~csrmat_m.f90->sourcefile~error_handling_m.f90 sourcefile~divertor_equilibrium_m.f90->sourcefile~error_handling_m.f90 sourcefile~divertor_equilibrium_m.f90->sourcefile~polygon_m.f90 sourcefile~dommaschk_equilibrium_m.f90->sourcefile~error_handling_m.f90 sourcefile~dommaschk_equilibrium_m.f90->sourcefile~fieldline_tracer_m.f90 sourcefile~dommaschk_equilibrium_m.f90->sourcefile~polygon_m.f90 sourcefile~dommaschk_equilibrium_m.f90->sourcefile~interpolation_m.f90 sourcefile~dommaschk_equilibrium_m.f90->sourcefile~kisslinger_m.f90 sourcefile~params_equi_dommaschk_m.f90 params_equi_dommaschk_m.f90 sourcefile~dommaschk_equilibrium_m.f90->sourcefile~params_equi_dommaschk_m.f90 sourcefile~dommaschk_equilibrium_netcdf_s.f90 dommaschk_equilibrium_netcdf_s.f90 sourcefile~dommaschk_equilibrium_netcdf_s.f90->sourcefile~error_handling_m.f90 sourcefile~dommaschk_equilibrium_netcdf_s.f90->sourcefile~dommaschk_equilibrium_m.f90 sourcefile~error_handler_s.f90 error_handler_s.f90 sourcefile~error_handler_s.f90->sourcefile~error_handling_m.f90 sourcefile~error_info_s.f90 error_info_s.f90 sourcefile~error_info_s.f90->sourcefile~error_handling_m.f90 sourcefile~helmholtz_operator_m.f90->sourcefile~error_handling_m.f90 sourcefile~helmholtz_operator_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~helmholtz_operator_m.f90->sourcefile~boundaries_perp.f90 sourcefile~helmholtz_operator_m.f90->sourcefile~csrmat_m.f90 sourcefile~helmholtz_solver_mgmres_cxx_s.f90 helmholtz_solver_mgmres_cxx_s.f90 sourcefile~helmholtz_solver_mgmres_cxx_s.f90->sourcefile~device_handling_m.f90 sourcefile~immersed_factory_m.f90 immersed_factory_m.f90 sourcefile~immersed_factory_m.f90->sourcefile~error_handling_m.f90 sourcefile~immersed_factory_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~immersed_m.f90 immersed_m.f90 sourcefile~immersed_factory_m.f90->sourcefile~immersed_m.f90 sourcefile~immersed_rho_m.f90 immersed_rho_m.f90 sourcefile~immersed_factory_m.f90->sourcefile~immersed_rho_m.f90 sourcefile~immersed_trace_m.f90 immersed_trace_m.f90 sourcefile~immersed_factory_m.f90->sourcefile~immersed_trace_m.f90 sourcefile~immersed_vessel_m.f90 immersed_vessel_m.f90 sourcefile~immersed_factory_m.f90->sourcefile~immersed_vessel_m.f90 sourcefile~immersed_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~immersed_netcdf_s.f90 immersed_netcdf_s.f90 sourcefile~immersed_netcdf_s.f90->sourcefile~error_handling_m.f90 sourcefile~immersed_netcdf_s.f90->sourcefile~immersed_m.f90 sourcefile~immersed_rho_m.f90->sourcefile~error_handling_m.f90 sourcefile~immersed_rho_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~immersed_rho_m.f90->sourcefile~immersed_m.f90 sourcefile~immersed_trace_m.f90->sourcefile~error_handling_m.f90 sourcefile~immersed_trace_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~immersed_trace_m.f90->sourcefile~connection_length_m.f90 sourcefile~immersed_trace_m.f90->sourcefile~immersed_m.f90 sourcefile~immersed_vessel_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~immersed_vessel_m.f90->sourcefile~immersed_m.f90 sourcefile~initialise_numerical_equilibrium.f90 initialise_numerical_equilibrium.f90 sourcefile~initialise_numerical_equilibrium.f90->sourcefile~numerical_equilibrium_m.f90 sourcefile~initialise_numerical_equilibrium.f90->sourcefile~polygon_m.f90 sourcefile~interpolation_m.f90->sourcefile~error_handling_m.f90 sourcefile~kisslinger_m.f90->sourcefile~error_handling_m.f90 sourcefile~map_factory_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~map_factory_m.f90->sourcefile~csrmat_m.f90 sourcefile~mesh_cart_build_s.f90 mesh_cart_build_s.f90 sourcefile~mesh_cart_build_s.f90->sourcefile~mesh_cart_m.f90 sourcefile~mesh_cart_communicate_s.f90 mesh_cart_communicate_s.f90 sourcefile~mesh_cart_communicate_s.f90->sourcefile~mesh_cart_m.f90 sourcefile~mesh_cart_communicate_s.f90->sourcefile~mpi_mapping_auxiliaries_m.f90 sourcefile~mesh_cart_netcdfio_s.f90 mesh_cart_netcdfio_s.f90 sourcefile~mesh_cart_netcdfio_s.f90->sourcefile~mesh_cart_m.f90 sourcefile~mesh_cart_reorder_s.f90 mesh_cart_reorder_s.f90 sourcefile~mesh_cart_reorder_s.f90->sourcefile~mesh_cart_m.f90 sourcefile~mesh_cart_s.f90 mesh_cart_s.f90 sourcefile~mesh_cart_s.f90->sourcefile~mesh_cart_m.f90 sourcefile~multigrid_s.f90 multigrid_s.f90 sourcefile~multigrid_s.f90->sourcefile~multigrid_m.f90 sourcefile~multigrid_solver_m.f90 multigrid_solver_m.f90 sourcefile~multigrid_solver_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~multigrid_solver_m.f90->sourcefile~multigrid_m.f90 sourcefile~multigrid_solver_m.f90->sourcefile~splitting_m.f90 sourcefile~multigrid_solver_m.f90->sourcefile~boundaries_perp.f90 sourcefile~multigrid_solver_m.f90->sourcefile~csrmat_m.f90 sourcefile~multigrid_solver_m.f90->sourcefile~helmholtz_operator_m.f90 sourcefile~multigrid_solver_s.f90 multigrid_solver_s.f90 sourcefile~multigrid_solver_s.f90->sourcefile~error_handling_m.f90 sourcefile~multigrid_solver_s.f90->sourcefile~boundaries_perp.f90 sourcefile~multigrid_solver_s.f90->sourcefile~multigrid_solver_m.f90 sourcefile~params_equi_circular_m.f90->sourcefile~error_handling_m.f90 sourcefile~params_equi_circular_toroidal_m.f90->sourcefile~error_handling_m.f90 sourcefile~params_equi_dommaschk_m.f90->sourcefile~error_handling_m.f90 sourcefile~params_equi_flare_m.f90->sourcefile~error_handling_m.f90 sourcefile~params_equi_salpha_m.f90->sourcefile~error_handling_m.f90 sourcefile~params_equi_slab_m.f90 params_equi_slab_m.f90 sourcefile~params_equi_slab_m.f90->sourcefile~error_handling_m.f90 sourcefile~parbnd_taylor_m.f90 parbnd_taylor_m.f90 sourcefile~parbnd_taylor_m.f90->sourcefile~error_handling_m.f90 sourcefile~parbnd_taylor_m.f90->sourcefile~fieldline_tracer_m.f90 sourcefile~parbnd_taylor_m.f90->sourcefile~mesh_cart_m.f90 sourcefile~parbnd_taylor_m.f90->sourcefile~connection_length_m.f90 sourcefile~parbnd_taylor_netcdf_s.f90 parbnd_taylor_netcdf_s.f90 sourcefile~parbnd_taylor_netcdf_s.f90->sourcefile~error_handling_m.f90 sourcefile~parbnd_taylor_netcdf_s.f90->sourcefile~parbnd_taylor_m.f90 sourcefile~polar_grid_s.f90 polar_grid_s.f90 sourcefile~polar_grid_s.f90->sourcefile~polar_grid_m.f90 sourcefile~solver3d_cerfacs_s.f90 solver3d_CERFACS_s.f90 sourcefile~solver3d_cerfacs_s.f90->sourcefile~solver3d_m.f90 sourcefile~solver3d_factory_m.f90 solver3d_factory_m.f90 sourcefile~solver3d_factory_m.f90->sourcefile~error_handling_m.f90 sourcefile~solver3d_factory_m.f90->sourcefile~solver3d_m.f90 sourcefile~solver3d_pim_s.f90 solver3d_PIM_s.f90 sourcefile~solver3d_pim_s.f90->sourcefile~solver3d_m.f90 sourcefile~splitting_gauss_seidel_cpu_s.f90 splitting_gauss_seidel_cpu_s.f90 sourcefile~splitting_gauss_seidel_cpu_s.f90->sourcefile~splitting_m.f90 sourcefile~splitting_gauss_seidel_redblack_cpu_s.f90 splitting_gauss_seidel_redblack_cpu_s.f90 sourcefile~splitting_gauss_seidel_redblack_cpu_s.f90->sourcefile~splitting_m.f90 sourcefile~splitting_jacobi_cpu_s.f90 splitting_jacobi_cpu_s.f90 sourcefile~splitting_jacobi_cpu_s.f90->sourcefile~splitting_m.f90 sourcefile~testfunctions_m.f90->sourcefile~numerical_equilibrium_m.f90 sourcefile~testfunctions_m.f90->sourcefile~circular_equilibrium_m.f90 sourcefile~testfunctions_m.f90->sourcefile~slab_equilibrium.f90 sourcefile~analytic_divertor_equilibrium_m.f90->sourcefile~divertor_equilibrium_m.f90 sourcefile~csr_samples_m.f90 csr_samples_m.f90 sourcefile~csr_samples_m.f90->sourcefile~csrmat_m.f90 sourcefile~helpers_m.f90 helpers_m.f90 sourcefile~helpers_m.f90->sourcefile~csrmat_m.f90 sourcefile~mpi_mapping_auxiliaries_m.f90->sourcefile~csrmat_m.f90 sourcefile~slab_equilibrium.f90->sourcefile~params_equi_slab_m.f90

Source Code

module comm_handling_m
    !! Contains information about MPI processes and functionality to change
    !! the communicator.
    use MPI

    implicit none
    private

    integer :: communicator = MPI_COMM_WORLD
    !! Communicator used in the library
    integer :: master = 0
    !! Rank of the master process

    public :: get_communicator
    public :: setup_comm
    public :: is_master

contains

    integer function get_communicator()
        !! Returns the MPI communicator
        get_communicator = communicator
    end function

    subroutine setup_comm(comm, rank_master)
        !! Sets the communication to the given communicator. Allows to
        !! change the rank of the master proc.
        integer, intent(in) :: comm
        !! Communicator
        integer, optional, intent(in) :: rank_master
        !! Rank of the master process

        communicator = comm
        if(present(rank_master)) master = rank_master

    end subroutine

    logical function is_master()
        !! Returns if the current proc is the MPI master or not
        integer :: rank, ierr
        logical, save :: res = .false.
        logical, save :: visited = .false.

        if(.not. visited) then
            call MPI_COMM_RANK(communicator, rank, ierr)
            if (rank == master) then
                res = .true.
            else
                res = .false.
            endif
            visited = .true.
        end if
        is_master = res
    end function

end module