Posts Evaluating Overlap Integral in Momentum Space
Post
Cancel

Evaluating Overlap Integral in Momentum Space

Introduction

Suppose χl,m(r) is a atomic orbital of the form:

(1)χl,m(r)=fl(r)Ylm(r^)

where fl(r) is the radial part and Ylm is the complex spherical harmonics. 1 Two types of functions are often used as atomic orbitals, i.e. Slater-type orbital (STO) 2

(2)fn,lSTO(r)=(2ζ)n+12[(2n)!]12rn1eζr

and Gaussian-type orbital (GTO): 3

(3)fn,lGTO(r)=B(l,α)rleαr2

The Fourier transform of χl,m(r) is a function of the same form, i.e. 4

(4)χ~l,m(k)=χl,m(r)eikrdr=ilgl(k)Ylm(k^)

where gl(k) is the spherical Bessel transform (SBT) of fl(r).

(5)gl(k)=2π0jl(kr)fl(r)r2dr

Let us consider first the overlap integral (or S-matrix) of two atomic orbitals with a distance R

(6)S(R)=χl1,m1(r)|χl2,m2(rR)

The integral can be performed in real-space, i.e.

(7)S(R)=χl1,m1(r)χl2,m2(rR)dr

or momentum space (Fourier space):

(8)S(R)=χ~l1,m1(k)χ~l2,m2(k)eikRdk

where the phase eikR in Eq.(8) is due to the shifting property of Fourier trasnform.

Overlap integral in momentum space

Starting with Eq.(8) and remember that the plane-wave can be expanded by spherical waves, i.e. 4

(9)eikR=4πl=0m=lliljl(kR)Ylm(k^)Ylm(R^)

where Ylm(θ,ϕ) are the complex spherical harmonics. Inserting Eq.(9) into Eq.(8), one can have

(10)S(R)=4πl=0m=llil1l2lgl1(k)Yl1m1(k^)gl2(k)Yl2m2(k^)jl(kR)Ylm(k^)Ylm(R^)k2dkdΩ(11)=4πl=0m=llil1l2l(1)m1+mG(l1,l2,l,-m1,m2,-m)Ylm(R^)0gl1(k)gl2(k)jl(kR)k2dk

where G is the Gaunt coefficient defined as integral over three complex spherical harmonics

(12)G(l1,l2,l3,m1,m2,m3)=θ=0πϕ=02πYl1m1(θ,ϕ)Yl2m2(θ,ϕ)Ylm(θ,ϕ)sinθdθdϕ
  • Note that Ylm(θ,ϕ)=(1)mYlm(θ,ϕ) is used from Eq.(10) to Eq.(11).

  • The integral over k in Eq.(11) is the inverse spherical Bessel transform of gl1(k)gl2(k).

  • In practice, real spherical harmonics Yl,m(θ,ϕ) are often used, which does not affect the validity of any of previous equations, but the Gaunt coefficients should be modified accordingly.

    (13)S(R)=4πl=0m=llil1l2lG(l1,l2,l,m1,m2,m)Yl,m(R^)0gl1(k)gl2(k)jl(kR)k2dk

    and

    (14)G(l1,l2,l3,m1,m2,m3)=θ=0πϕ=02πYl1,m1(θ,ϕ)Yl2,m2(θ,ϕ)Yl,m(θ,ϕ)sinθdθdϕ

Gaunt coefficients

Complex spherical harmonics

They Gaunt coefficients defined as Eq.(12) are related to Wigner-3j symbol by 5

(15)G(l1,l2,l3,m1,m2,m3)=(2l1+1)(2l2+1)(2l3+1)4π(l1l2l3000)(l1l2l3m1m2m3)

They obey the following symmetry rules

  • Invariant under space reflection, i.e.

    (16)G(l1,l2,l3,m1,m2,m3)=G(l1,l2,l3,m1,m2,m3)
  • Invariant under any permutation of the columns, i.e.

    (17)G(l1,l2,l3,m1,m2,m3)=G(l3,l1,l2,m3,m1,m2)=G(l2,l3,l1,m2,m3,m1)=G(l3,l2,l1,m3,m2,m1)=G(l1,l3,l2,m1,m3,m2)=G(l2,l1,l3,m2,m1,m3)
  • Non-zero only for even sum of the li, i.e. l1+l2+l3=2n for nN.

  • Non-zero for l1,l2,l3 fulfilling the triangle relation, i.e. |l1l2|ll1+l2.

  • Non-zero for m1+m2+m3=0.

As a result, the sum in Eq.(11) reduces to l=0m=lll=|l1l2|l1+l2m=llδm,m2m1.

The Gaunt coefficients can be obtained by recursion from Clebsch–Gordan coefficients.6 In sympy, one can get

1
2
3
4
from sympy.physics.wigner import gaunt
gaunt(0,0,0,0,0,0)                     # 1/(2*sqrt(pi))
gaunt(1,0,1,1,0,-1)                    # -1/(2*sqrt(pi))
gaunt(1000,1000,1200,9,3,-12).n(64)    # 0.00689500421922113448...

Real spherical harmonics

As is well known, complex and real spherical harmonics (SPH) can be inter-transformed by a unitary matrix Ul, i.e.7

(18)Yl,m(θ,ϕ)=n=02l+1Um,nlYlnl(θ,ϕ)={i2(Ylm(1)mYlm)if m<0Yl0if m=012(Yl|m|+(1)mYlm)if m>0

Therefore, the Gaunt coefficients defined in Eq.(14) can then be written as

(19)G(l1,l2,l3,m1,m2,m3)=θ=0πϕ=02πYl1,m1(θ,ϕ)Yl2,m2(θ,ϕ)Yl3,m3(θ,ϕ)sinθdθdϕ(20)=n1=02l1+1n2=02l2+1n3=02l3+1Um1,n1l1Um2,n2l2Um3,n3l3G(l1,l2,l3,n1-l1,n2-l2,n3-l3)

The Gaunt coefficients G also obey the following rules

  • Invariant under any permutation of the columns.
  • Non-zero only for even sum of the li, i.e. l1+l2+l3=2n for nN.
  • Non-zero for l1,l2,l3 fulfilling the triangle relation, i.e. |l1l2|ll1+l2.
  • Zero for m1<0, m2<0 and m3<0. To see this, by combining Eq.(18) and Eq.(20), we have

    G(l1,l2,l3,m1,m2,m3)=i22[G(l1,l2,l3,m1,m2,m3)(1)m1+m2+m3G(l1,l2,l3,m1,m2,m3)+(1)m2+m3G(l1,l2,l3,m1,m2,m3)(1)m1G(l1,l2,l3,m1,m2,m3)+(1)m1+m3G(l1,l2,l3,m1,m2,m3)(1)m2G(l1,l2,l3,m1,m2,m3)+(1)m1+m2G(l1,l2,l3,m1,m2,m3)(1)m3G(l1,l2,l3,m1,m2,m3)]

    where we have used m=m for abbreviation.

    • The Gaunt coefficients in the first two terms are apparently zero since all mi<0 and as a result the sum of mi could not possibly be zero.

    • For the Gaunt coefficients in the rest terms to be non-zero, one of the following conditions must be fulfilled:

      (21)m1=m2+m3;m2=m1+m3;m3=m1+m2

      Let’s first assume that m1=m2+m3 so that the Gaunt coefficients in the 3-rd and 4-th terms are not zero. Moreover, Due to the space reflection symmetry, the Gaunt coefficients in these two terms equal to each other. Apparently, the Gaunt coefficients in the rest terms are zero (we could not have m1=m2+m3, m2=m1+m3 and m3=m1+m2 at the same time). Now the sign before the 3-rd and 4-th terms can be written as

      (22)(1)m2+m3(1)m1=(1)m1[(1)m1+m2+m31]

      which is zero for m1=m2+m3. The same reasoning applies to the 5/6 and 7/8 terms.

  • If m1>0, m2>0 and m3>0, then non-zero for m1+m2+m3=2n for nN.

    In this case, Eq.(20) expands to

    G(l1,l2,l3,m1,m2,m3)=122[G(l1,l2,l3,m1,m2,m3)+(1)m1+m2+m3G(l1,l2,l3,m1,m2,m3)+(1)m2+m3G(l1,l2,l3,m1,m2,m3)+(1)m1G(l1,l2,l3,m1,m2,m3)+(1)m1+m3G(l1,l2,l3,m1,m2,m3)+(1)m2G(l1,l2,l3,m1,m2,m3)+(1)m1+m2G(l1,l2,l3,m1,m2,m3)+(1)m3G(l1,l2,l3,m1,m2,m3)]

    which is again non-zero only when one of the conditions in Eq.(21) is fulfilled. Assuming that m1=m2+m3, then the only non-zero terms are the third and fourth ones, where the Gaunt coefficients equal to each other, which leaves us the sign factor

    (23)(1)m2+m3+(1)m1=(1)m1[(1)m1+m2+m3+1]

    Obviously, it is non-zero only when m1+m2+m3=2n for nN.

  • Apparently, not invariant under space reflection.

Gaunt coefficients table

As can be clearly seen, the Gaunt coefficients, be it defined by complex or real SPH, only depends on the three pairs of quantum numbers (l,m). Therefore, one can calculated the coefficients in advance and look up the table when necessary, which can save some computation time. 8

1
2
3
4
from pysbt import GauntTable
GauntTable(l1=0, l2=0, l3=0, m1=0, m2=0, m3=0)    # 0.2820947917738781
GauntTable(4, 3, 1, 2, 3, 1)                      # -0.0435281713775682
GauntTable(4, 3, 1, 2, 3, 1, real=False)          # 0.0

Overlap integral of hydrogen 1s orbital

The hydrogen 1s orbital can be written as

(24)ψ10(r)=R10(r)Y0,0(θ,ϕ)=2er121π

where the unit of length is Bohr. According to Eq.(13), the overlap integral of two hydrogen 1s obitals (l1=l2=0) can be written as

(25)S10(R)=4π×G(0,0,0,0,0,0)Y0,00g(k)g(k)j0(kR)k2dk

where g(k) is the SBT of R10(r) and Y0,0=1/2π is isotropic.

As is well known, the overlap integral of two hydrogen 1s orbitals can be written as

(26)S(R)=eR(1+R+R23)

Below, we show the comparison of the overlap integral from numerical evaluation and analytic solution.

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
#!/usr/bin/env python

import numpy as np
from pysbt import sbt
from pysbt import GauntTable

N    = 256
rmin = 2.0 / 1024 / 32
rmax = 30
rr   = np.logspace(np.log10(rmin), np.log10(rmax), N, endpoint=True)
f1   = 2*np.exp(-rr)                                # R_{10}(r)
Y10  = 1 / 2 / np.sqrt(np.pi)

ss = sbt(rr)                                        # init SBT
g1 = ss.run(f1, direction=1, norm=True)             # SBT
s1 = ss.run(g1 * g1, direction=-1, norm=False)      # iSBT

sR = 4*np.pi * GauntTable(0, 0, 0, 0, 0, 0) * Y10 * s1

import matplotlib.pyplot as plt
plt.style.use('ggplot')

fig = plt.figure(
  dpi=300,
  figsize=(4, 2.5),
)

ax = plt.subplot()

ax.plot(rr, sR, ls='none', color='b',
        marker='o', ms=3, mew=0.5, mfc='w',
        label='Numeric')
ax.plot(rr, np.exp(-rr) * (1 + rr + rr**2 / 3),
        color='r', lw=0.8, ls='--', label='Analytic')

ax.legend(loc='upper right')

ax.set_xlabel('$R$ [Bohr]', labelpad=5)
ax.set_ylabel('$S(R)$', labelpad=5)

plt.tight_layout()
plt.savefig('s10.svg')
plt.show()
Figure 1. Comparison of numerical evaluation (blue circle) and analytic solution (red dashed line) of overlap integral of hydrogen 1s orbitals.

Reference

This post is licensed under CC BY 4.0 by the author.