LCOV - code coverage report
Current view: top level - src - qs_dispersion_utils.F (source / functions) Coverage Total Hit
Test: CP2K Regtests (git:561f475) Lines: 37.9 % 902 342
Test Date: 2026-06-21 06:48:54 Functions: 88.9 % 9 8

            Line data    Source code
       1              : !--------------------------------------------------------------------------------------------------!
       2              : !   CP2K: A general program to perform molecular dynamics simulations                              !
       3              : !   Copyright 2000-2026 CP2K developers group <https://cp2k.org>                                   !
       4              : !                                                                                                  !
       5              : !   SPDX-License-Identifier: GPL-2.0-or-later                                                      !
       6              : !--------------------------------------------------------------------------------------------------!
       7              : 
       8              : ! **************************************************************************************************
       9              : !> \brief Set disperson types for DFT calculations
      10              : !> \author JGH (04.2014)
      11              : ! **************************************************************************************************
      12              : MODULE qs_dispersion_utils
      13              : 
      14              :    USE atomic_kind_types,               ONLY: atomic_kind_type,&
      15              :                                               get_atomic_kind
      16              :    USE cp_log_handling,                 ONLY: cp_get_default_logger,&
      17              :                                               cp_logger_type
      18              :    USE cp_output_handling,              ONLY: cp_print_key_finished_output,&
      19              :                                               cp_print_key_unit_nr
      20              :    USE input_constants,                 ONLY: &
      21              :         vdw_nl_DRSLL, vdw_nl_LMKLL, vdw_nl_RVV10, vdw_pairpot_dftd2, vdw_pairpot_dftd3, &
      22              :         vdw_pairpot_dftd3bj, vdw_pairpot_dftd4, xc_funct_b3lyp, xc_funct_blyp, xc_funct_bp, &
      23              :         xc_funct_no_shortcut, xc_funct_pbe, xc_funct_pbe0, xc_funct_tpss, xc_none, &
      24              :         xc_vdw_fun_nonloc, xc_vdw_fun_pairpot
      25              :    USE input_section_types,             ONLY: section_vals_get_subs_vals,&
      26              :                                               section_vals_type,&
      27              :                                               section_vals_val_get
      28              :    USE kinds,                           ONLY: default_string_length,&
      29              :                                               dp
      30              :    USE physcon,                         ONLY: bohr,&
      31              :                                               kjmol
      32              :    USE qs_dispersion_types,             ONLY: qs_atom_dispersion_type,&
      33              :                                               qs_dispersion_type
      34              :    USE qs_environment_types,            ONLY: get_qs_env,&
      35              :                                               qs_environment_type
      36              :    USE qs_kind_types,                   ONLY: get_qs_kind,&
      37              :                                               qs_kind_type
      38              :    USE string_utilities,                ONLY: lowercase,&
      39              :                                               uppercase
      40              : #include "./base/base_uses.f90"
      41              : 
      42              :    IMPLICIT NONE
      43              : 
      44              :    PRIVATE
      45              : 
      46              :    CHARACTER(len=*), PARAMETER, PRIVATE :: moduleN = 'qs_dispersion_utils'
      47              : 
      48              :    PUBLIC :: qs_dispersion_env_set, qs_write_dispersion, &
      49              :              qs_scaling_dftd3, qs_scaling_dftd3bj
      50              :    PUBLIC :: cellhash, xc_functional_to_d_name, xc_functional_to_d4_name_int, xc_functional_detect_expanded
      51              : 
      52              : ! **************************************************************************************************
      53              : CONTAINS
      54              :    ! **************************************************************************************************
      55              : !> \brief ...
      56              : !> \param xc_functional_name ...
      57              : !> \param d_functional_name ...
      58              : ! **************************************************************************************************
      59           86 :    SUBROUTINE xc_functional_to_d_name(xc_functional_name, d_functional_name)
      60              :       CHARACTER(len=*), INTENT(IN)                       :: xc_functional_name
      61              :       CHARACTER(len=*), INTENT(OUT)                      :: d_functional_name
      62              : 
      63           86 :       IF (TRIM(ADJUSTL(xc_functional_name)) == "BP") THEN
      64           12 :          d_functional_name = "bp86"
      65              :       ELSE
      66           74 :          d_functional_name = TRIM(ADJUSTL(xc_functional_name))
      67           74 :          CALL lowercase(d_functional_name)
      68              :       END IF
      69              : 
      70           86 :    END SUBROUTINE xc_functional_to_d_name
      71              : 
      72              : ! **************************************************************************************************
      73              : !> \brief ...
      74              : !> \param xc_functional_id ...
      75              : !> \param xc_functional_name ...
      76              : ! **************************************************************************************************
      77            0 :    SUBROUTINE xc_functional_to_d4_name_int(xc_functional_id, xc_functional_name)
      78              :       INTEGER, INTENT(IN)                                :: xc_functional_id
      79              :       CHARACTER(len=*), INTENT(OUT)                      :: xc_functional_name
      80              : 
      81            0 :       SELECT CASE (xc_functional_id)
      82              :       CASE (xc_funct_pbe)
      83            0 :          xc_functional_name = "PBE"
      84              :       CASE (xc_funct_pbe0)
      85            0 :          xc_functional_name = "PBE0"
      86              :       CASE (xc_funct_b3lyp)
      87            0 :          xc_functional_name = "B3LYP"
      88              :       CASE (xc_funct_blyp)
      89            0 :          xc_functional_name = "BLYP"
      90              :       CASE (xc_funct_bp)
      91            0 :          xc_functional_name = "BP"
      92              :       CASE (xc_funct_tpss)
      93            0 :          xc_functional_name = "TPSS"
      94              :       CASE DEFAULT
      95            0 :          xc_functional_name = "NONE"
      96              :       END SELECT
      97              : 
      98            0 :    END SUBROUTINE xc_functional_to_d4_name_int
      99              : 
     100              : ! **************************************************************************************************
     101              : !> \brief ...
     102              : !> \param xc_fun_section ...
     103              : !> \param xc_functional_name ...
     104              : ! **************************************************************************************************
     105         6392 :    SUBROUTINE xc_functional_detect_expanded(xc_fun_section, xc_functional_name)
     106              :       TYPE(section_vals_type), POINTER                   :: xc_fun_section
     107              :       CHARACTER(len=*), INTENT(OUT)                      :: xc_functional_name
     108              : 
     109         6392 :       CHARACTER(len=20), ALLOCATABLE                     :: sub_names(:)
     110              :       INTEGER                                            :: i, n_explicit
     111              :       LOGICAL :: has_becke88, has_lyp, has_mgga_c_r2scan, has_mgga_c_scan, has_mgga_x_r2scan, &
     112              :          has_mgga_x_scan, has_optx, has_p86c, has_pbe0_13, has_vwn, has_xalpha
     113              :       REAL(dp)                                           :: scal_x_pbe
     114              :       TYPE(section_vals_type), POINTER                   :: sub_section
     115              : 
     116         6392 :       n_explicit = 0
     117         6392 :       has_becke88 = .FALSE.; has_lyp = .FALSE.; has_vwn = .FALSE.; has_p86c = .FALSE.
     118         6392 :       has_xalpha = .FALSE.; has_optx = .FALSE.; has_pbe0_13 = .FALSE.
     119         6392 :       has_mgga_c_r2scan = .FALSE.; has_mgga_x_r2scan = .FALSE.
     120         6392 :       has_mgga_c_scan = .FALSE.; has_mgga_x_scan = .FALSE.
     121              : 
     122        19176 :       ALLOCATE (sub_names(xc_fun_section%section%n_subsections))
     123              : 
     124      4525536 :       DO i = 1, xc_fun_section%section%n_subsections
     125      4519144 :          sub_section => xc_fun_section%subs_vals(i, 1)%section_vals
     126      4525536 :          IF (SIZE(sub_section%values, 2) > 0) THEN
     127         6646 :             n_explicit = n_explicit + 1
     128         6646 :             sub_names(n_explicit) = TRIM(ADJUSTL(sub_section%section%name))
     129          526 :             SELECT CASE (sub_names(n_explicit))
     130          526 :             CASE ("BECKE88"); has_becke88 = .TRUE.
     131          514 :             CASE ("LYP"); has_lyp = .TRUE.
     132           32 :             CASE ("VWN"); has_vwn = .TRUE.
     133           14 :             CASE ("P86C"); has_p86c = .TRUE.
     134           62 :             CASE ("XALPHA"); has_xalpha = .TRUE.
     135            4 :             CASE ("OPTX"); has_optx = .TRUE.
     136            4 :             CASE ("MGGA_C_R2SCAN"); has_mgga_c_r2scan = .TRUE.
     137            4 :             CASE ("MGGA_X_R2SCAN"); has_mgga_x_r2scan = .TRUE.
     138            4 :             CASE ("MGGA_C_SCAN"); has_mgga_c_scan = .TRUE.
     139            4 :             CASE ("MGGA_X_SCAN"); has_mgga_x_scan = .TRUE.
     140            0 :             CASE ("PBE0_1/3"); has_pbe0_13 = .TRUE.
     141              :             CASE ("PBE")
     142         2478 :                CALL section_vals_val_get(sub_section, "SCALE_X", r_val=scal_x_pbe)
     143         6646 :                IF (ABS(scal_x_pbe - 0.75_dp) < 0.01_dp) has_pbe0_13 = .TRUE.
     144              :             END SELECT
     145              :          END IF
     146              :       END DO
     147              : 
     148         6392 :       IF (has_becke88 .AND. has_lyp .AND. has_vwn .AND. has_xalpha) THEN
     149           32 :          xc_functional_name = "B3LYP"
     150         6360 :       ELSE IF (has_becke88 .AND. has_lyp) THEN
     151          948 :          xc_functional_name = MERGE("PBE0", "BLYP", has_pbe0_13)
     152         5886 :       ELSE IF (has_becke88 .AND. has_p86c) THEN
     153           14 :          xc_functional_name = "BP"
     154         5872 :       ELSE IF (has_optx .AND. has_lyp) THEN
     155            4 :          xc_functional_name = "OLYP"
     156         5868 :       ELSE IF (has_mgga_c_r2scan .AND. has_mgga_x_r2scan) THEN
     157            4 :          xc_functional_name = "R2SCAN"
     158         5864 :       ELSE IF (has_mgga_c_scan .AND. has_mgga_x_scan) THEN
     159            4 :          xc_functional_name = "SCAN"
     160         5860 :       ELSE IF (n_explicit == 1 .AND. has_pbe0_13) THEN
     161          554 :          xc_functional_name = "PBE0"
     162         5306 :       ELSE IF (n_explicit == 1) THEN
     163         4580 :          xc_functional_name = sub_names(1)
     164              :       ELSE
     165          726 :          xc_functional_name = "NONE"
     166              :       END IF
     167              : 
     168        12784 :    END SUBROUTINE xc_functional_detect_expanded
     169              : 
     170              : !> \brief ...
     171              : !> \param dispersion_env ...
     172              : !> \param xc_section ...
     173              : ! **************************************************************************************************
     174        12784 :    SUBROUTINE qs_dispersion_env_set(dispersion_env, xc_section)
     175              :       TYPE(qs_dispersion_type), POINTER                  :: dispersion_env
     176              :       TYPE(section_vals_type), POINTER                   :: xc_section
     177              : 
     178              :       CHARACTER(len=60)                                  :: xc_functional_name
     179              :       INTEGER                                            :: xc_functional_id
     180              :       LOGICAL                                            :: exfun, explicit
     181         6392 :       REAL(dp), POINTER                                  :: params(:), scal(:)
     182              :       TYPE(section_vals_type), POINTER                   :: nl_section, pp_section, vdw_section, &
     183              :                                                             xc_fun_section
     184              : 
     185            0 :       CPASSERT(ASSOCIATED(dispersion_env))
     186              : 
     187              :       ! set general defaults
     188         6392 :       dispersion_env%doabc = .FALSE.
     189         6392 :       dispersion_env%c9cnst = .FALSE.
     190         6392 :       dispersion_env%lrc = .FALSE.
     191         6392 :       dispersion_env%srb = .FALSE.
     192         6392 :       dispersion_env%verbose = .FALSE.
     193         6392 :       dispersion_env%nd3_exclude_pair = 0
     194         6392 :       NULLIFY (dispersion_env%c6ab, dispersion_env%maxci, dispersion_env%r0ab, dispersion_env%rcov, &
     195         6392 :                dispersion_env%r2r4, dispersion_env%cn, dispersion_env%cnkind, dispersion_env%cnlist, &
     196         6392 :                dispersion_env%d3_exclude_pair)
     197         6392 :       NULLIFY (dispersion_env%q_mesh, dispersion_env%kernel, dispersion_env%d2phi_dk2, &
     198         6392 :                dispersion_env%d2y_dx2)
     199         6392 :       NULLIFY (dispersion_env%sab_vdw, dispersion_env%sab_cn)
     200         6392 :       NULLIFY (dispersion_env%dftd_section)
     201         6392 :       NULLIFY (vdw_section, xc_fun_section)
     202         6392 :       vdw_section => section_vals_get_subs_vals(xc_section, "vdw_potential")
     203         6392 :       xc_fun_section => section_vals_get_subs_vals(xc_section, "XC_FUNCTIONAL")
     204         6392 :       CALL section_vals_val_get(xc_fun_section, "_SECTION_PARAMETERS_", i_val=xc_functional_id)
     205         6392 :       IF (xc_functional_id == xc_funct_no_shortcut .OR. xc_functional_id == xc_none) THEN
     206         6392 :          CALL xc_functional_detect_expanded(xc_fun_section, xc_functional_name)
     207              :       ELSE
     208            0 :          CALL xc_functional_to_d4_name_int(xc_functional_id, xc_functional_name)
     209              :       END IF
     210         6392 :       CALL section_vals_val_get(vdw_section, "POTENTIAL_TYPE", i_val=dispersion_env%type)
     211         6392 :       IF (dispersion_env%type == xc_vdw_fun_pairpot) THEN
     212          230 :          NULLIFY (pp_section)
     213          230 :          pp_section => section_vals_get_subs_vals(vdw_section, "PAIR_POTENTIAL")
     214          230 :          CALL section_vals_val_get(pp_section, "VERBOSE_OUTPUT", l_val=dispersion_env%verbose)
     215          230 :          CALL section_vals_val_get(pp_section, "TYPE", i_val=dispersion_env%pp_type)
     216          230 :          IF (dispersion_env%pp_type == vdw_pairpot_dftd2) THEN
     217              :             ! functional parameters for Grimme D2 type
     218           34 :             CALL section_vals_val_get(pp_section, "EXP_PRE", r_val=dispersion_env%exp_pre)
     219           34 :             CALL section_vals_val_get(pp_section, "SCALING", explicit=explicit)
     220           34 :             IF (.NOT. explicit) THEN
     221           22 :                CALL section_vals_val_get(pp_section, "REFERENCE_FUNCTIONAL", explicit=exfun)
     222           22 :                IF (.NOT. exfun) THEN
     223           12 :                   CALL xc_functional_to_d_name(xc_functional_name, dispersion_env%ref_functional)
     224           12 :                   IF (dispersion_env%ref_functional == "none") THEN
     225              :                      CALL cp_abort(__LOCATION__, &
     226              :                                    "D2 vdW: XC_FUNCTIONAL not supported. "// &
     227              :                                    "Set REFERENCE_FUNCTIONAL explicitly. "// &
     228              :                                    "Go to https://www.chemie.uni-bonn.de/grimme/de/software/dft-d3/ "// &
     229            0 :                                    "for a full list of supported functionals")
     230              :                   END IF
     231              :                ELSE
     232              :                   CALL section_vals_val_get(vdw_section, &
     233              :                                             "PAIR_POTENTIAL%REFERENCE_FUNCTIONAL", &
     234           10 :                                             c_val=dispersion_env%ref_functional)
     235              :                END IF
     236           22 :                CALL qs_scaling_dftd2(dispersion_env%scaling, dispersion_env%ref_functional)
     237              :             ELSE
     238           12 :                CALL section_vals_val_get(pp_section, "SCALING", r_val=dispersion_env%scaling)
     239              :             END IF
     240              :          ELSE
     241          196 :             dispersion_env%exp_pre = 0._dp
     242          196 :             dispersion_env%scaling = 0._dp
     243              :          END IF
     244          230 :          IF (dispersion_env%pp_type == vdw_pairpot_dftd3 .OR. &
     245              :              dispersion_env%pp_type == vdw_pairpot_dftd3bj) THEN
     246              :             ! functional parameters for Grimme DFT-D3 type
     247          154 :             CALL section_vals_val_get(pp_section, "EPS_CN", r_val=dispersion_env%eps_cn)
     248          154 :             CALL section_vals_val_get(pp_section, "CALCULATE_C9_TERM", l_val=dispersion_env%doabc)
     249          154 :             CALL section_vals_val_get(pp_section, "REFERENCE_C9_TERM", l_val=dispersion_env%c9cnst)
     250          154 :             CALL section_vals_val_get(pp_section, "LONG_RANGE_CORRECTION", l_val=dispersion_env%lrc)
     251          154 :             CALL section_vals_val_get(pp_section, "SHORT_RANGE_CORRECTION", l_val=dispersion_env%srb)
     252          154 :             CALL section_vals_val_get(pp_section, "SHORT_RANGE_CORRECTION_PARAMETERS", r_vals=params)
     253         1386 :             dispersion_env%srb_params(1:4) = params(1:4)
     254              :             ! KG corrections
     255          154 :             CALL section_vals_val_get(pp_section, "MOLECULE_CORRECTION", l_val=dispersion_env%domol)
     256          154 :             CALL section_vals_val_get(pp_section, "MOLECULE_CORRECTION_C8", r_val=dispersion_env%kgc8)
     257          154 :             IF (dispersion_env%pp_type == vdw_pairpot_dftd3) THEN
     258           80 :                CALL section_vals_val_get(pp_section, "D3_SCALING", explicit=explicit)
     259           74 :             ELSE IF (dispersion_env%pp_type == vdw_pairpot_dftd3bj) THEN
     260           74 :                CALL section_vals_val_get(pp_section, "D3BJ_SCALING", explicit=explicit)
     261              :             END IF
     262          154 :             IF (.NOT. explicit) THEN
     263          142 :                CALL section_vals_val_get(pp_section, "REFERENCE_FUNCTIONAL", explicit=exfun)
     264          142 :                IF (.NOT. exfun) THEN
     265           54 :                   CALL xc_functional_to_d_name(xc_functional_name, dispersion_env%ref_functional)
     266           54 :                   IF (dispersion_env%ref_functional == "none") THEN
     267              :                      CALL cp_abort(__LOCATION__, &
     268              :                                    "D3 vdW: XC_FUNCTIONAL not supported. "// &
     269              :                                    "Set REFERENCE_FUNCTIONAL explicitly. "// &
     270              :                                    "Go to https://www.chemie.uni-bonn.de/grimme/de/software/dft-d3/ for a full "// &
     271            0 :                                    "list of supported functionals")
     272              :                   END IF
     273              :                ELSE
     274              :                   CALL section_vals_val_get(vdw_section, &
     275              :                                             "PAIR_POTENTIAL%REFERENCE_FUNCTIONAL", &
     276           88 :                                             c_val=dispersion_env%ref_functional)
     277              :                END IF
     278              :                CALL section_vals_val_get(pp_section, "D3_REFERENCE_CODE", &
     279          142 :                                          l_val=dispersion_env%d3_reference_code)
     280          142 :                IF (.NOT. dispersion_env%d3_reference_code) THEN
     281           92 :                   IF (dispersion_env%pp_type == vdw_pairpot_dftd3) THEN
     282              :                      CALL qs_scaling_dftd3(dispersion_env%s6, dispersion_env%sr6, dispersion_env%s8, &
     283           56 :                                            dispersion_env%ref_functional)
     284           36 :                   ELSE IF (dispersion_env%pp_type == vdw_pairpot_dftd3bj) THEN
     285              :                      CALL qs_scaling_dftd3bj(dispersion_env%s6, dispersion_env%a1, dispersion_env%s8, &
     286           36 :                                              dispersion_env%a2, dispersion_env%ref_functional)
     287              :                   END IF
     288              :                END IF
     289              :             ELSE
     290           12 :                dispersion_env%d3_scaling_explicit = .TRUE.
     291           12 :                CALL section_vals_val_get(pp_section, "REFERENCE_FUNCTIONAL", explicit=exfun)
     292           12 :                IF (.NOT. exfun) THEN
     293            6 :                   CALL xc_functional_to_d_name(xc_functional_name, dispersion_env%ref_functional)
     294            6 :                   IF (dispersion_env%ref_functional == "none") THEN
     295            0 :                      dispersion_env%ref_functional = ""
     296              :                   END IF
     297              :                ELSE
     298              :                   CALL section_vals_val_get(vdw_section, &
     299              :                                             "PAIR_POTENTIAL%REFERENCE_FUNCTIONAL", &
     300            6 :                                             c_val=dispersion_env%ref_functional)
     301              :                END IF
     302              :                CALL section_vals_val_get(pp_section, "D3_REFERENCE_CODE", &
     303           12 :                                          l_val=dispersion_env%d3_reference_code)
     304           12 :                IF (.NOT. dispersion_env%d3_reference_code) THEN
     305           10 :                   IF (dispersion_env%pp_type == vdw_pairpot_dftd3) THEN
     306              :                      CALL qs_scaling_dftd3(dispersion_env%s6, dispersion_env%sr6, dispersion_env%s8, &
     307            4 :                                            dispersion_env%ref_functional)
     308            6 :                   ELSE IF (dispersion_env%pp_type == vdw_pairpot_dftd3bj) THEN
     309              :                      CALL qs_scaling_dftd3bj(dispersion_env%s6, dispersion_env%a1, dispersion_env%s8, &
     310            6 :                                              dispersion_env%a2, dispersion_env%ref_functional)
     311              :                   END IF
     312              :                END IF
     313           12 :                IF (dispersion_env%pp_type == vdw_pairpot_dftd3) THEN
     314            4 :                   CALL section_vals_val_get(pp_section, "D3_SCALING", r_vals=scal)
     315            4 :                   dispersion_env%s6 = scal(1)
     316            4 :                   dispersion_env%sr6 = scal(2)
     317            4 :                   dispersion_env%s8 = scal(3)
     318            4 :                   dispersion_env%a1 = 0.0_dp
     319            4 :                   dispersion_env%a2 = 0.0_dp
     320            8 :                ELSE IF (dispersion_env%pp_type == vdw_pairpot_dftd3bj) THEN
     321            8 :                   CALL section_vals_val_get(pp_section, "D3BJ_SCALING", r_vals=scal)
     322            8 :                   dispersion_env%s6 = scal(1)
     323            8 :                   dispersion_env%a1 = scal(2)
     324            8 :                   dispersion_env%s8 = scal(3)
     325            8 :                   dispersion_env%a2 = scal(4)
     326            8 :                   dispersion_env%sr6 = 0.0_dp
     327              :                END IF
     328              :             END IF
     329              :          ELSE
     330           76 :             dispersion_env%s6 = 0._dp
     331           76 :             dispersion_env%sr6 = 0._dp
     332           76 :             dispersion_env%s8 = 0._dp
     333           76 :             dispersion_env%s9 = 0._dp
     334           76 :             dispersion_env%a1 = 0._dp
     335           76 :             dispersion_env%a2 = 0._dp
     336           76 :             dispersion_env%eps_cn = 0._dp
     337              :          END IF
     338          230 :          IF (dispersion_env%pp_type == vdw_pairpot_dftd4) THEN
     339           42 :             CALL section_vals_val_get(pp_section, "D4_SCALING", explicit=explicit)
     340           42 :             IF (.NOT. explicit) THEN
     341           42 :                CALL section_vals_val_get(pp_section, "REFERENCE_FUNCTIONAL", explicit=exfun)
     342           42 :                IF (.NOT. exfun) THEN
     343           14 :                   CALL xc_functional_to_d_name(xc_functional_name, dispersion_env%ref_functional)
     344              :                ELSE
     345              :                   CALL section_vals_val_get(vdw_section, &
     346              :                                             "PAIR_POTENTIAL%REFERENCE_FUNCTIONAL", &
     347           28 :                                             c_val=dispersion_env%ref_functional)
     348              :                END IF
     349           42 :                IF (TRIM(ADJUSTL(dispersion_env%ref_functional)) == "none") THEN
     350            0 :                   CPABORT("D4: XC_FUNCTIONAL not supported. Set REFERENCE_FUNCTIONAL explicitly.")
     351              :                END IF
     352              :             ELSE
     353            0 :                CALL section_vals_val_get(pp_section, "D4_SCALING", r_vals=scal)
     354            0 :                dispersion_env%s6 = scal(1)
     355            0 :                dispersion_env%a1 = scal(2)
     356            0 :                dispersion_env%s8 = scal(3)
     357            0 :                dispersion_env%a2 = scal(4)
     358            0 :                dispersion_env%sr6 = 0.0_dp
     359            0 :                dispersion_env%ref_functional = "none"
     360              :             END IF
     361           42 :             CALL section_vals_val_get(pp_section, "EPS_CN", r_val=dispersion_env%eps_cn)
     362              :             CALL section_vals_val_get(pp_section, "D4_REFERENCE_CODE", &
     363           42 :                                       l_val=dispersion_env%d4_reference_code)
     364           42 :             CALL section_vals_val_get(pp_section, "D4_DEBUG", l_val=dispersion_env%d4_debug)
     365              :             CALL section_vals_val_get(pp_section, "D3_REFERENCE_CODE", &
     366           42 :                                       l_val=dispersion_env%d3_reference_code)
     367           42 :             CALL section_vals_val_get(pp_section, "D4_CUTOFF", r_val=dispersion_env%rc_d4)
     368           42 :             CALL section_vals_val_get(pp_section, "D4_CN_CUTOFF", r_val=dispersion_env%rc_cn)
     369           42 :             CALL section_vals_val_get(pp_section, "FACTOR_S9_TERM", r_val=dispersion_env%s9)
     370              :             !C9 term default=T for D4
     371           42 :             CALL section_vals_val_get(pp_section, "CALCULATE_C9_TERM", explicit=exfun)
     372           42 :             IF (exfun) THEN
     373            8 :                CALL section_vals_val_get(pp_section, "CALCULATE_C9_TERM", l_val=dispersion_env%doabc)
     374              :             ELSE
     375           34 :                dispersion_env%doabc = .TRUE.
     376              :             END IF
     377              :          END IF
     378          230 :          CALL section_vals_val_get(pp_section, "R_CUTOFF", r_val=dispersion_env%rc_disp)
     379              :          CALL section_vals_val_get(pp_section, "PARAMETER_FILE_NAME", &
     380          230 :                                    c_val=dispersion_env%parameter_file_name)
     381              :          ! set DFTD section for output handling
     382          230 :          dispersion_env%dftd_section => pp_section
     383         6162 :       ELSE IF (dispersion_env%type == xc_vdw_fun_nonloc) THEN
     384           50 :          NULLIFY (nl_section)
     385           50 :          nl_section => section_vals_get_subs_vals(vdw_section, "NON_LOCAL")
     386           50 :          CALL section_vals_val_get(nl_section, "VERBOSE_OUTPUT", l_val=dispersion_env%verbose)
     387              :          CALL section_vals_val_get(nl_section, "KERNEL_FILE_NAME", &
     388           50 :                                    c_val=dispersion_env%kernel_file_name)
     389           50 :          CALL section_vals_val_get(nl_section, "TYPE", i_val=dispersion_env%nl_type)
     390           50 :          CALL section_vals_val_get(nl_section, "CUTOFF", r_val=dispersion_env%pw_cutoff)
     391           50 :          CALL section_vals_val_get(nl_section, "PARAMETERS", r_vals=params)
     392           50 :          CALL section_vals_val_get(nl_section, "SCALE", r_val=dispersion_env%scale_rvv10)
     393           50 :          dispersion_env%b_value = params(1)
     394           50 :          dispersion_env%c_value = params(2)
     395              :       END IF
     396         6392 :    END SUBROUTINE qs_dispersion_env_set
     397              : 
     398              : ! **************************************************************************************************
     399              : !> \brief ...
     400              : !> \param qs_env ...
     401              : !> \param dispersion_env ...
     402              : !> \param ounit ...
     403              : ! **************************************************************************************************
     404         7362 :    SUBROUTINE qs_write_dispersion(qs_env, dispersion_env, ounit)
     405              :       TYPE(qs_environment_type), POINTER                 :: qs_env
     406              :       TYPE(qs_dispersion_type), POINTER                  :: dispersion_env
     407              :       INTEGER, INTENT(in), OPTIONAL                      :: ounit
     408              : 
     409              :       CHARACTER(LEN=2)                                   :: symbol
     410              :       INTEGER                                            :: i, ikind, nkind, output_unit
     411         7362 :       TYPE(atomic_kind_type), DIMENSION(:), POINTER      :: atomic_kind_set
     412              :       TYPE(cp_logger_type), POINTER                      :: logger
     413              :       TYPE(qs_atom_dispersion_type), POINTER             :: disp
     414         7362 :       TYPE(qs_kind_type), DIMENSION(:), POINTER          :: qs_kind_set
     415              :       TYPE(section_vals_type), POINTER                   :: dft_section
     416              : 
     417         7362 :       IF (PRESENT(ounit)) THEN
     418            0 :          output_unit = ounit
     419              :       ELSE
     420         7362 :          NULLIFY (logger)
     421         7362 :          logger => cp_get_default_logger()
     422              : 
     423         7362 :          dft_section => section_vals_get_subs_vals(qs_env%input, "DFT")
     424              :          output_unit = cp_print_key_unit_nr(logger, dft_section, &
     425         7362 :                                             "PRINT%DFT_CONTROL_PARAMETERS", extension=".Log")
     426              :       END IF
     427              : 
     428         7362 :       IF (output_unit > 0) THEN
     429              :          ! vdW type specific output
     430         1602 :          IF (dispersion_env%type == xc_vdw_fun_pairpot) THEN
     431          127 :             WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T67,'Pair Potential')")
     432              :             ! Pair potentials
     433          127 :             IF (dispersion_env%pp_type == vdw_pairpot_dftd2) THEN
     434           15 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T35,'DFT-D2')")
     435           15 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T35,'Potential Form: S. Grimme, JCC 27: 1787 (2006)')")
     436           15 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T35,'Cutoff Radius [Bohr]:',T73,F8.2)") dispersion_env%rc_disp
     437           15 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T35,'Scaling Factor:',T73,F8.4)") dispersion_env%scaling
     438           15 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T35,'Exp Prefactor for Damping:',T73,F8.1)") dispersion_env%exp_pre
     439           15 :                CALL get_qs_env(qs_env, atomic_kind_set=atomic_kind_set, qs_kind_set=qs_kind_set)
     440           15 :                nkind = SIZE(atomic_kind_set)
     441           40 :                DO ikind = 1, nkind
     442           25 :                   CALL get_atomic_kind(atomic_kind_set(ikind), element_symbol=symbol)
     443           25 :                   CALL get_qs_kind(qs_kind_set(ikind), dispersion=disp)
     444           40 :                   IF (disp%defined) THEN
     445              :                      WRITE (output_unit, fmt="(' vdW PARAMETER| ',T18,'Atom=',A2, "// &
     446              :                             "T28,'C6[J*nm^6*mol^-1]=',F8.4,T63,'r(vdW)[A]=',F8.4)") &
     447           25 :                         symbol, disp%c6/(1000._dp*bohr**6/kjmol), disp%vdw_radii/bohr
     448              :                   ELSE
     449            0 :                      WRITE (output_unit, fmt="(' vdW PARAMETER| ',T20,'Atom=',A2,T70,'not defined')")
     450              :                   END IF
     451              :                END DO
     452          112 :             ELSE IF (dispersion_env%pp_type == vdw_pairpot_dftd3) THEN
     453           26 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'DFT-D3 (Version 3.1)')")
     454           26 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'Potential Form: S. Grimme et al, JCP 132: 154104 (2010)')")
     455           26 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'Zero Damping')")
     456           26 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'Cutoff Radius [Bohr]:',T73,F8.2)") dispersion_env%rc_disp
     457           26 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'s6 Scaling Factor:',T73,F8.4)") dispersion_env%s6
     458           26 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'sr6 Scaling Factor:',T73,F8.4)") dispersion_env%sr6
     459           26 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'s8 Scaling Factor:',T73,F8.4)") dispersion_env%s8
     460           26 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'Cutoff for CN calculation:',T69,E12.4)") dispersion_env%eps_cn
     461           26 :                IF (dispersion_env%nd3_exclude_pair > 0) THEN
     462            0 :                   DO i = 1, dispersion_env%nd3_exclude_pair
     463              :                      WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'Excluded Pairs: ',T76,I2,' ',I2)") &
     464            0 :                         dispersion_env%d3_exclude_pair(i, :)
     465              :                   END DO
     466              :                END IF
     467           86 :             ELSE IF (dispersion_env%pp_type == vdw_pairpot_dftd3bj) THEN
     468           69 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'DFT-D3 (Version 3.1)')")
     469           69 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'Potential Form: S. Grimme et al, JCP 132: 154104 (2010)')")
     470           69 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'BJ Damping: S. Grimme et al, JCC 32: 1456 (2011)')")
     471           69 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'Cutoff Radius [Bohr]:',T73,F8.2)") dispersion_env%rc_disp
     472           69 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'s6 Scaling Factor:',T73,F8.4)") dispersion_env%s6
     473           69 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'a1 Damping Factor:',T73,F8.4)") dispersion_env%a1
     474           69 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'s8 Scaling Factor:',T73,F8.4)") dispersion_env%s8
     475           69 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'a2 Damping Factor:',T73,F8.4)") dispersion_env%a2
     476           69 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'Cutoff for CN calculation:',T69,E12.4)") dispersion_env%eps_cn
     477           69 :                IF (dispersion_env%nd3_exclude_pair > 0) THEN
     478            0 :                   DO i = 1, dispersion_env%nd3_exclude_pair
     479              :                      WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'Excluded Kind Pairs: ',T76,I2,' ',I2)") &
     480            0 :                         dispersion_env%d3_exclude_pair(i, :)
     481              :                   END DO
     482              :                END IF
     483           17 :             ELSE IF (dispersion_env%pp_type == vdw_pairpot_dftd4) THEN
     484              : #if defined(__DFTD4_V3)
     485              :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'DFT-D4(Version 3.7)')")
     486              : #else
     487           17 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'DFT-D4(Version 4.0)')")
     488              : #endif
     489           17 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'see https://github.com/dftd4/dftd4')")
     490           17 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'E. Caldeweyher et al, PCCP 22: 8499 (2020)')")
     491           17 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'E. Caldeweyher et al, JCP 150: 154122 (2019)')")
     492           17 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T26,'E. Caldeweyher et al, JCP 147: 034112 (2017)')")
     493              :             END IF
     494         1475 :          ELSE IF (dispersion_env%type == xc_vdw_fun_nonloc) THEN
     495           13 :             WRITE (output_unit, fmt="(' vdW POTENTIAL| ',T61,'Non-local Functional')")
     496              :             WRITE (output_unit, &
     497           13 :                    fmt="(' vdW POTENTIAL| ','Implementation: G. Roman-Perez, J. Soler, PRL 103: 096102 (2009)')")
     498              :             WRITE (output_unit, &
     499           13 :                    fmt="(' vdW POTENTIAL| ',T38,' T. Thonhauser et al, PRB 76: 125112 (2007)')")
     500              :             WRITE (output_unit, &
     501           13 :                    fmt="(' vdW POTENTIAL| ',T22,' R. Sabatini et al, J.Phys:Condens Matter 24: 424209 (2012)')")
     502              :             WRITE (output_unit, &
     503           13 :                    fmt="(' vdW POTENTIAL| ',T16,' Based on QE implementation by Brian Kolb, Timo Thonhauser (2009)')")
     504           13 :             SELECT CASE (dispersion_env%nl_type)
     505              :             CASE DEFAULT
     506              :                ! unknown functional
     507            0 :                CPABORT("")
     508              :             CASE (vdw_nl_DRSLL)
     509              :                WRITE (output_unit, &
     510            8 :                       fmt="(' vdW POTENTIAL| ','DRSLL Functional:           M. Dion et al, PRL 92: 246401 (2004)')")
     511              :             CASE (vdw_nl_LMKLL)
     512              :                WRITE (output_unit, &
     513            3 :                       fmt="(' vdW POTENTIAL| ','LMKLL Functional:            K. Lee et al, PRB 82: 081101 (2010)')")
     514              :             CASE (vdw_nl_RVV10)
     515              :                WRITE (output_unit, &
     516           13 :                       fmt="(' vdW POTENTIAL| ','RVV10 Functional:    R. Sabatini et al, PRB 87: 041108(R) (2013)')")
     517              :             END SELECT
     518           13 :             IF (dispersion_env%verbose) THEN
     519              :                WRITE (output_unit, &
     520           12 :                       fmt="(' vdW POTENTIAL| ','         Carrying out vdW-DF run using the following parameters:')")
     521              :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ','Nqs =',I8,'        Nr_points =',I8,'       r_max =',F10.3)") &
     522           12 :                   dispersion_env%nqs, dispersion_env%nr_points, dispersion_env%r_max
     523           12 :                WRITE (output_unit, fmt="(' vdW POTENTIAL| ','q_mesh =')")
     524          252 :                WRITE (output_unit, fmt="(8X,4F18.8)") (dispersion_env%q_mesh(i), i=1, dispersion_env%nqs)
     525              :                WRITE (output_unit, &
     526              :                       fmt="(' vdW POTENTIAL| ','Density cutoff for convolution [a.u.]:',T71,F10.1)") &
     527           12 :                   dispersion_env%pw_cutoff
     528              :             END IF
     529              :          END IF
     530              :       END IF
     531         7362 :       IF (.NOT. PRESENT(ounit)) THEN
     532              :          CALL cp_print_key_finished_output(output_unit, logger, dft_section, &
     533         7362 :                                            "PRINT%DFT_CONTROL_PARAMETERS")
     534              :       END IF
     535              : 
     536         7362 :    END SUBROUTINE qs_write_dispersion
     537              : 
     538              : ! **************************************************************************************************
     539              : !> \brief ...
     540              : !> \param scaling ...
     541              : !> \param ref_functional ...
     542              : ! **************************************************************************************************
     543           22 :    SUBROUTINE qs_scaling_dftd2(scaling, ref_functional)
     544              :       REAL(KIND=dp), INTENT(inout)                       :: scaling
     545              :       CHARACTER(LEN=default_string_length), INTENT(in)   :: ref_functional
     546              : 
     547              :       CHARACTER(LEN=default_string_length)               :: functional
     548              : 
     549           22 :       functional = ref_functional
     550           22 :       CALL uppercase(functional)
     551           22 :       SELECT CASE (TRIM(functional))
     552              :       CASE DEFAULT
     553              :          ! unknown functional
     554            0 :          CPABORT("No DFT-D2 s6 value available for this functional:"//TRIM(functional))
     555              :       CASE ("BLYP")
     556            6 :          scaling = 1.20_dp
     557              :       CASE ("B3LYP")
     558            2 :          scaling = 1.05_dp
     559              :       CASE ("TPSS")
     560            2 :          scaling = 1.00_dp
     561              :       CASE ("PBE")
     562            8 :          scaling = 0.75_dp
     563              :       CASE ("PBE0")
     564            2 :          scaling = 0.6_dp
     565              :       CASE ("B2PLYP")
     566            0 :          scaling = 0.55_dp
     567              :       CASE ("BP86")
     568            2 :          scaling = 1.05_dp
     569              :       CASE ("B97")
     570           22 :          scaling = 1.25_dp
     571              :       END SELECT
     572              : 
     573           22 :    END SUBROUTINE qs_scaling_dftd2
     574              : 
     575              : ! **************************************************************************************************
     576              : !> \brief ...
     577              : !> \param s6 ...
     578              : !> \param sr6 ...
     579              : !> \param s8 ...
     580              : !> \param ref_functional ...
     581              : ! **************************************************************************************************
     582           60 :    SUBROUTINE qs_scaling_dftd3(s6, sr6, s8, ref_functional)
     583              : 
     584              :       REAL(KIND=dp), INTENT(inout)                       :: s6, sr6, s8
     585              :       CHARACTER(LEN=default_string_length), INTENT(in)   :: ref_functional
     586              : 
     587              :       CHARACTER(LEN=default_string_length)               :: functional
     588              : 
     589           60 :       functional = ref_functional
     590           60 :       CALL uppercase(functional)
     591              :       ! values for different functionals from:
     592              :       ! https://www.chemie.uni-bonn.de/grimme/de/software/dft-d3/zero_damping
     593              :       ! L. Goerigk et al. PCCP 2017, 32147-32744, SI
     594              :       ! alternatively see the parameter file for the s-dftd3 program:
     595              :       ! https://github.com/dftd3/simple-dftd3/blob/main/assets/parameters.toml
     596           60 :       SELECT CASE (TRIM(functional))
     597              :       CASE DEFAULT
     598            0 :          CPABORT("No DFT-D3 values available for this functional:"//TRIM(ref_functional))
     599              :       CASE ("B1B95")
     600            0 :          s6 = 1.000_dp
     601            0 :          sr6 = 1.613_dp
     602            0 :          s8 = 1.868_dp
     603              :       CASE ("B2GPPLYP")
     604              :          ! L. Goerigk and S. Grimme
     605              :          ! J. Chem. Theory Comput. 2011, 7, 291-309; doi:10.1021/ct100466k
     606            0 :          s6 = 0.56_dp
     607            0 :          sr6 = 1.586_dp
     608            0 :          s8 = 0.760_dp
     609              :       CASE ("B2PLYP")
     610              :          ! L. Goerigk and S. Grimme
     611              :          ! J. Chem. Theory Comput. 2011, 7, 291-309; doi:10.1021/ct100466k
     612            2 :          s6 = 0.64_dp
     613            2 :          sr6 = 1.427_dp
     614            2 :          s8 = 1.022_dp
     615              :       CASE ("DSD-BLYP")
     616              :          ! L. Goerigk and S. Grimme
     617              :          ! J. Chem. Theory Comput. 2011, 7, 291-309; doi:10.1021/ct100466k
     618            0 :          s6 = 0.50_dp
     619            0 :          sr6 = 1.569_dp
     620            0 :          s8 = 0.705_dp
     621              :       CASE ("B3LYP")
     622              :          ! S. Grimme, J. Antony, S. Ehrlich, and H. Krieg
     623              :          ! J. Chem. Phys. 132,154104 (2010); doi:10.1063/1.3382344
     624            2 :          s6 = 1.000_dp
     625            2 :          sr6 = 1.261_dp
     626            2 :          s8 = 1.703_dp
     627              :       CASE ("B97-D")
     628              :          ! S. Grimme, J. Antony, S. Ehrlich, and H. Krieg
     629              :          ! J. Chem. Phys. 132,154104 (2010); doi:10.1063/1.3382344
     630            0 :          s6 = 1.000_dp
     631            0 :          sr6 = 0.892_dp
     632            0 :          s8 = 0.909_dp
     633              :       CASE ("BHLYP")
     634            0 :          s6 = 1.000_dp
     635            0 :          sr6 = 1.370_dp
     636            0 :          s8 = 1.442_dp
     637              :       CASE ("BLYP")
     638              :          ! S. Grimme, J. Antony, S. Ehrlich, and H. Krieg
     639              :          ! J. Chem. Phys. 132,154104 (2010); doi:10.1063/1.3382344
     640            4 :          s6 = 1.000_dp
     641            4 :          sr6 = 1.094_dp
     642            4 :          s8 = 1.682_dp
     643              :       CASE ("BP86")
     644              :          ! S. Grimme, J. Antony, S. Ehrlich, and H. Krieg
     645              :          ! J. Chem. Phys. 132,154104 (2010); doi:10.1063/1.3382344
     646            2 :          s6 = 1.000_dp
     647            2 :          sr6 = 1.139_dp
     648            2 :          s8 = 1.683_dp
     649              :       CASE ("BPBE")
     650            0 :          s6 = 1.000_dp
     651            0 :          sr6 = 1.087_dp
     652            0 :          s8 = 2.033_dp
     653              :       CASE ("MPWLYP")
     654            0 :          s6 = 1.000_dp
     655            0 :          sr6 = 1.239_dp
     656            0 :          s8 = 1.098_dp
     657              :       CASE ("PBE")
     658              :          ! S. Grimme, J. Antony, S. Ehrlich, and H. Krieg
     659              :          ! J. Chem. Phys. 132,154104 (2010); doi:10.1063/1.3382344
     660           46 :          s6 = 1.000_dp
     661           46 :          sr6 = 1.217_dp
     662           46 :          s8 = 0.722_dp
     663              :       CASE ("PBEHPBE")
     664            0 :          s6 = 1.000_dp
     665            0 :          sr6 = 1.5703_dp
     666            0 :          s8 = 1.4010_dp
     667              :       CASE ("PBE0")
     668              :          ! S. Grimme, J. Antony, S. Ehrlich, and H. Krieg
     669              :          ! J. Chem. Phys. 132,154104 (2010); doi:10.1063/1.3382344
     670            2 :          s6 = 1.000_dp
     671            2 :          sr6 = 1.287_dp
     672            2 :          s8 = 0.928_dp
     673              :       CASE ("PW6B95")
     674              :          ! S. Grimme, J. Antony, S. Ehrlich, and H. Krieg
     675              :          ! J. Chem. Phys. 132,154104 (2010); doi:10.1063/1.3382344
     676            0 :          s6 = 1.000_dp
     677            0 :          sr6 = 1.532_dp
     678            0 :          s8 = 0.862_dp
     679              :       CASE ("PWB6K")
     680            0 :          s6 = 1.000_dp
     681            0 :          sr6 = 1.660_dp
     682            0 :          s8 = 0.550_dp
     683              :       CASE ("REVPBE")
     684              :          ! S. Grimme, J. Antony, S. Ehrlich, and H. Krieg
     685              :          ! J. Chem. Phys. 132,154104 (2010); doi:10.1063/1.3382344
     686            0 :          s6 = 1.000_dp
     687            0 :          sr6 = 0.923_dp
     688            0 :          s8 = 1.010_dp
     689              :       CASE ("RPBE")
     690            0 :          s6 = 1.000_dp
     691            0 :          sr6 = 0.872_dp
     692            0 :          s8 = 0.514_dp
     693              :       CASE ("TPSS")
     694              :          ! S. Grimme, J. Antony, S. Ehrlich, and H. Krieg
     695              :          ! J. Chem. Phys. 132,154104 (2010); doi:10.1063/1.3382344
     696            2 :          s6 = 1.000_dp
     697            2 :          sr6 = 1.166_dp
     698            2 :          s8 = 1.105_dp
     699              :       CASE ("TPSS0")
     700              :          ! S. Grimme, J. Antony, S. Ehrlich, and H. Krieg
     701              :          ! J. Chem. Phys. 132,154104 (2010); doi:10.1063/1.3382344
     702            0 :          s6 = 1.000_dp
     703            0 :          sr6 = 1.252_dp
     704            0 :          s8 = 1.242_dp
     705              :       CASE ("TPSSH")
     706            0 :          s6 = 1.000_dp
     707            0 :          sr6 = 1.223_dp
     708            0 :          s8 = 1.219_dp
     709              :       CASE ("B1LYP")
     710            0 :          s6 = 1.000_dp
     711            0 :          sr6 = 1.3725_dp
     712            0 :          s8 = 1.9467_dp
     713              :       CASE ("B1P86")
     714            0 :          s6 = 1.000_dp
     715            0 :          sr6 = 1.1815_dp
     716            0 :          s8 = 1.1209_dp
     717              :       CASE ("B3P86")
     718            0 :          s6 = 1.000_dp
     719            0 :          sr6 = 1.1897_dp
     720            0 :          s8 = 1.1961_dp
     721              :       CASE ("B3PW91")
     722            0 :          s6 = 1.000_dp
     723            0 :          sr6 = 1.176_dp
     724            0 :          s8 = 1.775_dp
     725              :       CASE ("BMK")
     726            0 :          s6 = 1.000_dp
     727            0 :          sr6 = 1.931_dp
     728            0 :          s8 = 2.168_dp
     729              :       CASE ("CAMB3LYP")
     730            0 :          s6 = 1.000_dp
     731            0 :          sr6 = 1.378_dp
     732            0 :          s8 = 1.217_dp
     733              :       CASE ("LCWPBE")
     734            0 :          s6 = 1.000_dp
     735            0 :          sr6 = 1.355_dp
     736            0 :          s8 = 1.279_dp
     737              :       CASE ("M052X")
     738            0 :          s6 = 1.000_dp
     739            0 :          sr6 = 1.417_dp
     740            0 :          s8 = 0.000_dp
     741              :       CASE ("M05")
     742            0 :          s6 = 1.000_dp
     743            0 :          sr6 = 1.373_dp
     744            0 :          s8 = 0.595_dp
     745              :       CASE ("M062X")
     746            0 :          s6 = 1.000_dp
     747            0 :          sr6 = 1.619_dp
     748            0 :          s8 = 0.000_dp
     749              :       CASE ("M06HF")
     750            0 :          s6 = 1.000_dp
     751            0 :          sr6 = 1.446_dp
     752            0 :          s8 = 0.000_dp
     753              :       CASE ("M06L")
     754            0 :          s6 = 1.000_dp
     755            0 :          sr6 = 1.581_dp
     756            0 :          s8 = 0.000_dp
     757              :       CASE ("M06N")
     758            0 :          s6 = 1.000_dp
     759            0 :          sr6 = 1.325_dp
     760            0 :          s8 = 0.000_dp
     761              :       CASE ("HCTH120")
     762            0 :          s6 = 1.000_dp
     763            0 :          sr6 = 1.221_dp
     764            0 :          s8 = 1.206_dp
     765              :       CASE ("HCTH407")
     766            0 :          s6 = 1.000_dp
     767            0 :          sr6 = 4.0426_dp
     768            0 :          s8 = 2.7694_dp
     769              :       CASE ("MPW2PLYP")
     770            0 :          s6 = 1.000_dp
     771            0 :          sr6 = 1.5527_dp
     772            0 :          s8 = 0.7529_dp
     773              :       CASE ("PKZB")
     774            0 :          s6 = 1.000_dp
     775            0 :          sr6 = 0.6327_dp
     776            0 :          s8 = 0.000_dp
     777              :       CASE ("PTPSS")
     778            0 :          s6 = 0.750_dp
     779            0 :          sr6 = 1.541_dp
     780            0 :          s8 = 0.879_dp
     781              :       CASE ("PWPB95")
     782            0 :          s6 = 0.820_dp
     783            0 :          sr6 = 1.557_dp
     784            0 :          s8 = 0.705_dp
     785              :       CASE ("OLYP")
     786            0 :          s6 = 1.000_dp
     787            0 :          sr6 = 0.806_dp
     788            0 :          s8 = 1.764_dp
     789              :       CASE ("OPBE")
     790            0 :          s6 = 1.000_dp
     791            0 :          sr6 = 0.837_dp
     792            0 :          s8 = 2.055_dp
     793              :       CASE ("OTPSS")
     794            0 :          s6 = 1.000_dp
     795            0 :          sr6 = 1.128_dp
     796            0 :          s8 = 1.494_dp
     797              :       CASE ("PBE1KCIS")
     798            0 :          s6 = 1.000_dp
     799            0 :          sr6 = 3.6355_dp
     800            0 :          s8 = 1.7934_dp
     801              :       CASE ("PBE38")
     802            0 :          s6 = 1.000_dp
     803            0 :          sr6 = 1.333_dp
     804            0 :          s8 = 0.998_dp
     805              :       CASE ("PBEH1PBE")
     806            0 :          s6 = 1.000_dp
     807            0 :          sr6 = 1.3719_dp
     808            0 :          s8 = 1.0430_dp
     809              :       CASE ("PBESOL")
     810            0 :          s6 = 1.000_dp
     811            0 :          sr6 = 1.345_dp
     812            0 :          s8 = 0.612_dp
     813              :       CASE ("REVSSB")
     814            0 :          s6 = 1.000_dp
     815            0 :          sr6 = 1.221_dp
     816            0 :          s8 = 0.560_dp
     817              :       CASE ("REVTPSS")
     818            0 :          s6 = 1.000_dp
     819            0 :          sr6 = 1.3491_dp
     820            0 :          s8 = 1.3666_dp
     821              :       CASE ("SSB")
     822            0 :          s6 = 1.000_dp
     823            0 :          sr6 = 1.215_dp
     824            0 :          s8 = 0.663_dp
     825              :       CASE ("B97-1")
     826            0 :          s6 = 1.000_dp
     827            0 :          sr6 = 3.7924_dp
     828            0 :          s8 = 1.6418_dp
     829              :       CASE ("B97-2")
     830            0 :          s6 = 1.000_dp
     831            0 :          sr6 = 1.7066_dp
     832            0 :          s8 = 2.4661_dp
     833              :       CASE ("B98")
     834            0 :          s6 = 1.000_dp
     835            0 :          sr6 = 2.6895_dp
     836            0 :          s8 = 1.9078_dp
     837              :       CASE ("BOP")
     838            0 :          s6 = 1.000_dp
     839            0 :          sr6 = 0.929_dp
     840            0 :          s8 = 1.975_dp
     841              :       CASE ("HISS")
     842            0 :          s6 = 1.000_dp
     843            0 :          sr6 = 1.3338_dp
     844            0 :          s8 = 0.7615_dp
     845              :       CASE ("HSE03")
     846            0 :          s6 = 1.000_dp
     847            0 :          sr6 = 1.3944_dp
     848            0 :          s8 = 1.0156_dp
     849              :       CASE ("HSE06")
     850            0 :          s6 = 1.000_dp
     851            0 :          sr6 = 1.129_dp
     852            0 :          s8 = 0.109_dp
     853              :       CASE ("M08HX")
     854            0 :          s6 = 1.000_dp
     855            0 :          sr6 = 1.6247_dp
     856            0 :          s8 = 0.000_dp
     857              :       CASE ("MN15L")
     858            0 :          s6 = 1.000_dp
     859            0 :          sr6 = 3.3388_dp
     860            0 :          s8 = 0.000_dp
     861              :       CASE ("MPWPW91")
     862            0 :          s6 = 1.0000_dp
     863            0 :          sr6 = 1.3725_dp
     864            0 :          s8 = 1.9467_dp
     865              :       CASE ("MPW1B95")
     866            0 :          s6 = 1.000_dp
     867            0 :          sr6 = 1.605_dp
     868            0 :          s8 = 1.118_dp
     869              :       CASE ("MPW1KCIS")
     870            0 :          s6 = 1.000_dp
     871            0 :          sr6 = 1.7231_dp
     872            0 :          s8 = 2.2917_dp
     873              :       CASE ("MPW1LYP")
     874            0 :          s6 = 1.000_dp
     875            0 :          sr6 = 2.0512_dp
     876            0 :          s8 = 1.9529_dp
     877              :       CASE ("MPW1PW91")
     878            0 :          s6 = 1.000_dp
     879            0 :          sr6 = 1.2892_dp
     880            0 :          s8 = 1.4758_dp
     881              :       CASE ("MPWB1K")
     882            0 :          s6 = 1.000_dp
     883            0 :          sr6 = 1.671_dp
     884            0 :          s8 = 1.061_dp
     885              :       CASE ("MPWKCIS1K")
     886            0 :          s6 = 1.000_dp
     887            0 :          sr6 = 1.4853_dp
     888            0 :          s8 = 1.7553_dp
     889              :       CASE ("O3LYP")
     890            0 :          s6 = 1.000_dp
     891            0 :          sr6 = 1.4060_dp
     892            0 :          s8 = 1.8058_dp
     893              :       CASE ("PW1PW")
     894            0 :          s6 = 1.000_dp
     895            0 :          sr6 = 1.4968_dp
     896            0 :          s8 = 1.1786_dp
     897              :       CASE ("PW91P86")
     898            0 :          s6 = 1.0000_dp
     899            0 :          sr6 = 2.1040_dp
     900            0 :          s8 = 0.8747_dp
     901              :       CASE ("REVPBE0")
     902            0 :          s6 = 1.000_dp
     903            0 :          sr6 = 0.949_dp
     904            0 :          s8 = 0.792_dp
     905              :       CASE ("REVPBE38")
     906            0 :          s6 = 1.000_dp
     907            0 :          sr6 = 1.021_dp
     908            0 :          s8 = 0.862_dp
     909              :       CASE ("REVTPSSH")
     910            0 :          s6 = 1.000_dp
     911            0 :          sr6 = 1.3224_dp
     912            0 :          s8 = 1.2504_dp
     913              :       CASE ("REVTPSS0")
     914            0 :          s6 = 1.000_dp
     915            0 :          sr6 = 1.2881_dp
     916            0 :          s8 = 1.0649_dp
     917              :       CASE ("TPSS1KCIS")
     918            0 :          s6 = 1.000_dp
     919            0 :          sr6 = 1.7729_dp
     920            0 :          s8 = 2.0902_dp
     921              :       CASE ("THCTHHYB")
     922            0 :          s6 = 1.000_dp
     923            0 :          sr6 = 1.5001_dp
     924            0 :          s8 = 1.6302_dp
     925              :       CASE ("RPW86PBE")
     926            0 :          s6 = 1.000_dp
     927            0 :          sr6 = 1.224_dp
     928            0 :          s8 = 0.901_dp
     929              :       CASE ("SCAN")
     930            0 :          s6 = 1.000_dp
     931            0 :          sr6 = 1.324_dp
     932            0 :          s8 = 0.000_dp
     933              :       CASE ("THCTH")
     934            0 :          s6 = 1.000_dp
     935            0 :          sr6 = 0.932_dp
     936            0 :          s8 = 0.5662_dp
     937              :       CASE ("XLYP")
     938            0 :          s6 = 1.0000_dp
     939            0 :          sr6 = 0.9384_dp
     940            0 :          s8 = 0.7447_dp
     941              :       CASE ("X3LYP")
     942            0 :          s6 = 1.000_dp
     943            0 :          sr6 = 1.0000_dp
     944           60 :          s8 = 0.2990_dp
     945              :       END SELECT
     946              : 
     947           60 :    END SUBROUTINE qs_scaling_dftd3
     948              : 
     949              : ! **************************************************************************************************
     950              : !> \brief ...
     951              : !> \param s6 ...
     952              : !> \param a1 ...
     953              : !> \param s8 ...
     954              : !> \param a2 ...
     955              : !> \param ref_functional ...
     956              : ! **************************************************************************************************
     957           42 :    SUBROUTINE qs_scaling_dftd3bj(s6, a1, s8, a2, ref_functional)
     958              :       REAL(KIND=dp), INTENT(inout)                       :: s6, a1, s8, a2
     959              :       CHARACTER(LEN=default_string_length), INTENT(in)   :: ref_functional
     960              : 
     961              :       CHARACTER(LEN=default_string_length)               :: functional
     962              : 
     963           42 :       functional = ref_functional
     964           42 :       CALL uppercase(functional)
     965              : 
     966              :       ! values for different functionals from:
     967              :       ! https://www.chemie.uni-bonn.de/grimme/de/software/dft-d3/bj_damping
     968              :       ! L. Goerigk et al. PCCP 2017, 32147-32744, SI
     969              :       ! alternatively see the parameter file for the s-dftd3 program:
     970              :       ! https://github.com/dftd3/simple-dftd3/blob/main/assets/parameters.toml
     971           42 :       SELECT CASE (TRIM(functional))
     972              :       CASE DEFAULT
     973            0 :          CPABORT("No DFT-D3(BJ) values available for this functional:"//TRIM(functional))
     974              :       CASE ("B1B95")
     975            0 :          s6 = 1.0000_dp
     976            0 :          a1 = 0.2092_dp
     977            0 :          s8 = 1.4507_dp
     978            0 :          a2 = 5.5545_dp
     979              :       CASE ("B2GPPLYP")
     980            0 :          s6 = 0.5600_dp
     981            0 :          a1 = 0.0000_dp
     982            0 :          s8 = 0.2597_dp
     983            0 :          a2 = 6.3332_dp
     984              :       CASE ("B3PW91")
     985            0 :          s6 = 1.0000_dp
     986            0 :          a1 = 0.4312_dp
     987            0 :          s8 = 2.8524_dp
     988            0 :          a2 = 4.4693_dp
     989              :       CASE ("BHLYP")
     990            0 :          s6 = 1.0000_dp
     991            0 :          a1 = 0.2793_dp
     992            0 :          s8 = 1.0354_dp
     993            0 :          a2 = 4.9615_dp
     994              :       CASE ("BMK")
     995            0 :          s6 = 1.0000_dp
     996            0 :          a1 = 0.1940_dp
     997            0 :          s8 = 2.0860_dp
     998            0 :          a2 = 5.9197_dp
     999              :       CASE ("BOP")
    1000            0 :          s6 = 1.0000_dp
    1001            0 :          a1 = 0.4870_dp
    1002            0 :          s8 = 3.2950_dp
    1003            0 :          a2 = 3.5043_dp
    1004              :       CASE ("BPBE")
    1005            0 :          s6 = 1.0000_dp
    1006            0 :          a1 = 0.4567_dp
    1007            0 :          s8 = 4.0728_dp
    1008            0 :          a2 = 4.3908_dp
    1009              :       CASE ("B97-3C")
    1010            4 :          s6 = 1.0000_dp
    1011            4 :          a1 = 0.3700_dp
    1012            4 :          s8 = 1.5000_dp
    1013            4 :          a2 = 4.1000_dp
    1014              :       CASE ("CAMB3LYP")
    1015            0 :          s6 = 1.0000_dp
    1016            0 :          a1 = 0.3708_dp
    1017            0 :          s8 = 2.0674_dp
    1018            0 :          a2 = 5.4743_dp
    1019              :       CASE ("DSDBLYP")
    1020            0 :          s6 = 0.5000_dp
    1021            0 :          a1 = 0.0000_dp
    1022            0 :          s8 = 0.2130_dp
    1023            0 :          a2 = 6.0519_dp
    1024              :       CASE ("DSDPBEP86")
    1025            0 :          s6 = 0.4180_dp
    1026            0 :          a1 = 0.0000_dp
    1027            0 :          s8 = 0.0000_dp
    1028            0 :          a2 = 5.6500_dp
    1029              :       CASE ("DSDPBEB95")
    1030            0 :          s6 = 0.6100_dp
    1031            0 :          a1 = 0.0000_dp
    1032            0 :          s8 = 0.0000_dp
    1033            0 :          a2 = 6.2000_dp
    1034              :       CASE ("LCWPBE")
    1035            0 :          s6 = 1.0000_dp
    1036            0 :          a1 = 0.3919_dp
    1037            0 :          s8 = 1.8541_dp
    1038            0 :          a2 = 5.0897_dp
    1039              :       CASE ("LCWHPBE")
    1040            0 :          s6 = 1.0000_dp
    1041            0 :          a1 = 0.2746_dp
    1042            0 :          s8 = 1.1908_dp
    1043            0 :          a2 = 5.3157_dp
    1044              :       CASE ("MPW1B95")
    1045            0 :          s6 = 1.0000_dp
    1046            0 :          a1 = 0.1955_dp
    1047            0 :          s8 = 1.0508_dp
    1048            0 :          a2 = 6.4177_dp
    1049              :       CASE ("MPW2PLYP")
    1050            0 :          s6 = 0.6600_dp
    1051            0 :          a1 = 0.4105_dp
    1052            0 :          s8 = 0.6223_dp
    1053            0 :          a2 = 5.0136_dp
    1054              :       CASE ("MPWB1K")
    1055            0 :          s6 = 1.0000_dp
    1056            0 :          a1 = 0.1474_dp
    1057            0 :          s8 = 0.9499_dp
    1058            0 :          a2 = 6.6223_dp
    1059              :       CASE ("MPWLYP")
    1060            0 :          s6 = 1.0000_dp
    1061            0 :          a1 = 0.4831_dp
    1062            0 :          s8 = 2.0077_dp
    1063            0 :          a2 = 4.5323_dp
    1064              :       CASE ("OLYP")
    1065            0 :          s6 = 1.0000_dp
    1066            0 :          a1 = 0.5299_dp
    1067            0 :          s8 = 2.6205_dp
    1068            0 :          a2 = 2.8065_dp
    1069              :       CASE ("OPBE")
    1070            0 :          s6 = 1.0000_dp
    1071            0 :          a1 = 0.5512_dp
    1072            0 :          s8 = 3.3816_dp
    1073            0 :          a2 = 2.9444_dp
    1074              :       CASE ("OTPSS")
    1075            0 :          s6 = 1.0000_dp
    1076            0 :          a1 = 0.4634_dp
    1077            0 :          s8 = 2.7495_dp
    1078            0 :          a2 = 4.3153_dp
    1079              :       CASE ("PBE38")
    1080            0 :          s6 = 1.0000_dp
    1081            0 :          a1 = 0.3995_dp
    1082            0 :          s8 = 1.4623_dp
    1083            0 :          a2 = 5.1405_dp
    1084              :       CASE ("PBESOL")
    1085            0 :          s6 = 1.0000_dp
    1086            0 :          a1 = 0.4466_dp
    1087            0 :          s8 = 2.9491_dp
    1088            0 :          a2 = 6.1742_dp
    1089              :       CASE ("PTPSS")
    1090            0 :          s6 = 0.7500_dp
    1091            0 :          a1 = 0.0000_dp
    1092            0 :          s8 = 0.2804_dp
    1093            0 :          a2 = 6.5745_dp
    1094              :       CASE ("PWB6K")
    1095            0 :          s6 = 1.0000_dp
    1096            0 :          a1 = 0.1805_dp
    1097            0 :          s8 = 0.9383_dp
    1098            0 :          a2 = 7.7627_dp
    1099              :       CASE ("REVSSB")
    1100            0 :          s6 = 1.0000_dp
    1101            0 :          a1 = 0.4720_dp
    1102            0 :          s8 = 0.4389_dp
    1103            0 :          a2 = 4.0986_dp
    1104              :       CASE ("SSB")
    1105            0 :          s6 = 1.0000_dp
    1106            0 :          a1 = -0.0952_dp
    1107            0 :          s8 = -0.1744_dp
    1108            0 :          a2 = 5.2170_dp
    1109              :       CASE ("TPSSH")
    1110            0 :          s6 = 1.0000_dp
    1111            0 :          a1 = 0.4529_dp
    1112            0 :          s8 = 2.2382_dp
    1113            0 :          a2 = 4.6550_dp
    1114              :       CASE ("HCTH120")
    1115            0 :          s6 = 1.0000_dp
    1116            0 :          a1 = 0.3563_dp
    1117            0 :          s8 = 1.0821_dp
    1118            0 :          a2 = 4.3359_dp
    1119              :       CASE ("B2PLYP")
    1120            0 :          s6 = 0.6400_dp
    1121            0 :          a1 = 0.3065_dp
    1122            0 :          s8 = 0.9147_dp
    1123            0 :          a2 = 5.0570_dp
    1124              :       CASE ("B1LYP")
    1125            0 :          s6 = 1.0000_dp
    1126            0 :          a1 = 0.1986_dp
    1127            0 :          s8 = 2.1167_dp
    1128            0 :          a2 = 5.3875_dp
    1129              :       CASE ("B1P86")
    1130            0 :          s6 = 1.0000_dp
    1131            0 :          a1 = 0.4724_dp
    1132            0 :          s8 = 3.5681_dp
    1133            0 :          a2 = 4.9858_dp
    1134              :       CASE ("B3LYP", "SKALA", "SKALA-1.1", "SKALA1.1")
    1135            4 :          s6 = 1.0000_dp
    1136            4 :          a1 = 0.3981_dp
    1137            4 :          s8 = 1.9889_dp
    1138            4 :          a2 = 4.4211_dp
    1139              :       CASE ("B3P86")
    1140            0 :          s6 = 1.0000_dp
    1141            0 :          a1 = 0.4601_dp
    1142            0 :          s8 = 3.3211_dp
    1143            0 :          a2 = 4.9294_dp
    1144              :       CASE ("B97-1")
    1145            0 :          s6 = 1.0000_dp
    1146            0 :          a1 = 0.0000_dp
    1147            0 :          s8 = 0.4814_dp
    1148            0 :          a2 = 6.2279_dp
    1149              :       CASE ("B97-2")
    1150            0 :          s6 = 1.0000_dp
    1151            0 :          a1 = 0.0000_dp
    1152            0 :          s8 = 0.9448_dp
    1153            0 :          a2 = 5.4603_dp
    1154              :       CASE ("B97-D")
    1155            0 :          s6 = 1.0000_dp
    1156            0 :          a1 = 0.5545_dp
    1157            0 :          s8 = 2.2609_dp
    1158            0 :          a2 = 3.2297_dp
    1159              :       CASE ("B98")
    1160            0 :          s6 = 1.0000_dp
    1161            0 :          a1 = 0.0000_dp
    1162            0 :          s8 = 0.7086_dp
    1163            0 :          a2 = 6.0672_dp
    1164              :       CASE ("BLYP")
    1165            8 :          s6 = 1.0000_dp
    1166            8 :          a1 = 0.4298_dp
    1167            8 :          s8 = 2.6996_dp
    1168            8 :          a2 = 4.2359_dp
    1169              :       CASE ("BP86")
    1170            2 :          s6 = 1.0000_dp
    1171            2 :          a1 = 0.3946_dp
    1172            2 :          s8 = 3.2822_dp
    1173            2 :          a2 = 4.8516_dp
    1174              :       CASE ("DSD-BLYP")
    1175            0 :          s6 = 0.5000_dp
    1176            0 :          a1 = 0.0000_dp
    1177            0 :          s8 = 0.2130_dp
    1178            0 :          a2 = 6.0519_dp
    1179              :       CASE ("HCTH407")
    1180            0 :          s6 = 1.0000_dp
    1181            0 :          a1 = 0.0000_dp
    1182            0 :          s8 = 0.6490_dp
    1183            0 :          a2 = 4.8162_dp
    1184              :       CASE ("HISS")
    1185            0 :          s6 = 1.0000_dp
    1186            0 :          a1 = 0.0000_dp
    1187            0 :          s8 = 1.6112_dp
    1188            0 :          a2 = 7.3539_dp
    1189              :       CASE ("HSE03")
    1190            0 :          s6 = 1.0000_dp
    1191            0 :          a1 = 0.0000_dp
    1192            0 :          s8 = 1.1243_dp
    1193            0 :          a2 = 6.8889_dp
    1194              :       CASE ("HSE06")
    1195            0 :          s6 = 1.0000_dp
    1196            0 :          a1 = 0.3830_dp
    1197            0 :          s8 = 2.3100_dp
    1198            0 :          a2 = 5.6850_dp
    1199              :       CASE ("M11")
    1200            0 :          s6 = 1.0000_dp
    1201            0 :          a1 = 0.0000_dp
    1202            0 :          s8 = 2.8112_dp
    1203            0 :          a2 = 10.1389_dp
    1204              :       CASE ("MN12SX")
    1205            0 :          s6 = 1.0000_dp
    1206            0 :          a1 = 0.0983_dp
    1207            0 :          s8 = 1.1674_dp
    1208            0 :          a2 = 8.0259_dp
    1209              :       CASE ("MN15")
    1210            0 :          s6 = 1.0000_dp
    1211            0 :          a1 = 2.0971_dp
    1212            0 :          s8 = 0.7862_dp
    1213            0 :          a2 = 7.5923_dp
    1214              :       CASE ("MPWPW91")
    1215            0 :          s6 = 1.0000_dp
    1216            0 :          a1 = 0.3168_dp
    1217            0 :          s8 = 1.7974_dp
    1218            0 :          a2 = 4.7732_dp
    1219              :       CASE ("MPW1PW91")
    1220            0 :          s6 = 1.0000_dp
    1221            0 :          a1 = 0.3342_dp
    1222            0 :          s8 = 1.8744_dp
    1223            0 :          a2 = 4.9819_dp
    1224              :       CASE ("MPW1KCIS")
    1225            0 :          s6 = 1.0000_dp
    1226            0 :          a1 = 0.0576_dp
    1227            0 :          s8 = 1.0893_dp
    1228            0 :          a2 = 5.5314_dp
    1229              :       CASE ("MPWKCIS1K")
    1230            0 :          s6 = 1.0000_dp
    1231            0 :          a1 = 0.0855_dp
    1232            0 :          s8 = 1.2875_dp
    1233            0 :          a2 = 5.8961_dp
    1234              :       CASE ("N12SX")
    1235            0 :          s6 = 1.0000_dp
    1236            0 :          a1 = 0.3283_dp
    1237            0 :          s8 = 2.4900_dp
    1238            0 :          a2 = 5.7898_dp
    1239              :       CASE ("O3LYP")
    1240            0 :          s6 = 1.0000_dp
    1241            0 :          a1 = 0.0963_dp
    1242            0 :          s8 = 1.8171_dp
    1243            0 :          a2 = 5.9940_dp
    1244              :       CASE ("PBE0")
    1245            2 :          s6 = 1.0000_dp
    1246            2 :          a1 = 0.4145_dp
    1247            2 :          s8 = 1.2177_dp
    1248            2 :          a2 = 4.8593_dp
    1249              :       CASE ("PBE")
    1250           20 :          s6 = 1.0000_dp
    1251           20 :          a1 = 0.4289_dp
    1252           20 :          s8 = 0.7875_dp
    1253           20 :          a2 = 4.4407_dp
    1254              :       CASE ("PBEHPBE")
    1255            0 :          s6 = 1.0000_dp
    1256            0 :          a1 = 0.0000_dp
    1257            0 :          s8 = 1.1152_dp
    1258            0 :          a2 = 6.7184_dp
    1259              :       CASE ("PBEH1PBE")
    1260            0 :          s6 = 1.0000_dp
    1261            0 :          a1 = 0.0000_dp
    1262            0 :          s8 = 1.4877_dp
    1263            0 :          a2 = 7.0385_dp
    1264              :       CASE ("PBE1KCIS")
    1265            0 :          s6 = 1.0000_dp
    1266            0 :          a1 = 0.0000_dp
    1267            0 :          s8 = 0.7688_dp
    1268            0 :          a2 = 6.2794_dp
    1269              :       CASE ("PW1PW")
    1270            0 :          s6 = 1.0000_dp
    1271            0 :          a1 = 0.3807_dp
    1272            0 :          s8 = 2.3363_dp
    1273            0 :          a2 = 5.8844_dp
    1274              :       CASE ("PW6B95")
    1275            0 :          s6 = 1.0000_dp
    1276            0 :          a1 = 0.2076_dp
    1277            0 :          s8 = 0.7257_dp
    1278            0 :          a2 = 6.3750_dp
    1279              :       CASE ("PWPB95")
    1280            0 :          s6 = 0.8200_dp
    1281            0 :          a1 = 0.0000_dp
    1282            0 :          s8 = 0.2904_dp
    1283            0 :          a2 = 7.3141_dp
    1284              :       CASE ("R2SCAN")
    1285              :          ! J. Chem. Phys. 154, 061101 (2021), doi: 10.1063/5.0041008
    1286            0 :          s6 = 1.00000000_dp
    1287            0 :          a1 = 0.49484001_dp
    1288            0 :          s8 = 0.78981345_dp
    1289            0 :          a2 = 5.73083694_dp
    1290              :       CASE ("R2SCAN0")
    1291              :          ! J. Chem. Phys. 156, 134105 (2022), doi: 10.1063/5.0086040
    1292            0 :          s6 = 1.0000_dp
    1293            0 :          a1 = 0.4534_dp
    1294            0 :          s8 = 1.1846_dp
    1295            0 :          a2 = 5.8972_dp
    1296              :       CASE ("R2SCAN50")
    1297              :          ! J. Chem. Phys. 156, 134105 (2022), doi: 10.1063/5.0086040
    1298            0 :          s6 = 1.0000_dp
    1299            0 :          a1 = 0.4311_dp
    1300            0 :          s8 = 1.3294_dp
    1301            0 :          a2 = 5.9240_dp
    1302              :       CASE ("R2SCANH")
    1303              :          ! J. Chem. Phys. 156, 134105 (2022), doi: 10.1063/5.0086040
    1304            0 :          s6 = 1.0000_dp
    1305            0 :          a1 = 0.4709_dp
    1306            0 :          s8 = 1.1236_dp
    1307            0 :          a2 = 5.9157_dp
    1308              :       CASE ("REVPBE0")
    1309            0 :          s6 = 1.0000_dp
    1310            0 :          a1 = 0.4679_dp
    1311            0 :          s8 = 1.7588_dp
    1312            0 :          a2 = 3.7619_dp
    1313              :       CASE ("REVPBE38")
    1314            0 :          s6 = 1.0000_dp
    1315            0 :          a1 = 0.4309_dp
    1316            0 :          s8 = 1.4760_dp
    1317            0 :          a2 = 3.9446_dp
    1318              :       CASE ("REVPBE")
    1319            0 :          s6 = 1.0000_dp
    1320            0 :          a1 = 0.5238_dp
    1321            0 :          s8 = 2.3550_dp
    1322            0 :          a2 = 3.5016_dp
    1323              :       CASE ("REVTPSS")
    1324            0 :          s6 = 1.0000_dp
    1325            0 :          a1 = 0.4426_dp
    1326            0 :          s8 = 1.4023_dp
    1327            0 :          a2 = 4.4723_dp
    1328              :       CASE ("REVTPSS0")
    1329            0 :          s6 = 1.0000_dp
    1330            0 :          a1 = 0.2218_dp
    1331            0 :          s8 = 1.6151_dp
    1332            0 :          a2 = 5.7985_dp
    1333              :       CASE ("REVTPSSH")
    1334            0 :          s6 = 1.0000_dp
    1335            0 :          a1 = 0.2660_dp
    1336            0 :          s8 = 1.4076_dp
    1337            0 :          a2 = 5.3761_dp
    1338              :       CASE ("RPBE")
    1339            0 :          s6 = 1.0000_dp
    1340            0 :          a1 = 0.1820_dp
    1341            0 :          s8 = 0.8318_dp
    1342            0 :          a2 = 4.0094_dp
    1343              :       CASE ("RPW86PBE")
    1344            0 :          s6 = 1.0000_dp
    1345            0 :          a1 = 0.4613_dp
    1346            0 :          s8 = 1.3845_dp
    1347            0 :          a2 = 4.5062_dp
    1348              :       CASE ("RSCAN")
    1349              :          ! J. Chem. Phys. 154, 061101 (2021), doi: 10.1063/5.0041008
    1350            0 :          s6 = 1.00000000_dp
    1351            0 :          a1 = 0.47023427_dp
    1352            0 :          s8 = 1.08859014_dp
    1353            0 :          a2 = 5.73408312_dp
    1354              :       CASE ("SCAN")
    1355            0 :          s6 = 1.0000_dp
    1356            0 :          a1 = 0.538_dp
    1357            0 :          s8 = 0.0000_dp
    1358            0 :          a2 = 5.420_dp
    1359              :       CASE ("SOGGA11X")
    1360            0 :          s6 = 1.0000_dp
    1361            0 :          a1 = 0.1330_dp
    1362            0 :          s8 = 1.1426_dp
    1363            0 :          a2 = 5.7381_dp
    1364              :       CASE ("TPSS0")
    1365            0 :          s6 = 1.0000_dp
    1366            0 :          a1 = 0.3768_dp
    1367            0 :          s8 = 1.2576_dp
    1368            0 :          a2 = 4.5865_dp
    1369              :       CASE ("TPSS1KCIS")
    1370            0 :          s6 = 1.0000_dp
    1371            0 :          a1 = 0.0000_dp
    1372            0 :          s8 = 1.0542_dp
    1373            0 :          a2 = 6.0201_dp
    1374              :       CASE ("TPSS")
    1375            2 :          s6 = 1.0000_dp
    1376            2 :          a1 = 0.4535_dp
    1377            2 :          s8 = 1.9435_dp
    1378            2 :          a2 = 4.4752_dp
    1379              :       CASE ("THCTH")
    1380            0 :          s6 = 1.0000_dp
    1381            0 :          a1 = 0.0000_dp
    1382            0 :          s8 = 1.2626_dp
    1383            0 :          a2 = 5.6162_dp
    1384              :       CASE ("THCTHHYB")
    1385            0 :          s6 = 1.0000_dp
    1386            0 :          a1 = 0.0000_dp
    1387            0 :          s8 = 0.9585_dp
    1388            0 :          a2 = 6.2303_dp
    1389              :       CASE ("XLYP")
    1390            0 :          s6 = 1.0000_dp
    1391            0 :          a1 = 0.0809_dp
    1392            0 :          s8 = 1.5669_dp
    1393            0 :          a2 = 5.3166_dp
    1394              :       CASE ("X3LYP")
    1395            0 :          s6 = 1.0000_dp
    1396            0 :          a1 = 0.2022_dp
    1397            0 :          s8 = 1.5744_dp
    1398           42 :          a2 = 5.4184_dp
    1399              :       END SELECT
    1400              : 
    1401           42 :    END SUBROUTINE qs_scaling_dftd3bj
    1402              : 
    1403              : ! **************************************************************************************************
    1404              : !> \brief ...
    1405              : !> \param cell ...
    1406              : !> \param ncell ...
    1407              : !> \return ...
    1408              : ! **************************************************************************************************
    1409      3999088 :    FUNCTION cellhash(cell, ncell) RESULT(hash)
    1410              :       INTEGER, DIMENSION(3), INTENT(IN)                  :: cell, ncell
    1411              :       INTEGER                                            :: hash
    1412              : 
    1413              :       INTEGER                                            :: ix, iy, iz, nx, ny, nz
    1414              : 
    1415     15996352 :       CPASSERT(ALL(ABS(cell) <= ncell))
    1416              : 
    1417      3999088 :       ix = cell(1)
    1418      3999088 :       IF (ix /= 0) THEN
    1419      3432888 :          ix = 2*ABS(ix) - (1 + SIGN(1, ix))/2
    1420              :       END IF
    1421      3999088 :       iy = cell(2)
    1422      3999088 :       IF (iy /= 0) THEN
    1423      3432900 :          iy = 2*ABS(iy) - (1 + SIGN(1, iy))/2
    1424              :       END IF
    1425      3999088 :       iz = cell(3)
    1426      3999088 :       IF (iz /= 0) THEN
    1427      3432900 :          iz = 2*ABS(iz) - (1 + SIGN(1, iz))/2
    1428              :       END IF
    1429              : 
    1430      3999088 :       nx = 2*ncell(1) + 1
    1431      3999088 :       ny = 2*ncell(2) + 1
    1432      3999088 :       nz = 2*ncell(3) + 1
    1433              : 
    1434      3999088 :       hash = ix*ny*nz + iy*nz + iz + 1
    1435              : 
    1436      3999088 :    END FUNCTION cellhash
    1437              : ! **************************************************************************************************
    1438              : 
    1439              : END MODULE qs_dispersion_utils
        

Generated by: LCOV version 2.0-1