LCOV - code coverage report
Current view: top level - src - pao_param.F (source / functions) Hit Total Coverage
Test: CP2K Regtests (git:2fce0f8) Lines: 58 58 100.0 %
Date: 2024-12-21 06:28:57 Functions: 5 5 100.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 Front-End for any PAO parametrization
      10             : !> \author Ole Schuett
      11             : ! **************************************************************************************************
      12             : MODULE pao_param
      13             :    USE cp_dbcsr_api,                    ONLY: dbcsr_copy,&
      14             :                                               dbcsr_frobenius_norm,&
      15             :                                               dbcsr_multiply,&
      16             :                                               dbcsr_release,&
      17             :                                               dbcsr_type
      18             :    USE dm_ls_scf_types,                 ONLY: ls_scf_env_type
      19             :    USE kinds,                           ONLY: dp
      20             :    USE pao_input,                       ONLY: pao_equi_param,&
      21             :                                               pao_exp_param,&
      22             :                                               pao_fock_param,&
      23             :                                               pao_gth_param,&
      24             :                                               pao_rotinv_param
      25             :    USE pao_param_equi,                  ONLY: pao_calc_AB_equi,&
      26             :                                               pao_param_count_equi,&
      27             :                                               pao_param_finalize_equi,&
      28             :                                               pao_param_init_equi,&
      29             :                                               pao_param_initguess_equi
      30             :    USE pao_param_exp,                   ONLY: pao_calc_AB_exp,&
      31             :                                               pao_param_count_exp,&
      32             :                                               pao_param_finalize_exp,&
      33             :                                               pao_param_init_exp,&
      34             :                                               pao_param_initguess_exp
      35             :    USE pao_param_gth,                   ONLY: pao_calc_AB_gth,&
      36             :                                               pao_param_count_gth,&
      37             :                                               pao_param_finalize_gth,&
      38             :                                               pao_param_init_gth,&
      39             :                                               pao_param_initguess_gth
      40             :    USE pao_param_linpot,                ONLY: pao_calc_AB_linpot,&
      41             :                                               pao_param_count_linpot,&
      42             :                                               pao_param_finalize_linpot,&
      43             :                                               pao_param_init_linpot,&
      44             :                                               pao_param_initguess_linpot
      45             :    USE pao_types,                       ONLY: pao_env_type
      46             :    USE qs_environment_types,            ONLY: qs_environment_type
      47             : #include "./base/base_uses.f90"
      48             : 
      49             :    IMPLICIT NONE
      50             : 
      51             :    PRIVATE
      52             : 
      53             :    CHARACTER(len=*), PARAMETER, PRIVATE :: moduleN = 'pao_param'
      54             : 
      55             :    PUBLIC :: pao_calc_AB, pao_param_count, pao_param_initial_guess
      56             :    PUBLIC :: pao_param_init, pao_param_finalize
      57             : 
      58             : CONTAINS
      59             : 
      60             : ! **************************************************************************************************
      61             : !> \brief Takes current matrix_X and calculates the matrices A and B.
      62             : !> \param pao ...
      63             : !> \param qs_env ...
      64             : !> \param ls_scf_env ...
      65             : !> \param gradient ...
      66             : !> \param penalty ...
      67             : !> \param forces ...
      68             : ! **************************************************************************************************
      69       14760 :    SUBROUTINE pao_calc_AB(pao, qs_env, ls_scf_env, gradient, penalty, forces)
      70             :       TYPE(pao_env_type), POINTER                        :: pao
      71             :       TYPE(qs_environment_type), POINTER                 :: qs_env
      72             :       TYPE(ls_scf_env_type), TARGET                      :: ls_scf_env
      73             :       LOGICAL, INTENT(IN)                                :: gradient
      74             :       REAL(dp), INTENT(OUT), OPTIONAL                    :: penalty
      75             :       REAL(dp), DIMENSION(:, :), INTENT(OUT), OPTIONAL   :: forces
      76             : 
      77             :       CHARACTER(len=*), PARAMETER                        :: routineN = 'pao_calc_AB'
      78             : 
      79             :       INTEGER                                            :: handle
      80             : 
      81       14760 :       CALL timeset(routineN, handle)
      82             : 
      83       14760 :       IF (PRESENT(penalty)) penalty = 0.0_dp
      84       15210 :       IF (PRESENT(forces)) forces(:, :) = 0.0_dp
      85             : 
      86             :       !calculate matrix_A/B = Function of matrix_X
      87       17470 :       SELECT CASE (pao%parameterization)
      88             :       CASE (pao_exp_param)
      89        2710 :          CALL pao_calc_AB_exp(pao, qs_env, ls_scf_env, gradient)
      90             :       CASE (pao_fock_param, pao_rotinv_param)
      91       16382 :          CALL pao_calc_AB_linpot(pao, qs_env, ls_scf_env, gradient, penalty, forces)
      92             :       CASE (pao_gth_param)
      93        2152 :          CALL pao_calc_AB_gth(pao, qs_env, ls_scf_env, gradient, penalty)
      94             :       CASE (pao_equi_param)
      95        1690 :          CALL pao_calc_AB_equi(pao, qs_env, ls_scf_env, gradient, penalty)
      96             :       CASE DEFAULT
      97       14760 :          CPABORT("PAO: unkown parametrization")
      98             :       END SELECT
      99             : 
     100       14760 :       CALL timestop(handle)
     101       14760 :    END SUBROUTINE pao_calc_AB
     102             : 
     103             : ! **************************************************************************************************
     104             : !> \brief Initialize PAO parametrization
     105             : !> \param pao ...
     106             : !> \param qs_env ...
     107             : ! **************************************************************************************************
     108         280 :    SUBROUTINE pao_param_init(pao, qs_env)
     109             :       TYPE(pao_env_type), POINTER                        :: pao
     110             :       TYPE(qs_environment_type), POINTER                 :: qs_env
     111             : 
     112             :       CHARACTER(len=*), PARAMETER                        :: routineN = 'pao_param_init'
     113             : 
     114             :       INTEGER                                            :: handle
     115             : 
     116         280 :       CALL timeset(routineN, handle)
     117             : 
     118         304 :       SELECT CASE (pao%parameterization)
     119             :       CASE (pao_exp_param)
     120          24 :          CALL pao_param_init_exp(pao, qs_env)
     121             :       CASE (pao_fock_param, pao_rotinv_param)
     122         234 :          CALL pao_param_init_linpot(pao, qs_env)
     123             :       CASE (pao_gth_param)
     124          10 :          CALL pao_param_init_gth(pao, qs_env)
     125             :       CASE (pao_equi_param)
     126          12 :          CALL pao_param_init_equi(pao)
     127             :       CASE DEFAULT
     128         280 :          CPABORT("PAO: unknown parametrization")
     129             :       END SELECT
     130             : 
     131         280 :       CALL timestop(handle)
     132             : 
     133         280 :    END SUBROUTINE pao_param_init
     134             : 
     135             : ! **************************************************************************************************
     136             : !> \brief Finalize PAO parametrization
     137             : !> \param pao ...
     138             : ! **************************************************************************************************
     139         280 :    SUBROUTINE pao_param_finalize(pao)
     140             :       TYPE(pao_env_type), POINTER                        :: pao
     141             : 
     142             :       CHARACTER(len=*), PARAMETER :: routineN = 'pao_param_finalize'
     143             : 
     144             :       INTEGER                                            :: handle
     145             : 
     146         280 :       CALL timeset(routineN, handle)
     147             : 
     148         304 :       SELECT CASE (pao%parameterization)
     149             :       CASE (pao_exp_param)
     150          24 :          CALL pao_param_finalize_exp(pao)
     151             :       CASE (pao_fock_param, pao_rotinv_param)
     152         234 :          CALL pao_param_finalize_linpot(pao)
     153             :       CASE (pao_gth_param)
     154          10 :          CALL pao_param_finalize_gth(pao)
     155             :       CASE (pao_equi_param)
     156          12 :          CALL pao_param_finalize_equi()
     157             :       CASE DEFAULT
     158         280 :          CPABORT("PAO: unknown parametrization")
     159             :       END SELECT
     160             : 
     161         280 :       CALL timestop(handle)
     162             : 
     163         280 :    END SUBROUTINE pao_param_finalize
     164             : 
     165             : ! **************************************************************************************************
     166             : !> \brief Returns the number of parameters for given atomic kind
     167             : !> \param pao ...
     168             : !> \param qs_env ...
     169             : !> \param ikind ...
     170             : !> \param nparams ...
     171             : ! **************************************************************************************************
     172         322 :    SUBROUTINE pao_param_count(pao, qs_env, ikind, nparams)
     173             :       TYPE(pao_env_type), POINTER                        :: pao
     174             :       TYPE(qs_environment_type), POINTER                 :: qs_env
     175             :       INTEGER, INTENT(IN)                                :: ikind
     176             :       INTEGER, INTENT(OUT)                               :: nparams
     177             : 
     178             :       CHARACTER(len=*), PARAMETER                        :: routineN = 'pao_param_count'
     179             : 
     180             :       INTEGER                                            :: handle
     181             : 
     182         322 :       CALL timeset(routineN, handle)
     183             : 
     184         386 :       SELECT CASE (pao%parameterization)
     185             :       CASE (pao_exp_param)
     186         256 :          CALL pao_param_count_exp(qs_env, ikind=ikind, nparams=nparams)
     187             :       CASE (pao_fock_param, pao_rotinv_param)
     188         214 :          CALL pao_param_count_linpot(pao, qs_env, ikind=ikind, nparams=nparams)
     189             :       CASE (pao_gth_param)
     190          66 :          CALL pao_param_count_gth(qs_env, ikind=ikind, nparams=nparams)
     191             :       CASE (pao_equi_param)
     192          44 :          CALL pao_param_count_equi(qs_env, ikind=ikind, nparams=nparams)
     193             :       CASE DEFAULT
     194         322 :          CPABORT("PAO: unknown parametrization")
     195             :       END SELECT
     196             : 
     197         322 :       CALL timestop(handle)
     198             : 
     199         322 :    END SUBROUTINE pao_param_count
     200             : 
     201             : ! **************************************************************************************************
     202             : !> \brief Fills matrix_X with an initial guess
     203             : !> \param pao ...
     204             : !> \param qs_env ...
     205             : ! **************************************************************************************************
     206          68 :    SUBROUTINE pao_param_initial_guess(pao, qs_env)
     207             :       TYPE(pao_env_type), POINTER                        :: pao
     208             :       TYPE(qs_environment_type), POINTER                 :: qs_env
     209             : 
     210             :       CHARACTER(len=*), PARAMETER :: routineN = 'pao_param_initial_guess'
     211             : 
     212             :       INTEGER                                            :: handle
     213             :       REAL(dp)                                           :: norm
     214             :       TYPE(dbcsr_type)                                   :: matrix_tmp
     215             : 
     216          68 :       CALL timeset(routineN, handle)
     217             : 
     218          82 :       SELECT CASE (pao%parameterization)
     219             :       CASE (pao_exp_param)
     220          14 :          CALL pao_param_initguess_exp(pao)
     221             :       CASE (pao_fock_param, pao_rotinv_param)
     222          34 :          CALL pao_param_initguess_linpot(pao, qs_env)
     223             :       CASE (pao_gth_param)
     224          10 :          CALL pao_param_initguess_gth(pao)
     225             :       CASE (pao_equi_param)
     226          10 :          CALL pao_param_initguess_equi(pao, qs_env)
     227             :       CASE DEFAULT
     228          68 :          CPABORT("PAO: unknown parametrization")
     229             :       END SELECT
     230             : 
     231          68 :       norm = dbcsr_frobenius_norm(pao%matrix_X)
     232          68 :       IF (pao%iw > 0) WRITE (pao%iw, *) "PAO| Made initial guess for matrix_X with norm:", norm
     233             : 
     234          68 :       IF (pao%precondition) THEN
     235             :          !TODO: multiplying a matrix into itself while retaining sparsity seems to be broken
     236          16 :          CALL dbcsr_copy(matrix_tmp, pao%matrix_X)
     237             :          CALL dbcsr_multiply("N", "N", 1.0_dp, pao%matrix_precon, matrix_tmp, &
     238          16 :                              0.0_dp, pao%matrix_X, retain_sparsity=.TRUE.)
     239          16 :          CALL dbcsr_release(matrix_tmp)
     240             :       END IF
     241             : 
     242          68 :       CALL timestop(handle)
     243             : 
     244          68 :    END SUBROUTINE pao_param_initial_guess
     245             : 
     246             : END MODULE pao_param

Generated by: LCOV version 1.15