LCOV - code coverage report
Current view: top level - src/common - distribution_1d_types.F (source / functions) Hit Total Coverage
Test: CP2K Regtests (git:262480d) Lines: 47 52 90.4 %
Date: 2024-11-22 07:00:40 Functions: 3 5 60.0 %

          Line data    Source code
       1             : !--------------------------------------------------------------------------------------------------!
       2             : !   CP2K: A general program to perform molecular dynamics simulations                              !
       3             : !   Copyright 2000-2024 CP2K developers group <https://cp2k.org>                                   !
       4             : !                                                                                                  !
       5             : !   SPDX-License-Identifier: GPL-2.0-or-later                                                      !
       6             : !--------------------------------------------------------------------------------------------------!
       7             : 
       8             : ! **************************************************************************************************
       9             : !> \brief stores a lists of integer that are local to a processor.
      10             : !>      The idea is that these integers represent objects that are distributed
      11             : !>      between the different processors.
      12             : !>      The ordering is just to make some operation more efficient, logically
      13             : !>      these lists are like sets.
      14             : !>      Some operations assume that the integers represent a range of values
      15             : !>      from 1 to a (not too big) maxval, and that an element is present just
      16             : !>      once, and only on a processor (these assumption are marked in the
      17             : !>      documentation of such operations).
      18             : !>      The concrete task for which this structure was developed was
      19             : !>      distributing atoms between the processors.
      20             : !> \par History
      21             : !>      05.2002 created [fawzi]
      22             : !> \author Fawzi Mohamed
      23             : ! **************************************************************************************************
      24             : MODULE distribution_1d_types
      25             : 
      26             :    USE cp_array_utils,                  ONLY: cp_1d_i_p_type
      27             :    USE message_passing,                 ONLY: mp_para_env_release,&
      28             :                                               mp_para_env_type
      29             :    USE parallel_rng_types,              ONLY: rng_stream_p_type
      30             : #include "../base/base_uses.f90"
      31             : 
      32             :    IMPLICIT NONE
      33             : 
      34             :    PRIVATE
      35             : 
      36             :    LOGICAL, PRIVATE, PARAMETER :: debug_this_module = .TRUE.
      37             :    CHARACTER(len=*), PARAMETER, PRIVATE :: moduleN = 'distribution_1d_types'
      38             : 
      39             :    PUBLIC :: distribution_1d_type
      40             :    PUBLIC :: distribution_1d_create, distribution_1d_retain, distribution_1d_release
      41             : 
      42             : ! **************************************************************************************************
      43             :    TYPE local_particle_type
      44             :       TYPE(rng_stream_p_type), DIMENSION(:), POINTER :: rng => NULL()
      45             :    END TYPE local_particle_type
      46             : !***
      47             : 
      48             : ! **************************************************************************************************
      49             : !> \brief structure to store local (to a processor) ordered lists of integers.
      50             : !> \param ref_count reference count (see doc/ReferenceCounting.html)
      51             : !> \param n_el n_el(i) is number of elements of list(i)
      52             : !> \param list list(i) contains an ordered list of integer (the array
      53             : !>        might be bigger than n_el(i), but the extra elements should be
      54             : !>        ignored)
      55             : !> \param para_env the parallel environment underlying the distribution
      56             : !> \param listbased_distribution true if each list has its own
      57             : !>        distribution
      58             : !> \par History
      59             : !>      06.2002 created [fawzi]
      60             : !> \author Fawzi Mohamed
      61             : ! **************************************************************************************************
      62             :    TYPE distribution_1d_type
      63             :       INTEGER :: ref_count = -1
      64             :       LOGICAL :: listbased_distribution = .FALSE.
      65             :       INTEGER, DIMENSION(:), POINTER :: n_el => NULL()
      66             :       TYPE(cp_1d_i_p_type), DIMENSION(:), POINTER :: list => NULL()
      67             :       TYPE(mp_para_env_type), POINTER :: para_env => NULL()
      68             :       TYPE(local_particle_type), DIMENSION(:), POINTER :: local_particle_set => NULL()
      69             :    END TYPE distribution_1d_type
      70             : 
      71             : CONTAINS
      72             : 
      73             : ! **************************************************************************************************
      74             : !> \brief creates a local list
      75             : !> \param distribution_1d the lists to create
      76             : !> \param para_env parallel environment to be used
      77             : !> \param listbased_distribution if each list has its own distribution
      78             : !>        (defaults to false)
      79             : !> \param n_el number of elements in each list (defaults to 0)
      80             : !> \param n_lists number of lists to create (defaults to 1, or size(n_el))
      81             : !> \par History
      82             : !>      05.2002 created [fawzi]
      83             : !> \author Fawzi Mohamed
      84             : ! **************************************************************************************************
      85       20862 :    SUBROUTINE distribution_1d_create(distribution_1d, para_env, listbased_distribution, &
      86       20862 :                                      n_el, n_lists)
      87             :       TYPE(distribution_1d_type), POINTER                :: distribution_1d
      88             :       TYPE(mp_para_env_type), POINTER                    :: para_env
      89             :       LOGICAL, INTENT(in), OPTIONAL                      :: listbased_distribution
      90             :       INTEGER, DIMENSION(:), INTENT(in), OPTIONAL        :: n_el
      91             :       INTEGER, INTENT(in), OPTIONAL                      :: n_lists
      92             : 
      93             :       INTEGER                                            :: ilist, my_n_lists
      94             : 
      95       20862 :       my_n_lists = 1
      96       20862 :       IF (PRESENT(n_el)) my_n_lists = SIZE(n_el)
      97       20862 :       IF (PRESENT(n_lists)) my_n_lists = n_lists
      98             : 
      99       20862 :       ALLOCATE (distribution_1d)
     100             : 
     101       20862 :       distribution_1d%ref_count = 1
     102             : 
     103       20862 :       distribution_1d%para_env => para_env
     104       20862 :       CALL para_env%retain()
     105             : 
     106       20862 :       distribution_1d%listbased_distribution = .FALSE.
     107       20862 :       IF (PRESENT(listbased_distribution)) &
     108           0 :          distribution_1d%listbased_distribution = listbased_distribution
     109             : 
     110      265609 :       ALLOCATE (distribution_1d%n_el(my_n_lists), distribution_1d%list(my_n_lists))
     111             : 
     112       20862 :       IF (PRESENT(n_el)) THEN
     113      182161 :          distribution_1d%n_el(1:my_n_lists) = n_el(1:my_n_lists)
     114      182161 :          DO ilist = 1, my_n_lists
     115      414434 :             ALLOCATE (distribution_1d%list(ilist)%array(n_el(ilist)))
     116      762070 :             distribution_1d%list(ilist)%array = -1
     117             :          END DO
     118             :       ELSE
     119           0 :          distribution_1d%n_el(1:my_n_lists) = 0
     120           0 :          DO ilist = 1, my_n_lists
     121           0 :             NULLIFY (distribution_1d%list(ilist)%array)
     122             :          END DO
     123             :       END IF
     124             : 
     125       20862 :    END SUBROUTINE distribution_1d_create
     126             : 
     127             : ! **************************************************************************************************
     128             : !> \brief retains a distribution_1d
     129             : !> \param distribution_1d  the object to retain
     130             : !> \par History
     131             : !>      05.2002 created [fawzi]
     132             : !> \author Fawzi Mohamed
     133             : ! **************************************************************************************************
     134       19454 :    SUBROUTINE distribution_1d_retain(distribution_1d)
     135             :       TYPE(distribution_1d_type), INTENT(INOUT)          :: distribution_1d
     136             : 
     137       19454 :       CPASSERT(distribution_1d%ref_count > 0)
     138       19454 :       distribution_1d%ref_count = distribution_1d%ref_count + 1
     139       19454 :    END SUBROUTINE distribution_1d_retain
     140             : 
     141             : ! **************************************************************************************************
     142             : !> \brief releases the given distribution_1d
     143             : !> \param distribution_1d the object to release
     144             : !> \par History
     145             : !>      05.2002 created [fawzi]
     146             : !> \author Fawzi Mohamed
     147             : ! **************************************************************************************************
     148       59334 :    SUBROUTINE distribution_1d_release(distribution_1d)
     149             :       TYPE(distribution_1d_type), POINTER                :: distribution_1d
     150             : 
     151             :       INTEGER                                            :: ilist, iparticle_kind, iparticle_local, &
     152             :                                                             nparticle_kind, nparticle_local
     153       59334 :       TYPE(local_particle_type), DIMENSION(:), POINTER   :: local_particle_set
     154             : 
     155       59334 :       IF (ASSOCIATED(distribution_1d)) THEN
     156       40316 :          CPASSERT(distribution_1d%ref_count > 0)
     157       40316 :          distribution_1d%ref_count = distribution_1d%ref_count - 1
     158       40316 :          IF (distribution_1d%ref_count == 0) THEN
     159       20862 :             DEALLOCATE (distribution_1d%n_el)
     160             : 
     161      182161 :             DO ilist = 1, SIZE(distribution_1d%list)
     162      182161 :                DEALLOCATE (distribution_1d%list(ilist)%array)
     163             :             END DO
     164       20862 :             DEALLOCATE (distribution_1d%list)
     165             : 
     166             :             !MK Delete Wiener process
     167             : 
     168       20862 :             local_particle_set => distribution_1d%local_particle_set
     169             : 
     170       20862 :             IF (ASSOCIATED(local_particle_set)) THEN
     171          48 :                nparticle_kind = SIZE(local_particle_set)
     172         812 :                DO iparticle_kind = 1, nparticle_kind
     173         812 :                   IF (ASSOCIATED(local_particle_set(iparticle_kind)%rng)) THEN
     174         764 :                      nparticle_local = SIZE(local_particle_set(iparticle_kind)%rng)
     175       21788 :                      DO iparticle_local = 1, nparticle_local
     176       21024 :                         IF (ASSOCIATED(local_particle_set(iparticle_kind)% &
     177         764 :                                        rng(iparticle_local)%stream)) THEN
     178             :                            DEALLOCATE (local_particle_set(iparticle_kind)% &
     179       21024 :                                        rng(iparticle_local)%stream)
     180             :                         END IF
     181             :                      END DO
     182         764 :                      DEALLOCATE (local_particle_set(iparticle_kind)%rng)
     183             :                   END IF
     184             :                END DO
     185          48 :                DEALLOCATE (local_particle_set)
     186             :             END IF
     187             : 
     188       20862 :             CALL mp_para_env_release(distribution_1d%para_env)
     189             : 
     190       20862 :             DEALLOCATE (distribution_1d)
     191             :          END IF
     192             :       END IF
     193             : 
     194       59334 :    END SUBROUTINE distribution_1d_release
     195             : 
     196           0 : END MODULE distribution_1d_types

Generated by: LCOV version 1.15