LCOV - code coverage report
Current view: top level - src - qs_force_types.F (source / functions) Hit Total Coverage
Test: CP2K Regtests (git:4dc10b3) Lines: 184 235 78.3 %
Date: 2024-11-21 06:45:46 Functions: 7 11 63.6 %

          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             : !> \par History
      10             : !>      Add CP2K error reporting, new add_force routine [07.2014,JGH]
      11             : !> \author MK (03.06.2002)
      12             : ! **************************************************************************************************
      13             : MODULE qs_force_types
      14             : 
      15             :    USE atomic_kind_types,               ONLY: atomic_kind_type,&
      16             :                                               get_atomic_kind
      17             :    USE cp_log_handling,                 ONLY: cp_get_default_logger,&
      18             :                                               cp_logger_get_default_io_unit,&
      19             :                                               cp_logger_type
      20             :    USE kinds,                           ONLY: dp
      21             :    USE message_passing,                 ONLY: mp_para_env_type
      22             : #include "./base/base_uses.f90"
      23             : 
      24             :    IMPLICIT NONE
      25             :    CHARACTER(len=*), PARAMETER, PRIVATE :: moduleN = 'qs_force_types'
      26             :    PRIVATE
      27             : 
      28             :    TYPE qs_force_type
      29             :       REAL(KIND=dp), DIMENSION(:, :), POINTER :: all_potential => NULL(), &
      30             :                                                  core_overlap => NULL(), &
      31             :                                                  gth_ppl => NULL(), &
      32             :                                                  gth_nlcc => NULL(), &
      33             :                                                  gth_ppnl => NULL(), &
      34             :                                                  kinetic => NULL(), &
      35             :                                                  overlap => NULL(), &
      36             :                                                  overlap_admm => NULL(), &
      37             :                                                  rho_core => NULL(), &
      38             :                                                  rho_elec => NULL(), &
      39             :                                                  rho_lri_elec => NULL(), &
      40             :                                                  vhxc_atom => NULL(), &
      41             :                                                  g0s_Vh_elec => NULL(), &
      42             :                                                  repulsive => NULL(), &
      43             :                                                  dispersion => NULL(), &
      44             :                                                  gcp => NULL(), &
      45             :                                                  other => NULL(), &
      46             :                                                  ch_pulay => NULL(), &
      47             :                                                  fock_4c => NULL(), &
      48             :                                                  ehrenfest => NULL(), &
      49             :                                                  efield => NULL(), &
      50             :                                                  eev => NULL(), &
      51             :                                                  mp2_non_sep => NULL(), &
      52             :                                                  total => NULL()
      53             :    END TYPE qs_force_type
      54             : 
      55             :    PUBLIC :: qs_force_type
      56             : 
      57             :    PUBLIC :: allocate_qs_force, &
      58             :              add_qs_force, &
      59             :              deallocate_qs_force, &
      60             :              replicate_qs_force, &
      61             :              sum_qs_force, &
      62             :              get_qs_force, &
      63             :              put_qs_force, &
      64             :              total_qs_force, &
      65             :              zero_qs_force, &
      66             :              write_forces_debug
      67             : 
      68             : CONTAINS
      69             : 
      70             : ! **************************************************************************************************
      71             : !> \brief   Allocate a Quickstep force data structure.
      72             : !> \param qs_force ...
      73             : !> \param natom_of_kind ...
      74             : !> \date    05.06.2002
      75             : !> \author  MK
      76             : !> \version 1.0
      77             : ! **************************************************************************************************
      78        4209 :    SUBROUTINE allocate_qs_force(qs_force, natom_of_kind)
      79             : 
      80             :       TYPE(qs_force_type), DIMENSION(:), POINTER         :: qs_force
      81             :       INTEGER, DIMENSION(:), INTENT(IN)                  :: natom_of_kind
      82             : 
      83             :       INTEGER                                            :: ikind, n, nkind
      84             : 
      85        4209 :       IF (ASSOCIATED(qs_force)) CALL deallocate_qs_force(qs_force)
      86             : 
      87        4209 :       nkind = SIZE(natom_of_kind)
      88             : 
      89       20797 :       ALLOCATE (qs_force(nkind))
      90             : 
      91       12379 :       DO ikind = 1, nkind
      92        8170 :          n = natom_of_kind(ikind)
      93       24510 :          ALLOCATE (qs_force(ikind)%all_potential(3, n))
      94       16340 :          ALLOCATE (qs_force(ikind)%core_overlap(3, n))
      95       16340 :          ALLOCATE (qs_force(ikind)%gth_ppl(3, n))
      96       16340 :          ALLOCATE (qs_force(ikind)%gth_nlcc(3, n))
      97       16340 :          ALLOCATE (qs_force(ikind)%gth_ppnl(3, n))
      98       16340 :          ALLOCATE (qs_force(ikind)%kinetic(3, n))
      99       16340 :          ALLOCATE (qs_force(ikind)%overlap(3, n))
     100       16340 :          ALLOCATE (qs_force(ikind)%overlap_admm(3, n))
     101       16340 :          ALLOCATE (qs_force(ikind)%rho_core(3, n))
     102       16340 :          ALLOCATE (qs_force(ikind)%rho_elec(3, n))
     103       16340 :          ALLOCATE (qs_force(ikind)%rho_lri_elec(3, n))
     104       16340 :          ALLOCATE (qs_force(ikind)%vhxc_atom(3, n))
     105       16340 :          ALLOCATE (qs_force(ikind)%g0s_Vh_elec(3, n))
     106       16340 :          ALLOCATE (qs_force(ikind)%repulsive(3, n))
     107       16340 :          ALLOCATE (qs_force(ikind)%dispersion(3, n))
     108       16340 :          ALLOCATE (qs_force(ikind)%gcp(3, n))
     109       16340 :          ALLOCATE (qs_force(ikind)%other(3, n))
     110       16340 :          ALLOCATE (qs_force(ikind)%ch_pulay(3, n))
     111       16340 :          ALLOCATE (qs_force(ikind)%ehrenfest(3, n))
     112       16340 :          ALLOCATE (qs_force(ikind)%efield(3, n))
     113       16340 :          ALLOCATE (qs_force(ikind)%eev(3, n))
     114             :          ! Always initialize ch_pulay to zero..
     115       99270 :          qs_force(ikind)%ch_pulay = 0.0_dp
     116       16340 :          ALLOCATE (qs_force(ikind)%fock_4c(3, n))
     117       16340 :          ALLOCATE (qs_force(ikind)%mp2_non_sep(3, n))
     118       20549 :          ALLOCATE (qs_force(ikind)%total(3, n))
     119             :       END DO
     120             : 
     121        4209 :    END SUBROUTINE allocate_qs_force
     122             : 
     123             : ! **************************************************************************************************
     124             : !> \brief   Deallocate a Quickstep force data structure.
     125             : !> \param qs_force ...
     126             : !> \date    05.06.2002
     127             : !> \author  MK
     128             : !> \version 1.0
     129             : ! **************************************************************************************************
     130        4209 :    SUBROUTINE deallocate_qs_force(qs_force)
     131             : 
     132             :       TYPE(qs_force_type), DIMENSION(:), POINTER         :: qs_force
     133             : 
     134             :       INTEGER                                            :: ikind, nkind
     135             : 
     136        4209 :       CPASSERT(ASSOCIATED(qs_force))
     137             : 
     138        4209 :       nkind = SIZE(qs_force)
     139             : 
     140       12379 :       DO ikind = 1, nkind
     141             : 
     142        8170 :          IF (ASSOCIATED(qs_force(ikind)%all_potential)) THEN
     143        8170 :             DEALLOCATE (qs_force(ikind)%all_potential)
     144             :          END IF
     145             : 
     146        8170 :          IF (ASSOCIATED(qs_force(ikind)%core_overlap)) THEN
     147        8170 :             DEALLOCATE (qs_force(ikind)%core_overlap)
     148             :          END IF
     149             : 
     150        8170 :          IF (ASSOCIATED(qs_force(ikind)%gth_ppl)) THEN
     151        8170 :             DEALLOCATE (qs_force(ikind)%gth_ppl)
     152             :          END IF
     153             : 
     154        8170 :          IF (ASSOCIATED(qs_force(ikind)%gth_nlcc)) THEN
     155        8170 :             DEALLOCATE (qs_force(ikind)%gth_nlcc)
     156             :          END IF
     157             : 
     158        8170 :          IF (ASSOCIATED(qs_force(ikind)%gth_ppnl)) THEN
     159        8170 :             DEALLOCATE (qs_force(ikind)%gth_ppnl)
     160             :          END IF
     161             : 
     162        8170 :          IF (ASSOCIATED(qs_force(ikind)%kinetic)) THEN
     163        8170 :             DEALLOCATE (qs_force(ikind)%kinetic)
     164             :          END IF
     165             : 
     166        8170 :          IF (ASSOCIATED(qs_force(ikind)%overlap)) THEN
     167        8170 :             DEALLOCATE (qs_force(ikind)%overlap)
     168             :          END IF
     169             : 
     170        8170 :          IF (ASSOCIATED(qs_force(ikind)%overlap_admm)) THEN
     171        8170 :             DEALLOCATE (qs_force(ikind)%overlap_admm)
     172             :          END IF
     173             : 
     174        8170 :          IF (ASSOCIATED(qs_force(ikind)%rho_core)) THEN
     175        8170 :             DEALLOCATE (qs_force(ikind)%rho_core)
     176             :          END IF
     177             : 
     178        8170 :          IF (ASSOCIATED(qs_force(ikind)%rho_elec)) THEN
     179        8170 :             DEALLOCATE (qs_force(ikind)%rho_elec)
     180             :          END IF
     181        8170 :          IF (ASSOCIATED(qs_force(ikind)%rho_lri_elec)) THEN
     182        8170 :             DEALLOCATE (qs_force(ikind)%rho_lri_elec)
     183             :          END IF
     184             : 
     185        8170 :          IF (ASSOCIATED(qs_force(ikind)%vhxc_atom)) THEN
     186        8170 :             DEALLOCATE (qs_force(ikind)%vhxc_atom)
     187             :          END IF
     188             : 
     189        8170 :          IF (ASSOCIATED(qs_force(ikind)%g0s_Vh_elec)) THEN
     190        8170 :             DEALLOCATE (qs_force(ikind)%g0s_Vh_elec)
     191             :          END IF
     192             : 
     193        8170 :          IF (ASSOCIATED(qs_force(ikind)%repulsive)) THEN
     194        8170 :             DEALLOCATE (qs_force(ikind)%repulsive)
     195             :          END IF
     196             : 
     197        8170 :          IF (ASSOCIATED(qs_force(ikind)%dispersion)) THEN
     198        8170 :             DEALLOCATE (qs_force(ikind)%dispersion)
     199             :          END IF
     200             : 
     201        8170 :          IF (ASSOCIATED(qs_force(ikind)%gcp)) THEN
     202        8170 :             DEALLOCATE (qs_force(ikind)%gcp)
     203             :          END IF
     204             : 
     205        8170 :          IF (ASSOCIATED(qs_force(ikind)%other)) THEN
     206        8170 :             DEALLOCATE (qs_force(ikind)%other)
     207             :          END IF
     208             : 
     209        8170 :          IF (ASSOCIATED(qs_force(ikind)%total)) THEN
     210        8170 :             DEALLOCATE (qs_force(ikind)%total)
     211             :          END IF
     212             : 
     213        8170 :          IF (ASSOCIATED(qs_force(ikind)%ch_pulay)) THEN
     214        8170 :             DEALLOCATE (qs_force(ikind)%ch_pulay)
     215             :          END IF
     216             : 
     217        8170 :          IF (ASSOCIATED(qs_force(ikind)%fock_4c)) THEN
     218        8170 :             DEALLOCATE (qs_force(ikind)%fock_4c)
     219             :          END IF
     220             : 
     221        8170 :          IF (ASSOCIATED(qs_force(ikind)%mp2_non_sep)) THEN
     222        8170 :             DEALLOCATE (qs_force(ikind)%mp2_non_sep)
     223             :          END IF
     224             : 
     225        8170 :          IF (ASSOCIATED(qs_force(ikind)%ehrenfest)) THEN
     226        8170 :             DEALLOCATE (qs_force(ikind)%ehrenfest)
     227             :          END IF
     228             : 
     229        8170 :          IF (ASSOCIATED(qs_force(ikind)%efield)) THEN
     230        8170 :             DEALLOCATE (qs_force(ikind)%efield)
     231             :          END IF
     232             : 
     233       12379 :          IF (ASSOCIATED(qs_force(ikind)%eev)) THEN
     234        8170 :             DEALLOCATE (qs_force(ikind)%eev)
     235             :          END IF
     236             :       END DO
     237             : 
     238        4209 :       DEALLOCATE (qs_force)
     239             : 
     240        4209 :    END SUBROUTINE deallocate_qs_force
     241             : 
     242             : ! **************************************************************************************************
     243             : !> \brief    Initialize a Quickstep force data structure.
     244             : !> \param qs_force ...
     245             : !> \date    15.07.2002
     246             : !> \author  MK
     247             : !> \version 1.0
     248             : ! **************************************************************************************************
     249       12391 :    SUBROUTINE zero_qs_force(qs_force)
     250             : 
     251             :       TYPE(qs_force_type), DIMENSION(:), POINTER         :: qs_force
     252             : 
     253             :       INTEGER                                            :: ikind
     254             : 
     255       12391 :       CPASSERT(ASSOCIATED(qs_force))
     256             : 
     257       36367 :       DO ikind = 1, SIZE(qs_force)
     258      313332 :          qs_force(ikind)%all_potential(:, :) = 0.0_dp
     259      313332 :          qs_force(ikind)%core_overlap(:, :) = 0.0_dp
     260      313332 :          qs_force(ikind)%gth_ppl(:, :) = 0.0_dp
     261      313332 :          qs_force(ikind)%gth_nlcc(:, :) = 0.0_dp
     262      313332 :          qs_force(ikind)%gth_ppnl(:, :) = 0.0_dp
     263      313332 :          qs_force(ikind)%kinetic(:, :) = 0.0_dp
     264      313332 :          qs_force(ikind)%overlap(:, :) = 0.0_dp
     265      313332 :          qs_force(ikind)%overlap_admm(:, :) = 0.0_dp
     266      313332 :          qs_force(ikind)%rho_core(:, :) = 0.0_dp
     267      313332 :          qs_force(ikind)%rho_elec(:, :) = 0.0_dp
     268      313332 :          qs_force(ikind)%rho_lri_elec(:, :) = 0.0_dp
     269      313332 :          qs_force(ikind)%vhxc_atom(:, :) = 0.0_dp
     270      313332 :          qs_force(ikind)%g0s_Vh_elec(:, :) = 0.0_dp
     271      313332 :          qs_force(ikind)%repulsive(:, :) = 0.0_dp
     272      313332 :          qs_force(ikind)%dispersion(:, :) = 0.0_dp
     273      313332 :          qs_force(ikind)%gcp(:, :) = 0.0_dp
     274      313332 :          qs_force(ikind)%other(:, :) = 0.0_dp
     275      313332 :          qs_force(ikind)%fock_4c(:, :) = 0.0_dp
     276      313332 :          qs_force(ikind)%ehrenfest(:, :) = 0.0_dp
     277      313332 :          qs_force(ikind)%efield(:, :) = 0.0_dp
     278      313332 :          qs_force(ikind)%eev(:, :) = 0.0_dp
     279      313332 :          qs_force(ikind)%mp2_non_sep(:, :) = 0.0_dp
     280      325723 :          qs_force(ikind)%total(:, :) = 0.0_dp
     281             :       END DO
     282             : 
     283       12391 :    END SUBROUTINE zero_qs_force
     284             : 
     285             : ! **************************************************************************************************
     286             : !> \brief    Sum up two qs_force entities qs_force_out = qs_force_out + qs_force_in
     287             : !> \param qs_force_out ...
     288             : !> \param qs_force_in ...
     289             : !> \author  JGH
     290             : ! **************************************************************************************************
     291        1396 :    SUBROUTINE sum_qs_force(qs_force_out, qs_force_in)
     292             : 
     293             :       TYPE(qs_force_type), DIMENSION(:), POINTER         :: qs_force_out, qs_force_in
     294             : 
     295             :       INTEGER                                            :: ikind
     296             : 
     297        1396 :       CPASSERT(ASSOCIATED(qs_force_out))
     298        1396 :       CPASSERT(ASSOCIATED(qs_force_in))
     299             : 
     300        4240 :       DO ikind = 1, SIZE(qs_force_out)
     301             :          qs_force_out(ikind)%all_potential(:, :) = qs_force_out(ikind)%all_potential(:, :) + &
     302       42792 :                                                    qs_force_in(ikind)%all_potential(:, :)
     303             :          qs_force_out(ikind)%core_overlap(:, :) = qs_force_out(ikind)%core_overlap(:, :) + &
     304       42792 :                                                   qs_force_in(ikind)%core_overlap(:, :)
     305             :          qs_force_out(ikind)%gth_ppl(:, :) = qs_force_out(ikind)%gth_ppl(:, :) + &
     306       42792 :                                              qs_force_in(ikind)%gth_ppl(:, :)
     307             :          qs_force_out(ikind)%gth_nlcc(:, :) = qs_force_out(ikind)%gth_nlcc(:, :) + &
     308       42792 :                                               qs_force_in(ikind)%gth_nlcc(:, :)
     309             :          qs_force_out(ikind)%gth_ppnl(:, :) = qs_force_out(ikind)%gth_ppnl(:, :) + &
     310       42792 :                                               qs_force_in(ikind)%gth_ppnl(:, :)
     311             :          qs_force_out(ikind)%kinetic(:, :) = qs_force_out(ikind)%kinetic(:, :) + &
     312       42792 :                                              qs_force_in(ikind)%kinetic(:, :)
     313             :          qs_force_out(ikind)%overlap(:, :) = qs_force_out(ikind)%overlap(:, :) + &
     314       42792 :                                              qs_force_in(ikind)%overlap(:, :)
     315             :          qs_force_out(ikind)%overlap_admm(:, :) = qs_force_out(ikind)%overlap_admm(:, :) + &
     316       42792 :                                                   qs_force_in(ikind)%overlap_admm(:, :)
     317             :          qs_force_out(ikind)%rho_core(:, :) = qs_force_out(ikind)%rho_core(:, :) + &
     318       42792 :                                               qs_force_in(ikind)%rho_core(:, :)
     319             :          qs_force_out(ikind)%rho_elec(:, :) = qs_force_out(ikind)%rho_elec(:, :) + &
     320       42792 :                                               qs_force_in(ikind)%rho_elec(:, :)
     321             :          qs_force_out(ikind)%rho_lri_elec(:, :) = qs_force_out(ikind)%rho_lri_elec(:, :) + &
     322       42792 :                                                   qs_force_in(ikind)%rho_lri_elec(:, :)
     323             :          qs_force_out(ikind)%vhxc_atom(:, :) = qs_force_out(ikind)%vhxc_atom(:, :) + &
     324       42792 :                                                qs_force_in(ikind)%vhxc_atom(:, :)
     325             :          qs_force_out(ikind)%g0s_Vh_elec(:, :) = qs_force_out(ikind)%g0s_Vh_elec(:, :) + &
     326       42792 :                                                  qs_force_in(ikind)%g0s_Vh_elec(:, :)
     327             :          qs_force_out(ikind)%repulsive(:, :) = qs_force_out(ikind)%repulsive(:, :) + &
     328       42792 :                                                qs_force_in(ikind)%repulsive(:, :)
     329             :          qs_force_out(ikind)%dispersion(:, :) = qs_force_out(ikind)%dispersion(:, :) + &
     330       42792 :                                                 qs_force_in(ikind)%dispersion(:, :)
     331             :          qs_force_out(ikind)%gcp(:, :) = qs_force_out(ikind)%gcp(:, :) + &
     332       42792 :                                          qs_force_in(ikind)%gcp(:, :)
     333             :          qs_force_out(ikind)%other(:, :) = qs_force_out(ikind)%other(:, :) + &
     334       42792 :                                            qs_force_in(ikind)%other(:, :)
     335             :          qs_force_out(ikind)%fock_4c(:, :) = qs_force_out(ikind)%fock_4c(:, :) + &
     336       42792 :                                              qs_force_in(ikind)%fock_4c(:, :)
     337             :          qs_force_out(ikind)%ehrenfest(:, :) = qs_force_out(ikind)%ehrenfest(:, :) + &
     338       42792 :                                                qs_force_in(ikind)%ehrenfest(:, :)
     339             :          qs_force_out(ikind)%efield(:, :) = qs_force_out(ikind)%efield(:, :) + &
     340       42792 :                                             qs_force_in(ikind)%efield(:, :)
     341             :          qs_force_out(ikind)%eev(:, :) = qs_force_out(ikind)%eev(:, :) + &
     342       42792 :                                          qs_force_in(ikind)%eev(:, :)
     343             :          qs_force_out(ikind)%mp2_non_sep(:, :) = qs_force_out(ikind)%mp2_non_sep(:, :) + &
     344       42792 :                                                  qs_force_in(ikind)%mp2_non_sep(:, :)
     345             :          qs_force_out(ikind)%total(:, :) = qs_force_out(ikind)%total(:, :) + &
     346       44188 :                                            qs_force_in(ikind)%total(:, :)
     347             :       END DO
     348             : 
     349        1396 :    END SUBROUTINE sum_qs_force
     350             : 
     351             : ! **************************************************************************************************
     352             : !> \brief    Replicate and sum up the force
     353             : !> \param qs_force ...
     354             : !> \param para_env ...
     355             : !> \date    25.05.2016
     356             : !> \author  JHU
     357             : !> \version 1.0
     358             : ! **************************************************************************************************
     359       10311 :    SUBROUTINE replicate_qs_force(qs_force, para_env)
     360             : 
     361             :       TYPE(qs_force_type), DIMENSION(:), POINTER         :: qs_force
     362             :       TYPE(mp_para_env_type), POINTER                    :: para_env
     363             : 
     364             :       INTEGER                                            :: ikind
     365             : 
     366             :       !  *** replicate forces ***
     367       30475 :       DO ikind = 1, SIZE(qs_force)
     368      547964 :          CALL para_env%sum(qs_force(ikind)%overlap)
     369      547964 :          CALL para_env%sum(qs_force(ikind)%overlap_admm)
     370      547964 :          CALL para_env%sum(qs_force(ikind)%kinetic)
     371      547964 :          CALL para_env%sum(qs_force(ikind)%gth_ppl)
     372      547964 :          CALL para_env%sum(qs_force(ikind)%gth_nlcc)
     373      547964 :          CALL para_env%sum(qs_force(ikind)%gth_ppnl)
     374      547964 :          CALL para_env%sum(qs_force(ikind)%all_potential)
     375      547964 :          CALL para_env%sum(qs_force(ikind)%core_overlap)
     376      547964 :          CALL para_env%sum(qs_force(ikind)%rho_core)
     377      547964 :          CALL para_env%sum(qs_force(ikind)%rho_elec)
     378      547964 :          CALL para_env%sum(qs_force(ikind)%rho_lri_elec)
     379      547964 :          CALL para_env%sum(qs_force(ikind)%vhxc_atom)
     380      547964 :          CALL para_env%sum(qs_force(ikind)%g0s_Vh_elec)
     381      547964 :          CALL para_env%sum(qs_force(ikind)%fock_4c)
     382      547964 :          CALL para_env%sum(qs_force(ikind)%mp2_non_sep)
     383      547964 :          CALL para_env%sum(qs_force(ikind)%repulsive)
     384      547964 :          CALL para_env%sum(qs_force(ikind)%dispersion)
     385      547964 :          CALL para_env%sum(qs_force(ikind)%gcp)
     386      547964 :          CALL para_env%sum(qs_force(ikind)%ehrenfest)
     387             : 
     388             :          qs_force(ikind)%total(:, :) = qs_force(ikind)%total(:, :) + &
     389             :                                        qs_force(ikind)%core_overlap(:, :) + &
     390             :                                        qs_force(ikind)%gth_ppl(:, :) + &
     391             :                                        qs_force(ikind)%gth_nlcc(:, :) + &
     392             :                                        qs_force(ikind)%gth_ppnl(:, :) + &
     393             :                                        qs_force(ikind)%all_potential(:, :) + &
     394             :                                        qs_force(ikind)%kinetic(:, :) + &
     395             :                                        qs_force(ikind)%overlap(:, :) + &
     396             :                                        qs_force(ikind)%overlap_admm(:, :) + &
     397             :                                        qs_force(ikind)%rho_core(:, :) + &
     398             :                                        qs_force(ikind)%rho_elec(:, :) + &
     399             :                                        qs_force(ikind)%rho_lri_elec(:, :) + &
     400             :                                        qs_force(ikind)%vhxc_atom(:, :) + &
     401             :                                        qs_force(ikind)%g0s_Vh_elec(:, :) + &
     402             :                                        qs_force(ikind)%fock_4c(:, :) + &
     403             :                                        qs_force(ikind)%mp2_non_sep(:, :) + &
     404             :                                        qs_force(ikind)%repulsive(:, :) + &
     405             :                                        qs_force(ikind)%dispersion(:, :) + &
     406             :                                        qs_force(ikind)%gcp(:, :) + &
     407             :                                        qs_force(ikind)%ehrenfest(:, :) + &
     408             :                                        qs_force(ikind)%efield(:, :) + &
     409      294375 :                                        qs_force(ikind)%eev(:, :)
     410             :       END DO
     411             : 
     412       10311 :    END SUBROUTINE replicate_qs_force
     413             : 
     414             : ! **************************************************************************************************
     415             : !> \brief Add force to a force_type  variable.
     416             : !> \param force Input force, dimension (3,natom)
     417             : !> \param qs_force The force type variable to be used
     418             : !> \param forcetype ...
     419             : !> \param atomic_kind_set ...
     420             : !> \par History
     421             : !>      07.2014 JGH
     422             : !> \author JGH
     423             : ! **************************************************************************************************
     424        1098 :    SUBROUTINE add_qs_force(force, qs_force, forcetype, atomic_kind_set)
     425             : 
     426             :       REAL(KIND=dp), DIMENSION(:, :), INTENT(IN)         :: force
     427             :       TYPE(qs_force_type), DIMENSION(:), POINTER         :: qs_force
     428             :       CHARACTER(LEN=*), INTENT(IN)                       :: forcetype
     429             :       TYPE(atomic_kind_type), DIMENSION(:), POINTER      :: atomic_kind_set
     430             : 
     431             :       INTEGER                                            :: ia, iatom, ikind, natom_kind
     432             :       TYPE(atomic_kind_type), POINTER                    :: atomic_kind
     433             : 
     434             : !   ------------------------------------------------------------------------
     435             : 
     436        1098 :       CPASSERT(ASSOCIATED(qs_force))
     437             : 
     438        1098 :       SELECT CASE (forcetype)
     439             :       CASE ("overlap_admm")
     440        3070 :          DO ikind = 1, SIZE(atomic_kind_set, 1)
     441        1972 :             atomic_kind => atomic_kind_set(ikind)
     442        1972 :             CALL get_atomic_kind(atomic_kind=atomic_kind, natom=natom_kind)
     443        6218 :             DO ia = 1, natom_kind
     444        3148 :                iatom = atomic_kind%atom_list(ia)
     445       14564 :                qs_force(ikind)%overlap_admm(:, ia) = qs_force(ikind)%overlap_admm(:, ia) + force(:, iatom)
     446             :             END DO
     447             :          END DO
     448             :       CASE DEFAULT
     449        1098 :          CPABORT("")
     450             :       END SELECT
     451             : 
     452        1098 :    END SUBROUTINE add_qs_force
     453             : 
     454             : ! **************************************************************************************************
     455             : !> \brief Put force to a force_type  variable.
     456             : !> \param force Input force, dimension (3,natom)
     457             : !> \param qs_force The force type variable to be used
     458             : !> \param forcetype ...
     459             : !> \param atomic_kind_set ...
     460             : !> \par History
     461             : !>      09.2019 JGH
     462             : !> \author JGH
     463             : ! **************************************************************************************************
     464           0 :    SUBROUTINE put_qs_force(force, qs_force, forcetype, atomic_kind_set)
     465             : 
     466             :       REAL(KIND=dp), DIMENSION(:, :), INTENT(IN)         :: force
     467             :       TYPE(qs_force_type), DIMENSION(:), POINTER         :: qs_force
     468             :       CHARACTER(LEN=*), INTENT(IN)                       :: forcetype
     469             :       TYPE(atomic_kind_type), DIMENSION(:), POINTER      :: atomic_kind_set
     470             : 
     471             :       INTEGER                                            :: ia, iatom, ikind, natom_kind
     472             :       TYPE(atomic_kind_type), POINTER                    :: atomic_kind
     473             : 
     474             : !   ------------------------------------------------------------------------
     475             : 
     476           0 :       SELECT CASE (forcetype)
     477             :       CASE ("dispersion")
     478           0 :          DO ikind = 1, SIZE(atomic_kind_set, 1)
     479           0 :             atomic_kind => atomic_kind_set(ikind)
     480           0 :             CALL get_atomic_kind(atomic_kind=atomic_kind, natom=natom_kind)
     481           0 :             DO ia = 1, natom_kind
     482           0 :                iatom = atomic_kind%atom_list(ia)
     483           0 :                qs_force(ikind)%dispersion(:, ia) = force(:, iatom)
     484             :             END DO
     485             :          END DO
     486             :       CASE DEFAULT
     487           0 :          CPABORT("")
     488             :       END SELECT
     489             : 
     490           0 :    END SUBROUTINE put_qs_force
     491             : 
     492             : ! **************************************************************************************************
     493             : !> \brief Get force from a force_type  variable.
     494             : !> \param force Input force, dimension (3,natom)
     495             : !> \param qs_force The force type variable to be used
     496             : !> \param forcetype ...
     497             : !> \param atomic_kind_set ...
     498             : !> \par History
     499             : !>      09.2019 JGH
     500             : !> \author JGH
     501             : ! **************************************************************************************************
     502           0 :    SUBROUTINE get_qs_force(force, qs_force, forcetype, atomic_kind_set)
     503             : 
     504             :       REAL(KIND=dp), DIMENSION(:, :), INTENT(INOUT)      :: force
     505             :       TYPE(qs_force_type), DIMENSION(:), POINTER         :: qs_force
     506             :       CHARACTER(LEN=*), INTENT(IN)                       :: forcetype
     507             :       TYPE(atomic_kind_type), DIMENSION(:), POINTER      :: atomic_kind_set
     508             : 
     509             :       INTEGER                                            :: ia, iatom, ikind, natom_kind
     510             :       TYPE(atomic_kind_type), POINTER                    :: atomic_kind
     511             : 
     512             : !   ------------------------------------------------------------------------
     513             : 
     514           0 :       SELECT CASE (forcetype)
     515             :       CASE ("dispersion")
     516           0 :          DO ikind = 1, SIZE(atomic_kind_set, 1)
     517           0 :             atomic_kind => atomic_kind_set(ikind)
     518           0 :             CALL get_atomic_kind(atomic_kind=atomic_kind, natom=natom_kind)
     519           0 :             DO ia = 1, natom_kind
     520           0 :                iatom = atomic_kind%atom_list(ia)
     521           0 :                force(:, iatom) = qs_force(ikind)%dispersion(:, ia)
     522             :             END DO
     523             :          END DO
     524             :       CASE DEFAULT
     525           0 :          CPABORT("")
     526             :       END SELECT
     527             : 
     528           0 :    END SUBROUTINE get_qs_force
     529             : 
     530             : ! **************************************************************************************************
     531             : !> \brief Get current total force
     532             : !> \param force Input force, dimension (3,natom)
     533             : !> \param qs_force The force type variable to be used
     534             : !> \param atomic_kind_set ...
     535             : !> \par History
     536             : !>      09.2019 JGH
     537             : !> \author JGH
     538             : ! **************************************************************************************************
     539         368 :    SUBROUTINE total_qs_force(force, qs_force, atomic_kind_set)
     540             : 
     541             :       REAL(KIND=dp), DIMENSION(:, :), INTENT(INOUT)      :: force
     542             :       TYPE(qs_force_type), DIMENSION(:), POINTER         :: qs_force
     543             :       TYPE(atomic_kind_type), DIMENSION(:), POINTER      :: atomic_kind_set
     544             : 
     545             :       INTEGER                                            :: ia, iatom, ikind, natom_kind
     546             :       TYPE(atomic_kind_type), POINTER                    :: atomic_kind
     547             : 
     548             : !   ------------------------------------------------------------------------
     549             : 
     550        5232 :       force(:, :) = 0.0_dp
     551        1216 :       DO ikind = 1, SIZE(atomic_kind_set, 1)
     552         848 :          atomic_kind => atomic_kind_set(ikind)
     553         848 :          CALL get_atomic_kind(atomic_kind=atomic_kind, natom=natom_kind)
     554        2432 :          DO ia = 1, natom_kind
     555        1216 :             iatom = atomic_kind%atom_list(ia)
     556             :             force(:, iatom) = qs_force(ikind)%core_overlap(:, ia) + &
     557             :                               qs_force(ikind)%gth_ppl(:, ia) + &
     558             :                               qs_force(ikind)%gth_nlcc(:, ia) + &
     559             :                               qs_force(ikind)%gth_ppnl(:, ia) + &
     560             :                               qs_force(ikind)%all_potential(:, ia) + &
     561             :                               qs_force(ikind)%kinetic(:, ia) + &
     562             :                               qs_force(ikind)%overlap(:, ia) + &
     563             :                               qs_force(ikind)%overlap_admm(:, ia) + &
     564             :                               qs_force(ikind)%rho_core(:, ia) + &
     565             :                               qs_force(ikind)%rho_elec(:, ia) + &
     566             :                               qs_force(ikind)%rho_lri_elec(:, ia) + &
     567             :                               qs_force(ikind)%vhxc_atom(:, ia) + &
     568             :                               qs_force(ikind)%g0s_Vh_elec(:, ia) + &
     569             :                               qs_force(ikind)%fock_4c(:, ia) + &
     570             :                               qs_force(ikind)%mp2_non_sep(:, ia) + &
     571             :                               qs_force(ikind)%repulsive(:, ia) + &
     572             :                               qs_force(ikind)%dispersion(:, ia) + &
     573             :                               qs_force(ikind)%gcp(:, ia) + &
     574             :                               qs_force(ikind)%ehrenfest(:, ia) + &
     575             :                               qs_force(ikind)%efield(:, ia) + &
     576        5712 :                               qs_force(ikind)%eev(:, ia)
     577             :          END DO
     578             :       END DO
     579             : 
     580         368 :    END SUBROUTINE total_qs_force
     581             : 
     582             : ! **************************************************************************************************
     583             : !> \brief Write a Quickstep force data for 1 atom
     584             : !> \param qs_force ...
     585             : !> \param ikind ...
     586             : !> \param iatom ...
     587             : !> \param iunit ...
     588             : !> \date    05.06.2002
     589             : !> \author  MK/JGH
     590             : !> \version 1.0
     591             : ! **************************************************************************************************
     592           0 :    SUBROUTINE write_forces_debug(qs_force, ikind, iatom, iunit)
     593             : 
     594             :       TYPE(qs_force_type), DIMENSION(:), POINTER         :: qs_force
     595             :       INTEGER, INTENT(IN), OPTIONAL                      :: ikind, iatom, iunit
     596             : 
     597             :       CHARACTER(LEN=35)                                  :: fmtstr2
     598             :       CHARACTER(LEN=48)                                  :: fmtstr1
     599             :       INTEGER                                            :: iounit, jatom, jkind
     600             :       REAL(KIND=dp), DIMENSION(3)                        :: total
     601             :       TYPE(cp_logger_type), POINTER                      :: logger
     602             : 
     603           0 :       IF (PRESENT(iunit)) THEN
     604           0 :          iounit = iunit
     605             :       ELSE
     606           0 :          NULLIFY (logger)
     607           0 :          logger => cp_get_default_logger()
     608           0 :          iounit = cp_logger_get_default_io_unit(logger)
     609             :       END IF
     610           0 :       IF (PRESENT(ikind)) THEN
     611           0 :          jkind = ikind
     612             :       ELSE
     613           0 :          jkind = 1
     614             :       END IF
     615           0 :       IF (PRESENT(iatom)) THEN
     616           0 :          jatom = iatom
     617             :       ELSE
     618           0 :          jatom = 1
     619             :       END IF
     620             : 
     621           0 :       IF (iounit > 0) THEN
     622             : 
     623           0 :          fmtstr1 = "(/,T2,A,/,T3,A,T11,A,T23,A,T40,A1,2(17X,A1))"
     624           0 :          fmtstr2 = "((T2,I5,4X,I4,T18,A,T34,3F18.12))"
     625             : 
     626             :          WRITE (UNIT=iounit, FMT=fmtstr1) &
     627           0 :             "FORCES [a.u.]", "Atom", "Kind", "Component", "X", "Y", "Z"
     628             : 
     629             :          total(1:3) = qs_force(jkind)%overlap(1:3, jatom) &
     630             :                       + qs_force(jkind)%overlap_admm(1:3, jatom) &
     631             :                       + qs_force(jkind)%kinetic(1:3, jatom) &
     632             :                       + qs_force(jkind)%gth_ppl(1:3, jatom) &
     633             :                       + qs_force(jkind)%gth_ppnl(1:3, jatom) &
     634             :                       + qs_force(jkind)%core_overlap(1:3, jatom) &
     635             :                       + qs_force(jkind)%rho_core(1:3, jatom) &
     636             :                       + qs_force(jkind)%rho_elec(1:3, jatom) &
     637             :                       + qs_force(jkind)%dispersion(1:3, jatom) &
     638             :                       + qs_force(jkind)%fock_4c(1:3, jatom) &
     639           0 :                       + qs_force(jkind)%mp2_non_sep(1:3, jatom)
     640             : 
     641             :          WRITE (UNIT=iounit, FMT=fmtstr2) &
     642           0 :             jatom, jkind, "       overlap", qs_force(jkind)%overlap(1:3, jatom), &
     643           0 :             jatom, jkind, "  overlap_admm", qs_force(jkind)%overlap_admm(1:3, jatom), &
     644           0 :             jatom, jkind, "       kinetic", qs_force(jkind)%kinetic(1:3, jatom), &
     645           0 :             jatom, jkind, "       gth_ppl", qs_force(jkind)%gth_ppl(1:3, jatom), &
     646           0 :             jatom, jkind, "      gth_ppnl", qs_force(jkind)%gth_ppnl(1:3, jatom), &
     647           0 :             jatom, jkind, "  core_overlap", qs_force(jkind)%core_overlap(1:3, jatom), &
     648           0 :             jatom, jkind, "      rho_core", qs_force(jkind)%rho_core(1:3, jatom), &
     649           0 :             jatom, jkind, "      rho_elec", qs_force(jkind)%rho_elec(1:3, jatom), &
     650           0 :             jatom, jkind, "    dispersion", qs_force(jkind)%dispersion(1:3, jatom), &
     651           0 :             jatom, jkind, "       fock_4c", qs_force(jkind)%fock_4c(1:3, jatom), &
     652           0 :             jatom, jkind, "   mp2_non_sep", qs_force(jkind)%mp2_non_sep(1:3, jatom), &
     653           0 :             jatom, jkind, "         total", total(1:3)
     654             : 
     655             :       END IF
     656             : 
     657           0 :    END SUBROUTINE write_forces_debug
     658             : 
     659           0 : END MODULE qs_force_types

Generated by: LCOV version 1.15