LCOV - code coverage report
Current view: top level - src - exstates_types.F (source / functions) Coverage Total Hit
Test: CP2K Regtests (git:936074a) Lines: 92.5 % 80 74
Test Date: 2025-12-04 06:27:48 Functions: 57.1 % 7 4

            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              : !> \brief Types for excited states potential energies
      10              : !> \par History
      11              : !>       2020.01 created
      12              : !> \author JGH
      13              : ! **************************************************************************************************
      14              : MODULE exstates_types
      15              :    USE cp_dbcsr_api,                    ONLY: dbcsr_p_type
      16              :    USE cp_dbcsr_operations,             ONLY: dbcsr_deallocate_matrix_set
      17              :    USE cp_fm_types,                     ONLY: cp_fm_release,&
      18              :                                               cp_fm_type
      19              :    USE input_constants,                 ONLY: xc_kernel_method_best
      20              :    USE input_section_types,             ONLY: section_vals_type,&
      21              :                                               section_vals_val_get
      22              :    USE kinds,                           ONLY: dp
      23              :    USE pw_types,                        ONLY: pw_r3d_rs_type
      24              :    USE qs_local_rho_types,              ONLY: local_rho_set_release,&
      25              :                                               local_rho_type
      26              : #include "./base/base_uses.f90"
      27              : 
      28              :    IMPLICIT NONE
      29              : 
      30              :    PRIVATE
      31              : 
      32              :    CHARACTER(len=*), PARAMETER, PRIVATE :: moduleN = 'exstates_types'
      33              : 
      34              :    PUBLIC :: excited_energy_type, exstate_release, exstate_create
      35              :    PUBLIC :: exstate_matrix_release, exstate_potential_release
      36              :    PUBLIC :: wfn_history_type
      37              : 
      38              : ! *****************************************************************************
      39              : 
      40              :    TYPE wfn_history_type
      41              :       INTEGER                                            :: state = -1
      42              :       REAL(KIND=dp)                                      :: evalue = 0.0_dp
      43              :       TYPE(cp_fm_type), POINTER, DIMENSION(:)            :: evect => NULL()
      44              :       TYPE(cp_fm_type), POINTER, DIMENSION(:)            :: cpmos => NULL()
      45              :       REAL(KIND=dp)                                      :: xsval = 0.0_dp, gsval = 0.0_dp, gsmin = 0.0_dp
      46              :    END TYPE wfn_history_type
      47              : 
      48              : ! *****************************************************************************
      49              : !> \brief Contains information on the excited states energy
      50              : !> \par History
      51              : !>       01.2020 created
      52              : !> \author JGH
      53              : ! *****************************************************************************
      54              :    TYPE excited_energy_type
      55              :       INTEGER                                            :: state = -1
      56              :       REAL(KIND=dp)                                      :: evalue = 0.0_dp
      57              :       INTEGER                                            :: xc_kernel_method = -1
      58              :       REAL(KIND=dp)                                      :: eps_delta_rho = 1.E-02_dp
      59              :       INTEGER                                            :: diff_order = -1
      60              :       LOGICAL                                            :: debug_forces = .FALSE.
      61              :       TYPE(cp_fm_type), POINTER, DIMENSION(:)            :: evect => NULL()
      62              :       TYPE(cp_fm_type), POINTER, DIMENSION(:)            :: cpmos => NULL()
      63              :       TYPE(dbcsr_p_type), DIMENSION(:), POINTER          :: matrix_pe => NULL()
      64              :       TYPE(dbcsr_p_type), DIMENSION(:), POINTER          :: matrix_hz => NULL()
      65              :       TYPE(dbcsr_p_type), DIMENSION(:), POINTER          :: matrix_pe_admm => NULL()
      66              :       TYPE(dbcsr_p_type), DIMENSION(:), POINTER          :: matrix_px1 => NULL()
      67              :       TYPE(dbcsr_p_type), DIMENSION(:), POINTER          :: matrix_px1_admm => NULL()
      68              :       TYPE(dbcsr_p_type), DIMENSION(:), POINTER          :: matrix_px1_asymm => NULL()
      69              :       TYPE(dbcsr_p_type), DIMENSION(:), POINTER          :: matrix_px1_admm_asymm => NULL()
      70              :       TYPE(dbcsr_p_type), DIMENSION(:), POINTER          :: matrix_wx1 => NULL()
      71              :       TYPE(pw_r3d_rs_type)                               :: vh_rspace = pw_r3d_rs_type()
      72              :       TYPE(pw_r3d_rs_type), DIMENSION(:), POINTER        :: vxc_rspace => NULL()
      73              :       TYPE(pw_r3d_rs_type), DIMENSION(:), POINTER        :: vtau_rspace => NULL()
      74              :       TYPE(pw_r3d_rs_type), DIMENSION(:), POINTER        :: vadmm_rspace => NULL()
      75              :       TYPE(local_rho_type), POINTER                      :: local_rho_set => NULL()
      76              :       TYPE(local_rho_type), POINTER                      :: local_rho_set_admm => NULL()
      77              :       TYPE(wfn_history_type)                             :: wfn_history = wfn_history_type()
      78              :       TYPE(cp_fm_type), POINTER, DIMENSION(:, :)         :: bse_w_matrix_MO => NULL()
      79              :       REAL(kind=dp), ALLOCATABLE, DIMENSION(:)           :: gw_eigen
      80              :       TYPE(dbcsr_p_type), DIMENSION(:), POINTER          :: matrix_ks => NULL()
      81              :    END TYPE excited_energy_type
      82              : 
      83              : CONTAINS
      84              : 
      85              : ! **************************************************************************************************
      86              : !> \brief ...
      87              : !> \param ex_env ...
      88              : ! **************************************************************************************************
      89         7444 :    SUBROUTINE exstate_release(ex_env)
      90              :       TYPE(excited_energy_type), POINTER                 :: ex_env
      91              : 
      92         7444 :       IF (ASSOCIATED(ex_env)) THEN
      93              : 
      94         7444 :          CALL cp_fm_release(ex_env%evect)
      95         7444 :          CALL cp_fm_release(ex_env%cpmos)
      96              :          !
      97         7444 :          CALL cp_fm_release(ex_env%bse_w_matrix_MO)
      98              :          !
      99         7444 :          CALL exstate_matrix_release(ex_env)
     100              :          !
     101         7444 :          CALL exstate_potential_release(ex_env)
     102              :          !
     103         7444 :          CALL cp_fm_release(ex_env%wfn_history%evect)
     104         7444 :          CALL cp_fm_release(ex_env%wfn_history%cpmos)
     105              : 
     106         7444 :          IF (ALLOCATED(ex_env%gw_eigen)) &
     107            0 :             DEALLOCATE (ex_env%gw_eigen)
     108              : 
     109         7444 :          DEALLOCATE (ex_env)
     110              : 
     111              :       END IF
     112              : 
     113         7444 :    END SUBROUTINE exstate_release
     114              : 
     115              : ! **************************************************************************************************
     116              : !> \brief ...
     117              : !> \param ex_env ...
     118              : ! **************************************************************************************************
     119         7444 :    SUBROUTINE exstate_matrix_release(ex_env)
     120              :       TYPE(excited_energy_type), POINTER                 :: ex_env
     121              : 
     122         7444 :       IF (ASSOCIATED(ex_env)) THEN
     123         7444 :          IF (ASSOCIATED(ex_env%matrix_ks)) CALL dbcsr_deallocate_matrix_set(ex_env%matrix_ks)
     124         7444 :          NULLIFY (ex_env%matrix_ks)
     125         7444 :          IF (ASSOCIATED(ex_env%matrix_pe)) CALL dbcsr_deallocate_matrix_set(ex_env%matrix_pe)
     126         7444 :          NULLIFY (ex_env%matrix_pe)
     127         7444 :          IF (ASSOCIATED(ex_env%matrix_hz)) CALL dbcsr_deallocate_matrix_set(ex_env%matrix_hz)
     128         7444 :          NULLIFY (ex_env%matrix_hz)
     129         7444 :          IF (ASSOCIATED(ex_env%matrix_pe_admm)) CALL dbcsr_deallocate_matrix_set(ex_env%matrix_pe_admm)
     130         7444 :          NULLIFY (ex_env%matrix_pe_admm)
     131         7444 :          IF (ASSOCIATED(ex_env%matrix_px1)) CALL dbcsr_deallocate_matrix_set(ex_env%matrix_px1)
     132         7444 :          NULLIFY (ex_env%matrix_px1)
     133         7444 :          IF (ASSOCIATED(ex_env%matrix_px1_admm)) CALL dbcsr_deallocate_matrix_set(ex_env%matrix_px1_admm)
     134         7444 :          NULLIFY (ex_env%matrix_px1_admm)
     135         7444 :          IF (ASSOCIATED(ex_env%matrix_px1_asymm)) CALL dbcsr_deallocate_matrix_set(ex_env%matrix_px1_asymm)
     136         7444 :          NULLIFY (ex_env%matrix_px1_asymm)
     137         7444 :          IF (ASSOCIATED(ex_env%matrix_px1_admm_asymm)) CALL dbcsr_deallocate_matrix_set(ex_env%matrix_px1_admm_asymm)
     138         7444 :          NULLIFY (ex_env%matrix_px1_admm_asymm)
     139         7444 :          IF (ASSOCIATED(ex_env%matrix_wx1)) CALL dbcsr_deallocate_matrix_set(ex_env%matrix_wx1)
     140         7444 :          NULLIFY (ex_env%matrix_wx1)
     141              :       END IF
     142              : 
     143         7444 :    END SUBROUTINE exstate_matrix_release
     144              : 
     145              : ! **************************************************************************************************
     146              : !> \brief ...
     147              : !> \param ex_env ...
     148              : ! **************************************************************************************************
     149         8008 :    SUBROUTINE exstate_potential_release(ex_env)
     150              :       TYPE(excited_energy_type), POINTER                 :: ex_env
     151              : 
     152              :       INTEGER                                            :: iab
     153              : 
     154         8008 :       IF (ASSOCIATED(ex_env)) THEN
     155         8008 :          IF (ASSOCIATED(ex_env%vh_rspace%pw_grid)) THEN
     156          564 :             CALL ex_env%vh_rspace%release()
     157              :          END IF
     158         8008 :          IF (ASSOCIATED(ex_env%vxc_rspace)) THEN
     159         1236 :             DO iab = 1, SIZE(ex_env%vxc_rspace)
     160         1236 :                CALL ex_env%vxc_rspace(iab)%release()
     161              :             END DO
     162          564 :             DEALLOCATE (ex_env%vxc_rspace)
     163          564 :             NULLIFY (ex_env%vxc_rspace)
     164              :          END IF
     165         8008 :          IF (ASSOCIATED(ex_env%vtau_rspace)) THEN
     166            0 :             DO iab = 1, SIZE(ex_env%vtau_rspace)
     167            0 :                CALL ex_env%vtau_rspace(iab)%release()
     168              :             END DO
     169            0 :             DEALLOCATE (ex_env%vtau_rspace)
     170            0 :             NULLIFY (ex_env%vtau_rspace)
     171              :          END IF
     172         8008 :          IF (ASSOCIATED(ex_env%vadmm_rspace)) THEN
     173          164 :             DO iab = 1, SIZE(ex_env%vadmm_rspace)
     174          164 :                CALL ex_env%vadmm_rspace(iab)%release()
     175              :             END DO
     176           78 :             DEALLOCATE (ex_env%vadmm_rspace)
     177           78 :             NULLIFY (ex_env%vadmm_rspace)
     178              :          END IF
     179         8008 :          IF (ASSOCIATED(ex_env%local_rho_set)) THEN
     180           78 :             CALL local_rho_set_release(ex_env%local_rho_set)
     181           78 :             NULLIFY (ex_env%local_rho_set)
     182              :          END IF
     183         8008 :          IF (ASSOCIATED(ex_env%local_rho_set_admm)) THEN
     184           10 :             CALL local_rho_set_release(ex_env%local_rho_set_admm)
     185           10 :             NULLIFY (ex_env%local_rho_set_admm)
     186              :          END IF
     187              :       END IF
     188              : 
     189         8008 :    END SUBROUTINE exstate_potential_release
     190              : 
     191              : ! **************************************************************************************************
     192              : !> \brief Allocates and intitializes exstate_env
     193              : !> \param ex_env the object to create
     194              : !> \param excited_state ...
     195              : !> \param dft_section ...
     196              : !> \par History
     197              : !>       2020.01 created
     198              : !> \author JGH
     199              : ! **************************************************************************************************
     200         7444 :    SUBROUTINE exstate_create(ex_env, excited_state, dft_section)
     201              :       TYPE(excited_energy_type), POINTER                 :: ex_env
     202              :       LOGICAL, INTENT(IN)                                :: excited_state
     203              :       TYPE(section_vals_type), POINTER                   :: dft_section
     204              : 
     205         7444 :       CPASSERT(.NOT. ASSOCIATED(ex_env))
     206         7444 :       ALLOCATE (ex_env)
     207              :       ex_env%evalue = 0.0_dp
     208              :       NULLIFY (ex_env%evect)
     209              :       NULLIFY (ex_env%cpmos)
     210              :       NULLIFY (ex_env%bse_w_matrix_MO)
     211         7444 :       IF (excited_state) THEN
     212          352 :          CALL section_vals_val_get(dft_section, "EXCITED_STATES%STATE", i_val=ex_env%state)
     213              :          CALL section_vals_val_get(dft_section, "EXCITED_STATES%XC_KERNEL_METHOD", &
     214          352 :                                    i_val=ex_env%xc_kernel_method)
     215              :          CALL section_vals_val_get(dft_section, "EXCITED_STATES%DEBUG_FORCES", &
     216          352 :                                    l_val=ex_env%debug_forces)
     217              :          CALL section_vals_val_get(dft_section, "EXCITED_STATES%EPS_DELTA_RHO", &
     218          352 :                                    r_val=ex_env%eps_delta_rho)
     219              :          CALL section_vals_val_get(dft_section, "EXCITED_STATES%DIFF_ORDER", &
     220          352 :                                    i_val=ex_env%diff_order)
     221              :       ELSE
     222         7092 :          ex_env%state = 0
     223         7092 :          ex_env%xc_kernel_method = xc_kernel_method_best
     224              :       END IF
     225         7444 :       ex_env%wfn_history%evalue = 0.0_dp
     226         7444 :       ex_env%wfn_history%state = ex_env%state
     227         7444 :       ex_env%wfn_history%xsval = 1.0_dp
     228         7444 :       ex_env%wfn_history%gsval = 1.0_dp
     229         7444 :       ex_env%wfn_history%gsmin = 1.0_dp
     230         7444 :       NULLIFY (ex_env%wfn_history%cpmos)
     231         7444 :       NULLIFY (ex_env%wfn_history%evect)
     232              : 
     233         7444 :    END SUBROUTINE exstate_create
     234              : 
     235            0 : END MODULE exstates_types
        

Generated by: LCOV version 2.0-1