LIBMBD METHOD: Difference between revisions
No edit summary |
No edit summary |
||
Line 2: | Line 2: | ||
{{TAGDEF|LIBMBD_METHOD|[string]}} | {{TAGDEF|LIBMBD_METHOD|[string]}} | ||
Description: {{TAG|LIBMBD_METHOD}} selects the van der Waals | Description: {{TAG|LIBMBD_METHOD}} selects one of the van der Waals methods available in library libMBD of many-body dispersion methods{{cite|libmbd_1}}{{cite|libmbd_2}}{{cite|hermann:jcp:2023}}. | ||
---- | ---- | ||
{{NB|important| This feature is available from VASP.6.3.0 onwards that needs to be compiled with [[Precompiler_options#-DUSELIBXC|-DUSELIBXC]].}} | {{NB|important| This feature is available from VASP.6.3.0 onwards that needs to be compiled with [[Precompiler_options#-DUSELIBXC|-DUSELIBXC]].}} |
Revision as of 10:23, 2 February 2024
LIBMBD_METHOD = [string]
Description: LIBMBD_METHOD selects one of the van der Waals methods available in library libMBD of many-body dispersion methods[1][2][3].
Important: This feature is available from VASP.6.3.0 onwards that needs to be compiled with -DUSELIBXC. |
LIBXC1 and LIBXC2 can be set to a label (string) or number (integer) associated with a functional listed on the Libxc website[4], e.g., GGA_X_PBE
and 101
for PBE exchange. The label indicates if this is an exchange (X), correlation (C), or exchange-correlation (XC) functional, and which family it belongs to, namely LDA (LDA or HYB_LDA), GGA (GGA or HYB_GGA) or meta-GGA (MGGA or HYB_MGGA). If LIBXC1 corresponds to an exchange functional, then it can be used in combination with LIBXC2 for the correlation functional.
Libxc is a separate library package that has to be downloaded[5] and compiled before VASP is compiled with the corresponding precompiler options and links to the libraries.
Calculations with Laplacian-dependent meta-GGA functionals and meta-GGA-based hybrid functionals are possible since VASP.6.4.0.
Warning: Do not use the Libxc functionals that are hybrid-MGGA-exchange-only, i.e., those whose label starts with HYB_MGGA_X, since the results will be wrong. |
Important: To get correct results with meta-GGA functionals (see discussion at LTBOUNDLIBXC), it is necessary to use Libxc from version 5.2.0 onwards (or the master version for the latest implemented functionals) and to compile it with the option --disable-fhc .
|
How to
The allowed possibilities for LIBXC1 and LIBXC2 are the following:
- Both LIBXC1 and LIBXC2 are specified and correspond to exchange and correlation functionals, respectively.
- Only LIBXC1 is specified and corresponds to an exchange or exchange-correlation functional.
- LIBXC1 and LIBXC2 can correspond to functionals of different families, e.g., a meta-GGA and a GGA, respectively.
Regarding other tags in INCAR related to Libxc:
- One also has to specify GGA = LIBXC for LDA, GGA and GGA-based hybrid functionals or METAGGA = LIBXC for meta-GGA functionals and meta-GGA-based hybrid functionals. Note that if one of the tags (LIBXC1 or LIBXC2 ) corresponds to a meta-GGA, while the other corresponds to a GGA or LDA, then METAGGA = LIBXC (and not GGA = LIBXC) has to be specified.
- Many of the functionals implemented in Libxc have parameters that can be modified. This can be done via the tags LIBXC1_Pn and LIBXC2_Pn, where .
- The tag LTBOUNDLIBXC, which is .FALSE. by default, allows to enforce the lower bound on the kinetic-energy density () with before is used in a meta-GGA functional from Libxc.
For calculations with hybrid functionals (LHFCALC=True), the following provides some explanations:
- The Libxc functionals whose tag starts with HYB already include the mixing parameter. Therefore, for them, the ALDAX, ALDAC, AGGAX, AGGAC, AMGGAX, and AMGGAC tags can not be used (more information on how to modify the mixing and screening parameters can be found at LIBXC1_Pn).
- If the semilocal component of the hybrid functional is constructed using Libxc functionals that do not contain HYB in the tag, then ALDAX, AGGAX, ALDAC, and AGGAC will be used and multiply
- respectively, where and .
Examples of INCAR
- PBE[6]
GGA = LIBXC LIBXC1 = GGA_X_PBE # or 101 LIBXC2 = GGA_C_PBE # or 130
- SCAN[7]
METAGGA = LIBXC LIBXC1 = MGGA_X_SCAN # or 263 LIBXC2 = MGGA_C_SCAN # or 267
- PBEh (PBE0)[8]
LHFCALC = .TRUE. AEXX = 0.25 GGA = LIBXC LIBXC1 = HYB_GGA_XC_PBEH # or 406
- SCAN0
LHFCALC = .TRUE. AEXX = 0.25 METAGGA = LIBXC LIBXC1 = MGGA_X_SCAN # or 263 LIBXC1 = MGGA_C_SCAN # or 267
Related tags and articles
LIBXC2, LIBXC1_Pn, LIBXC2_Pn, LTBOUNDLIBXC, GGA, METAGGA, LHFCALC, AEXX, ALDAX, ALDAC, AGGAX, AGGAC, AMGGAX, AMGGAC, List of hybrid functionals
References
- ↑ https://libmbd.github.io/
- ↑ https://github.com/libmbd/libmbd
- ↑ J. Hermann, M. Stöhr, S. Góger, S. Chaudhuri, B. Aradi, R. J. Maurer, and A. Tkatchenko, libMBD: A general-purpose package for scalable quantum many-body dispersion calculations, J. Chem. Phys. 159, 174802 (2023).
- ↑ https://libxc.gitlab.io/functionals/
- ↑ https://libxc.gitlab.io
- ↑ J. P. Perdew, K. Burke, and M. Ernzerhof, Phys. Rev. Lett., 77, 3865 (1996).
- ↑ J. Sun, A. Ruzsinszky, and J. P. Perdew, Phys. Rev. Lett. 115, 036402 (2015).
- ↑ C. Adamo and V. Barone, Phys. Rev. Lett., 110, 6158 (1999).