File: chemistry.dox

package info (click to toggle)
madness 0.10.1%2Bgit20200818.eee5fd9f-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, trixie
  • size: 34,980 kB
  • sloc: cpp: 280,841; ansic: 12,626; python: 4,961; fortran: 4,245; xml: 1,053; makefile: 714; sh: 276; perl: 244; yacc: 227; lex: 188; asm: 141; csh: 55
file content (138 lines) | stat: -rw-r--r-- 6,492 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
/*
  This file is part of MADNESS.

  Copyright (C) 2015 Stony Brook University

  This program is free software; you can redistribute it and/or modify
  it under the terms of the GNU General Public License as published by
  the Free Software Foundation; either version 2 of the License, or
  (at your option) any later version.

  This program is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  GNU General Public License for more details.

  You should have received a copy of the GNU General Public License
  along with this program; if not, write to the Free Software
  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA

  For more information please contact:

  Robert J. Harrison
  Oak Ridge National Laboratory
  One Bethel Valley Road
  P.O. Box 2008, MS-6367

  email: harrisonrj@ornl.gov
  tel:   865-241-3937
  fax:   865-572-0680
*/

/**
 \file chemistry.dox
 \brief Overview over quantum chemistry implementations in the MADNESS framework.
 \addtogroup chemistry

\par Background

MADNESS does quantum chemistry

\par DFT functionals for the user

A molecular wave function may be determined using the ground state density only. 
For all but the simplest local density approximation functionals we use the density functional library <a href=http://www.tddft.org/programs/octopus/wiki/index.php/Libxc>libxc</a>.
The user may request a functional according to the general syntax
\code
 xc  FUNC1 weight1 FUNC2 weight2 ..
\endcode
where FUNC1 etc are the name of a libxc functional, and the weight describes the admixture coefficient

or use the following predefined functionals (not case sensitive)
\code
 xc hf
 xc lda
 xc bp
 xc pbe
 xc pbe0
 xc b3lyp
\endcode

As an example, the PBE0 functional would be expressed in the general syntax as
\code
 xc  GGA_X_PBE 0.75 GGA_C_PBE 1.0 HF 0.25
\endcode

Expert parameters are RHOTOL, RHOMIN, and GGATOL, which determine at which density value threshold (RHOTOL) the density will be set to RHOMIN inside libxc, and at which density the gga potential will be munged, since it might not be bound.


\par DFT functionals for the developer

A DFT functional is most easily constructed through the use of the madness::XCOperator class in SCFOperators.h
\code
 #include "SCFOperators.h"
 XCOperator xc_operator(world,&calc,ispin);
\endcode

where the arguments to the constructor are the world and a pointer to a madness::SCF or madness::Nemo calculation. 
The constructor will create the necessary density and density gradients (in XCOperator::prep_xc_args() ).
Note that the ispin argument (0 for alpha, 1 for beta) is only important for the computation of the xc potential, and may be changed later on to avoid re-creation of the density (gradients).
The functional information is passed to the constructor through the calculation parameters.

A DFT energy and potential can be constructed as
\code
double ex_energy=xc_operator.compute_xc_energy();
real_function_3d xc_potential=xc_operator.make_xc_potential();
\endcode

Direct application of the XC functional to a vector of orbitals mo may be accomplished as
\code 
std::vector<real_function_3d> vmo = xc_operator(mo);
\endcode

If a response kernel is requested (e.g. in CPHF equations, or in linear response), the kernel itself is numerically unstable. 
To some extent this instability is circumvented by performing as many operations as possible on a fixed grid, so that only the result of the kernel application is available
\code
real_function_3d result=xc_operator.apply_xc_kernel(perturbed_density);
\endcode


\par Internal implementation details

For LDA functionals the density is processed as-is, only very small and negative densities  are set to zero (through the RHOTOL and RHOMIN arguments).

For GGA functionals the reduced density gradients \f$ \sigma\f$ are necessary, which decay very fast and cause numerical instabilites. 
To avoid these instabilities we express the density gradients as
\f{align}{
\rho &= exp(\zeta) \\
\nabla \rho &= \rho \nabla \zeta \\
\sigma &= |\nabla\rho|^2 = |\nabla \zeta|^2 \rho^2 = \chi \rho^2
\f}
which defines the quantities \f$ \zeta\f$ and \f$ \chi \f$.
The functional form of \f$\zeta\f$ is a superposition of cones located at the nuclei with asymptotic slope of the HOMO orbital energy, its derivative is numerically more stable than that of the density itself.
In this way the density gradients and the density may be munged in a consistent manner.
In fact, often the ratio \f$ \sigma/\rho^2 =\chi\f$ is used in DFT functionals.
All functions are passed to libxc through the madness::XCfunctional interface class. 
A vector of functions named xc_arg is passed to the multiop method, with the various functions being on enumerated vector positions, described in madness::XCfunctional::xc_arg.

Response kernels for GGA are even more numerically unstable than the XC potential. 
We use the same log-derivative trick as before, which fixes the long-range noise. 
However the intermediate potentials have to be multiplied with the gradients of the (perturbed) density, followed by taking the divergence, which is equivalent to applying the Laplacian to the (perturbed) density. 
Numerical noise is amplified and convergence during the SCF or CPHF iterations might not be achieved.
Furthermore, the perturbed density is not strictly positive, so its logarithm is not defined.
We can pull an unperturbed density out of the perturbed density gradient to regain some stability
\f{align}{
\sigma_\mathrm{pt}	&=\nabla\rho\cdot\nabla\rho_\mathrm{pt} = \rho\left(\nabla\zeta\cdot\nabla\rho_\mathrm{pt}\right)
\f}


The code in XCOperator works as follows
 - compute \f$\zeta\f$, density gradients, etc through madness::XCOperator::prep_xc_args and put them on a vector of functions. So far these are spin densities.
 - call xc_potential or xc_kernel_apply
   - call \c madness::XCfunctional::make_libxc_args to munge the density and density gradients -- convert spin density to full density if spin-restricted
   - call libxc functions to compute the functional derivatives of the density functional
   - multiply intermediate quantities to the functional derivatives
   - return scalar intermediates, for the exact description see in madness::XCfunctional::vxc and madness::XCfunctional::fxc_apply
 - multiply the semilocal intermediates with the density gradients, take div operator

*/