LCOV - code coverage report
Current view: top level - src/motion - md_environment_types.F (source / functions) Hit Total Coverage
Test: CP2K Regtests (git:a24d8ac) Lines: 119 137 86.9 %
Date: 2025-01-02 07:24:57 Functions: 5 6 83.3 %

          Line data    Source code
       1             : !--------------------------------------------------------------------------------------------------!
       2             : !   CP2K: A general program to perform molecular dynamics simulations                              !
       3             : !   Copyright 2000-2025 CP2K developers group <https://cp2k.org>                                   !
       4             : !                                                                                                  !
       5             : !   SPDX-License-Identifier: GPL-2.0-or-later                                                      !
       6             : !--------------------------------------------------------------------------------------------------!
       7             : 
       8             : ! **************************************************************************************************
       9             : !> \par History
      10             : !>      give the md_env its own para_env Joost VandeVondele 07.2003
      11             : !>      Teodoro Laino - 09.2007 - University of Zurich - generalizing thermostats
      12             : !>                                and barostats
      13             : !> \author CJM SEPT-12-02
      14             : ! **************************************************************************************************
      15             : MODULE md_environment_types
      16             :    USE averages_types,                  ONLY: average_quantities_type,&
      17             :                                               create_averages,&
      18             :                                               release_averages,&
      19             :                                               retain_averages
      20             :    USE barostat_types,                  ONLY: barostat_type,&
      21             :                                               release_barostat_type
      22             :    USE cell_types,                      ONLY: cell_type
      23             :    USE extended_system_types,           ONLY: npt_info_type
      24             :    USE force_env_types,                 ONLY: force_env_release,&
      25             :                                               force_env_retain,&
      26             :                                               force_env_type
      27             :    USE free_energy_types,               ONLY: fe_env_release,&
      28             :                                               free_energy_type
      29             :    USE input_constants,                 ONLY: do_thermo_al,&
      30             :                                               langevin_ensemble
      31             :    USE input_section_types,             ONLY: section_vals_get_subs_vals,&
      32             :                                               section_vals_type
      33             :    USE kinds,                           ONLY: dp
      34             :    USE md_ener_types,                   ONLY: md_ener_type,&
      35             :                                               release_md_ener
      36             :    USE message_passing,                 ONLY: mp_para_env_release,&
      37             :                                               mp_para_env_type
      38             :    USE reftraj_types,                   ONLY: reftraj_type,&
      39             :                                               release_reftraj
      40             :    USE simpar_types,                    ONLY: simpar_type
      41             :    USE thermal_region_types,            ONLY: release_thermal_regions,&
      42             :                                               thermal_regions_type
      43             :    USE thermostat_types,                ONLY: release_thermostats,&
      44             :                                               thermostat_type,&
      45             :                                               thermostats_type
      46             : #include "../base/base_uses.f90"
      47             : 
      48             :    IMPLICIT NONE
      49             : 
      50             :    PRIVATE
      51             : 
      52             : ! **************************************************************************************************
      53             :    TYPE md_environment_type
      54             :       ! para_env is the parallel environment of the MD,  i.e. the systems
      55             :       ! that are dealt with by the integrator e.g in the PIMD this could
      56             :       ! be parent of every bead.
      57             :       PRIVATE
      58             :       LOGICAL                                    :: init = .FALSE., first_time = .FALSE., ehrenfest_md = .FALSE.
      59             :       INTEGER, POINTER                           :: itimes => NULL()
      60             :       REAL(KIND=dp), POINTER                     :: used_time => NULL(), t => NULL()
      61             :       REAL(KIND=dp), POINTER                     :: constant => NULL()
      62             :       TYPE(mp_para_env_type), POINTER            :: para_env => NULL()
      63             :       TYPE(cell_type), POINTER                   :: cell => NULL()
      64             :       TYPE(force_env_type), POINTER              :: force_env => NULL()
      65             :       TYPE(md_ener_type), POINTER                :: md_ener => NULL()
      66             :       TYPE(thermostats_type), POINTER            :: thermostats => NULL()
      67             :       TYPE(barostat_type), POINTER               :: barostat => NULL()
      68             :       TYPE(reftraj_type), POINTER                :: reftraj => NULL()
      69             :       TYPE(free_energy_type), POINTER           :: fe_env => NULL()
      70             :       TYPE(simpar_type), POINTER                 :: simpar => NULL()
      71             :       TYPE(average_quantities_type), POINTER     :: averages => NULL()
      72             :       TYPE(thermal_regions_type), POINTER        :: thermal_regions => NULL()
      73             :    END TYPE md_environment_type
      74             : 
      75             :    ! *** Public subroutines and data types ***
      76             :    PUBLIC :: md_environment_type, set_md_env, get_md_env, md_env_create, &
      77             :              md_env_release, need_per_atom_wiener_process
      78             : 
      79             :    ! *** Global parameters ***
      80             :    CHARACTER(len=*), PARAMETER, PRIVATE :: moduleN = 'md_environment_types'
      81             : 
      82             : CONTAINS
      83             : 
      84             : ! **************************************************************************************************
      85             : !> \brief Creates MD environment
      86             : !>      Purpose: Initialise the integrator environment.
      87             : !>      retain the para_env for this environment (should be used for parallel
      88             : !>      communications)
      89             : !> \param md_env the force environment to retain
      90             : !> \param md_section ...
      91             : !> \param para_env ...
      92             : !> \param force_env ...
      93             : ! **************************************************************************************************
      94        1786 :    SUBROUTINE md_env_create(md_env, md_section, para_env, force_env)
      95             :       TYPE(md_environment_type), INTENT(OUT)             :: md_env
      96             :       TYPE(section_vals_type), POINTER                   :: md_section
      97             :       TYPE(mp_para_env_type), POINTER                    :: para_env
      98             :       TYPE(force_env_type), POINTER                      :: force_env
      99             : 
     100             :       TYPE(section_vals_type), POINTER                   :: averages_section
     101             : 
     102        1786 :       md_env%para_env => para_env
     103        1786 :       CALL md_env%para_env%retain()
     104        1786 :       ALLOCATE (md_env%itimes)
     105        1786 :       ALLOCATE (md_env%constant)
     106        1786 :       ALLOCATE (md_env%used_time)
     107        1786 :       ALLOCATE (md_env%t)
     108        1786 :       md_env%itimes = -1
     109        1786 :       md_env%constant = 0.0_dp
     110        1786 :       md_env%used_time = 0.0_dp
     111        1786 :       md_env%t = 0.0_dp
     112        1786 :       md_env%init = .TRUE.
     113        1786 :       md_env%first_time = .TRUE.
     114        1786 :       md_env%ehrenfest_md = .FALSE.
     115        1786 :       averages_section => section_vals_get_subs_vals(md_section, "AVERAGES")
     116        1786 :       CALL create_averages(md_env%averages, averages_section, force_env=force_env)
     117             : 
     118        1786 :    END SUBROUTINE md_env_create
     119             : 
     120             : ! **************************************************************************************************
     121             : !> \brief releases the given md env
     122             : !> \param md_env the md environment to release
     123             : !> \par History
     124             : !>      04.2003 created [fawzi]
     125             : !> \author fawzi
     126             : ! **************************************************************************************************
     127        1786 :    SUBROUTINE md_env_release(md_env)
     128             :       TYPE(md_environment_type), INTENT(INOUT)           :: md_env
     129             : 
     130        1786 :       CALL fe_env_release(md_env%fe_env)
     131        1786 :       CALL mp_para_env_release(md_env%para_env)
     132        1786 :       DEALLOCATE (md_env%itimes)
     133        1786 :       DEALLOCATE (md_env%constant)
     134        1786 :       DEALLOCATE (md_env%used_time)
     135        1786 :       DEALLOCATE (md_env%t)
     136             : 
     137        1786 :       NULLIFY (md_env%cell)
     138        1786 :       NULLIFY (md_env%simpar)
     139        1786 :       CALL release_barostat_type(md_env%barostat)
     140        1786 :       IF (ASSOCIATED(md_env%thermostats)) THEN
     141         542 :          CALL release_thermostats(md_env%thermostats)
     142         542 :          DEALLOCATE (md_env%thermostats)
     143             :       END IF
     144        1786 :       IF (ASSOCIATED(md_env%reftraj)) THEN
     145          38 :          CALL release_reftraj(md_env%reftraj)
     146          38 :          DEALLOCATE (md_env%reftraj)
     147             :       END IF
     148        1786 :       IF (ASSOCIATED(md_env%md_ener)) THEN
     149        1786 :          CALL release_md_ener(md_env%md_ener)
     150        1786 :          DEALLOCATE (md_env%md_ener)
     151             :       END IF
     152        1786 :       CALL force_env_release(md_env%force_env)
     153        1786 :       CALL release_averages(md_env%averages)
     154        1786 :       IF (ASSOCIATED(md_env%thermal_regions)) THEN
     155          14 :          CALL release_thermal_regions(md_env%thermal_regions)
     156          14 :          DEALLOCATE (md_env%thermal_regions)
     157             :       END IF
     158             : 
     159        1786 :    END SUBROUTINE md_env_release
     160             : 
     161             : ! **************************************************************************************************
     162             : !> \brief get components of MD environment type
     163             : !> \param md_env the force environment to retain
     164             : !> \param itimes ...
     165             : !> \param constant ...
     166             : !> \param used_time ...
     167             : !> \param cell ...
     168             : !> \param simpar ...
     169             : !> \param npt ...
     170             : !> \param force_env ...
     171             : !> \param para_env ...
     172             : !> \param reftraj ...
     173             : !> \param t ...
     174             : !> \param init ...
     175             : !> \param first_time ...
     176             : !> \param fe_env ...
     177             : !> \param thermostats ...
     178             : !> \param barostat ...
     179             : !> \param thermostat_coeff ...
     180             : !> \param thermostat_part ...
     181             : !> \param thermostat_shell ...
     182             : !> \param thermostat_baro ...
     183             : !> \param thermostat_fast ...
     184             : !> \param thermostat_slow ...
     185             : !> \param md_ener ...
     186             : !> \param averages ...
     187             : !> \param thermal_regions ...
     188             : !> \param ehrenfest_md ...
     189             : ! **************************************************************************************************
     190      534693 :    SUBROUTINE get_md_env(md_env, itimes, constant, used_time, cell, simpar, npt, &
     191             :                          force_env, para_env, reftraj, t, init, first_time, fe_env, thermostats, barostat, &
     192             :                          thermostat_coeff, thermostat_part, thermostat_shell, thermostat_baro, &
     193             :                          thermostat_fast, thermostat_slow, md_ener, averages, &
     194             :                          thermal_regions, ehrenfest_md)
     195             : 
     196             :       TYPE(md_environment_type), INTENT(IN)              :: md_env
     197             :       INTEGER, OPTIONAL, POINTER                         :: itimes
     198             :       REAL(KIND=dp), OPTIONAL, POINTER                   :: constant, used_time
     199             :       TYPE(cell_type), OPTIONAL, POINTER                 :: cell
     200             :       TYPE(simpar_type), OPTIONAL, POINTER               :: simpar
     201             :       TYPE(npt_info_type), OPTIONAL, POINTER             :: npt(:, :)
     202             :       TYPE(force_env_type), OPTIONAL, POINTER            :: force_env
     203             :       TYPE(mp_para_env_type), OPTIONAL, POINTER          :: para_env
     204             :       TYPE(reftraj_type), OPTIONAL, POINTER              :: reftraj
     205             :       REAL(KIND=dp), OPTIONAL, POINTER                   :: t
     206             :       LOGICAL, OPTIONAL                                  :: init, first_time
     207             :       TYPE(free_energy_type), OPTIONAL, POINTER          :: fe_env
     208             :       TYPE(thermostats_type), OPTIONAL, POINTER          :: thermostats
     209             :       TYPE(barostat_type), OPTIONAL, POINTER             :: barostat
     210             :       TYPE(thermostat_type), OPTIONAL, POINTER           :: thermostat_coeff, thermostat_part, &
     211             :                                                             thermostat_shell, thermostat_baro, &
     212             :                                                             thermostat_fast, thermostat_slow
     213             :       TYPE(md_ener_type), OPTIONAL, POINTER              :: md_ener
     214             :       TYPE(average_quantities_type), OPTIONAL, POINTER   :: averages
     215             :       TYPE(thermal_regions_type), OPTIONAL, POINTER      :: thermal_regions
     216             :       LOGICAL, OPTIONAL                                  :: ehrenfest_md
     217             : 
     218      534693 :       IF (PRESENT(itimes)) itimes => md_env%itimes
     219      534693 :       IF (PRESENT(fe_env)) fe_env => md_env%fe_env
     220      534693 :       IF (PRESENT(constant)) constant => md_env%constant
     221      534693 :       IF (PRESENT(used_time)) used_time => md_env%used_time
     222      534693 :       IF (PRESENT(t)) t => md_env%t
     223      534693 :       IF (PRESENT(cell)) cell => md_env%cell
     224      534693 :       IF (PRESENT(simpar)) simpar => md_env%simpar
     225      534693 :       IF (PRESENT(thermostats)) thermostats => md_env%thermostats
     226      534693 :       IF (PRESENT(barostat)) barostat => md_env%barostat
     227             :       IF (PRESENT(thermostat_part) .OR. PRESENT(thermostat_coeff) .OR. &
     228             :           PRESENT(thermostat_baro) .OR. PRESENT(thermostat_shell) .OR. &
     229      534693 :           PRESENT(thermostat_fast) .OR. PRESENT(thermostat_slow)) THEN
     230       89450 :          IF (ASSOCIATED(md_env%thermostats)) THEN
     231       21562 :             IF (PRESENT(thermostat_part)) THEN
     232       21146 :                thermostat_part => md_env%thermostats%thermostat_part
     233             :             END IF
     234       21562 :             IF (PRESENT(thermostat_coeff)) THEN
     235       15258 :                thermostat_coeff => md_env%thermostats%thermostat_coef
     236             :             END IF
     237       21562 :             IF (PRESENT(thermostat_shell)) THEN
     238       21562 :                thermostat_shell => md_env%thermostats%thermostat_shell
     239             :             END IF
     240       21562 :             IF (PRESENT(thermostat_fast)) THEN
     241           0 :                thermostat_fast => md_env%thermostats%thermostat_fast
     242             :             END IF
     243       21562 :             IF (PRESENT(thermostat_slow)) THEN
     244           0 :                thermostat_slow => md_env%thermostats%thermostat_slow
     245             :             END IF
     246       21562 :             IF (PRESENT(thermostat_baro)) THEN
     247        6128 :                thermostat_baro => md_env%thermostats%thermostat_baro
     248             :             END IF
     249             :          END IF
     250             :       END IF
     251      534693 :       IF (PRESENT(npt)) THEN
     252       10762 :          IF (ASSOCIATED(md_env%barostat)) THEN
     253        5648 :             npt => md_env%barostat%npt
     254             :          END IF
     255             :       END IF
     256      534693 :       IF (PRESENT(averages)) averages => md_env%averages
     257      534693 :       IF (PRESENT(force_env)) force_env => md_env%force_env
     258      534693 :       IF (PRESENT(para_env)) para_env => md_env%para_env
     259      534693 :       IF (PRESENT(reftraj)) reftraj => md_env%reftraj
     260      534693 :       IF (PRESENT(md_ener)) md_ener => md_env%md_ener
     261      534693 :       IF (PRESENT(init)) init = md_env%init
     262      534693 :       IF (PRESENT(first_time)) first_time = md_env%first_time
     263      534693 :       IF (PRESENT(ehrenfest_md)) ehrenfest_md = md_env%ehrenfest_md
     264      534693 :       IF (PRESENT(thermal_regions)) thermal_regions => md_env%thermal_regions
     265             : 
     266      534693 :    END SUBROUTINE get_md_env
     267             : 
     268             : ! **************************************************************************************************
     269             : !> \brief Set the integrator environment to the correct program.
     270             : !> \param md_env the force environment to retain
     271             : !> \param itimes ...
     272             : !> \param constant ...
     273             : !> \param cell ...
     274             : !> \param simpar ...
     275             : !> \param fe_env ...
     276             : !> \param force_env ...
     277             : !> \param para_env ...
     278             : !> \param init ...
     279             : !> \param first_time ...
     280             : !> \param thermostats ...
     281             : !> \param barostat ...
     282             : !> \param reftraj ...
     283             : !> \param md_ener ...
     284             : !> \param averages ...
     285             : !> \param thermal_regions ...
     286             : !> \param ehrenfest_md ...
     287             : ! **************************************************************************************************
     288       52321 :    SUBROUTINE set_md_env(md_env, itimes, constant, cell, simpar, fe_env, force_env, &
     289             :                          para_env, init, first_time, thermostats, barostat, reftraj, md_ener, averages, &
     290             :                          thermal_regions, ehrenfest_md)
     291             : 
     292             :       TYPE(md_environment_type), INTENT(INOUT)           :: md_env
     293             :       INTEGER, OPTIONAL, POINTER                         :: itimes
     294             :       REAL(KIND=dp), OPTIONAL, POINTER                   :: constant
     295             :       TYPE(cell_type), OPTIONAL, POINTER                 :: cell
     296             :       TYPE(simpar_type), OPTIONAL, POINTER               :: simpar
     297             :       TYPE(free_energy_type), OPTIONAL, POINTER          :: fe_env
     298             :       TYPE(force_env_type), OPTIONAL, POINTER            :: force_env
     299             :       TYPE(mp_para_env_type), OPTIONAL, POINTER          :: para_env
     300             :       LOGICAL, OPTIONAL                                  :: init, first_time
     301             :       TYPE(thermostats_type), OPTIONAL, POINTER          :: thermostats
     302             :       TYPE(barostat_type), OPTIONAL, POINTER             :: barostat
     303             :       TYPE(reftraj_type), OPTIONAL, POINTER              :: reftraj
     304             :       TYPE(md_ener_type), OPTIONAL, POINTER              :: md_ener
     305             :       TYPE(average_quantities_type), OPTIONAL, POINTER   :: averages
     306             :       TYPE(thermal_regions_type), OPTIONAL, POINTER      :: thermal_regions
     307             :       LOGICAL, OPTIONAL                                  :: ehrenfest_md
     308             : 
     309       52321 :       IF (PRESENT(init)) md_env%init = init
     310       52321 :       IF (PRESENT(first_time)) md_env%first_time = first_time
     311       52321 :       IF (PRESENT(ehrenfest_md)) md_env%ehrenfest_md = ehrenfest_md
     312       52321 :       IF (PRESENT(cell)) md_env%cell => cell
     313       52321 :       IF (PRESENT(barostat)) THEN
     314        1786 :          IF (ASSOCIATED(md_env%barostat)) THEN
     315           0 :          IF (.NOT. ASSOCIATED(md_env%barostat, barostat)) THEN
     316           0 :             CALL release_barostat_type(md_env%barostat)
     317             :          END IF
     318             :          END IF
     319        1786 :          md_env%barostat => barostat
     320             :       END IF
     321       52321 :       IF (PRESENT(thermostats)) THEN
     322        1786 :          IF (ASSOCIATED(md_env%thermostats)) THEN
     323           0 :          IF (.NOT. ASSOCIATED(md_env%thermostats, thermostats)) THEN
     324           0 :             CALL release_thermostats(md_env%thermostats)
     325           0 :             DEALLOCATE (md_env%thermostats)
     326             :          END IF
     327             :          END IF
     328        1786 :          md_env%thermostats => thermostats
     329             :       END IF
     330       52321 :       IF (PRESENT(simpar)) md_env%simpar => simpar
     331       52321 :       IF (PRESENT(itimes)) md_env%itimes => itimes
     332       52321 :       IF (PRESENT(fe_env)) md_env%fe_env => fe_env
     333       52321 :       IF (PRESENT(constant)) md_env%constant => constant
     334       52321 :       IF (PRESENT(para_env)) md_env%para_env => para_env
     335       52321 :       IF (PRESENT(force_env)) THEN
     336        1786 :          IF (ASSOCIATED(force_env)) THEN
     337        1786 :             CALL force_env_retain(force_env)
     338             :          END IF
     339        1786 :          IF (ASSOCIATED(md_env%force_env)) THEN
     340           0 :             CALL force_env_release(md_env%force_env)
     341             :          END IF
     342        1786 :          md_env%force_env => force_env
     343             :       END IF
     344       52321 :       IF (PRESENT(reftraj)) THEN
     345          38 :          IF (ASSOCIATED(md_env%reftraj)) THEN
     346           0 :          IF (.NOT. ASSOCIATED(md_env%reftraj, reftraj)) THEN
     347           0 :             CALL release_reftraj(md_env%reftraj)
     348           0 :             DEALLOCATE (md_env%reftraj)
     349             :          END IF
     350             :          END IF
     351          38 :          md_env%reftraj => reftraj
     352             :       END IF
     353       52321 :       IF (PRESENT(md_ener)) THEN
     354        1786 :          IF (ASSOCIATED(md_env%md_ener)) THEN
     355           0 :             IF (.NOT. ASSOCIATED(md_env%md_ener, md_ener)) THEN
     356           0 :                CALL release_md_ener(md_env%md_ener)
     357           0 :                DEALLOCATE (md_env%md_ener)
     358             :             END IF
     359             :          END IF
     360        1786 :          md_env%md_ener => md_ener
     361             :       END IF
     362       52321 :       IF (PRESENT(averages)) THEN
     363          20 :          CALL release_averages(md_env%averages)
     364          20 :          CALL retain_averages(averages)
     365          20 :          md_env%averages => averages
     366             :       END IF
     367       52321 :       IF (PRESENT(thermal_regions)) THEN
     368        1786 :          IF (ASSOCIATED(md_env%thermal_regions)) THEN
     369           0 :             IF (.NOT. ASSOCIATED(md_env%thermal_regions, thermal_regions)) THEN
     370           0 :                CALL release_thermal_regions(md_env%thermal_regions)
     371           0 :                DEALLOCATE (md_env%thermal_regions)
     372             :             END IF
     373             :          END IF
     374        1786 :          md_env%thermal_regions => thermal_regions
     375             :       END IF
     376             : 
     377       52321 :    END SUBROUTINE set_md_env
     378             : 
     379             : ! **************************************************************************************************
     380             : !> \brief ...
     381             : !> \param md_env ...
     382             : !> \return ...
     383             : !> \par History
     384             : !>      02.2012 created [noamb]
     385             : !> \author Noam Bernstein
     386             : ! **************************************************************************************************
     387        1830 :    PURE FUNCTION need_per_atom_wiener_process(md_env)
     388             :       TYPE(md_environment_type), INTENT(IN)              :: md_env
     389             :       LOGICAL                                            :: need_per_atom_wiener_process
     390             : 
     391             : ! return value
     392             : ! check for Langevin ensemble
     393             : 
     394        1830 :       need_per_atom_wiener_process = (md_env%simpar%ensemble == langevin_ensemble)
     395        1830 :       IF (need_per_atom_wiener_process) RETURN
     396             : 
     397             :       ! check for adaptive-Langevin thermostat
     398        1746 :       IF (.NOT. ASSOCIATED(md_env%thermostats)) RETURN
     399         546 :       IF (.NOT. ASSOCIATED(md_env%thermostats%thermostat_part)) RETURN
     400         530 :       need_per_atom_wiener_process = (md_env%thermostats%thermostat_part%type_of_thermostat == do_thermo_al)
     401             : 
     402         530 :    END FUNCTION need_per_atom_wiener_process
     403             : 
     404           0 : END MODULE md_environment_types

Generated by: LCOV version 1.15