10
1
mirror of https://github.com/pfloos/quack synced 2025-01-05 10:59:38 +01:00

fix bug in CCGW

This commit is contained in:
Pierre-Francois Loos 2022-12-06 09:15:32 +01:00
parent ab2857b377
commit c130e3a352
5 changed files with 36 additions and 16 deletions

View File

@ -1,7 +1,7 @@
# RHF UHF KS MOM # RHF UHF KS MOM
T F F F T F F F
# MP2* MP3 # MP2* MP3
T F F F
# CCD pCCD DCD CCSD CCSD(T) # CCD pCCD DCD CCSD CCSD(T)
F F F F F F F F F F
# drCCD rCCD crCCD lCCD # drCCD rCCD crCCD lCCD
@ -13,7 +13,7 @@
# G0F2* evGF2* qsGF2* G0F3 evGF3 # G0F2* evGF2* qsGF2* G0F3 evGF3
F F F F F F F F F F
# G0W0* evGW* qsGW* SRG-qsGW ufG0W0 ufGW # G0W0* evGW* qsGW* SRG-qsGW ufG0W0 ufGW
F F T F F F T F F F F T
# G0T0 evGT qsGT # G0T0 evGT qsGT
F F F F F F
# * unrestricted version available # * unrestricted version available

View File

@ -15,4 +15,4 @@
# ACFDT: AC Kx XBS # ACFDT: AC Kx XBS
F T T F T T
# BSE: BSE dBSE dTDA evDyn ppBSE BSE2 # BSE: BSE dBSE dTDA evDyn ppBSE BSE2
F F T F F T F F T F F F

View File

@ -1,2 +1,2 @@
1 1 1 1 1. 1 1 1 1 5.
2 2 2 2 1. 2 2 2 2 5.

View File

@ -29,9 +29,6 @@ subroutine CCGW(maxSCF,thresh,nBas,nC,nO,nV,nR,ERI,ENuc,ERHF,e)
integer :: nSCF integer :: nSCF
double precision :: Conv double precision :: Conv
double precision,allocatable :: eO(:)
double precision,allocatable :: eV(:)
double precision,allocatable :: OVVO(:,:,:,:) double precision,allocatable :: OVVO(:,:,:,:)
double precision,allocatable :: VOOV(:,:,:,:) double precision,allocatable :: VOOV(:,:,:,:)
@ -74,21 +71,16 @@ subroutine CCGW(maxSCF,thresh,nBas,nC,nO,nV,nR,ERI,ENuc,ERHF,e)
! Form energy denominator and guess amplitudes ! Form energy denominator and guess amplitudes
allocate(eO(nO),eV(nV))
allocate(delta_2h1p(nO,nO,nV,nBas),delta_2p1h(nO,nV,nV,nBas)) allocate(delta_2h1p(nO,nO,nV,nBas),delta_2p1h(nO,nV,nV,nBas))
allocate(V_2h1p(nBas,nO,nO,nV),V_2p1h(nBas,nO,nV,nV)) allocate(V_2h1p(nBas,nO,nO,nV),V_2p1h(nBas,nO,nV,nV))
allocate(t_2h1p(nO,nO,nV,nBas),t_2p1h(nO,nV,nV,nBas)) allocate(t_2h1p(nO,nO,nV,nBas),t_2p1h(nO,nV,nV,nBas))
allocate(x_2h1p(nBas,nBas),x_2p1h(nBas,nBas)) allocate(x_2h1p(nBas,nBas),x_2p1h(nBas,nBas))
eO(:) = e(1:nO)
eV(:) = e(nO+1:nBas)
do i=nC+1,nO do i=nC+1,nO
do j=nC+1,nO do j=nC+1,nO
do a=1,nV-nR do a=1,nV-nR
do p=nC+1,nBas-nR do p=nC+1,nBas-nR
delta_2h1p(i,j,a,p) = eO(i) + eO(j) - eV(a) - e(p)
V_2h1p(p,i,j,a) = sqrt(2d0)*ERI(p,nO+a,i,j) V_2h1p(p,i,j,a) = sqrt(2d0)*ERI(p,nO+a,i,j)
end do end do
@ -101,7 +93,6 @@ subroutine CCGW(maxSCF,thresh,nBas,nC,nO,nV,nR,ERI,ENuc,ERHF,e)
do b=1,nV-nR do b=1,nV-nR
do p=nC+1,nBas-nR do p=nC+1,nBas-nR
delta_2p1h(i,a,b,p) = eV(a) + eV(b) - eO(i) - e(p)
V_2p1h(p,i,a,b) = sqrt(2d0)*ERI(p,i,nO+b,nO+a) V_2p1h(p,i,a,b) = sqrt(2d0)*ERI(p,i,nO+b,nO+a)
end do end do
@ -117,6 +108,7 @@ subroutine CCGW(maxSCF,thresh,nBas,nC,nO,nV,nR,ERI,ENuc,ERHF,e)
Conv = 1d0 Conv = 1d0
nSCF = 0 nSCF = 0
eGW(:) = e(:)
t_2h1p(:,:,:,:) = 0d0 t_2h1p(:,:,:,:) = 0d0
t_2p1h(:,:,:,:) = 0d0 t_2p1h(:,:,:,:) = 0d0
@ -138,6 +130,32 @@ subroutine CCGW(maxSCF,thresh,nBas,nC,nO,nV,nR,ERI,ENuc,ERHF,e)
nSCF = nSCF + 1 nSCF = nSCF + 1
! Compute energy differences
do i=nC+1,nO
do j=nC+1,nO
do a=1,nV-nR
do p=nC+1,nBas-nR
delta_2h1p(i,j,a,p) = eGW(i) + eGW(j) - eGW(nO+a) - e(p)
end do
end do
end do
end do
do i=nC+1,nO
do a=1,nV-nR
do b=1,nV-nR
do p=nC+1,nBas-nR
delta_2p1h(i,a,b,p) = eGW(nO+a) + eGW(nO+b) - eGW(i) - e(p)
end do
end do
end do
end do
! Compute intermediates ! Compute intermediates
x_2h1p(:,:) = 0d0 x_2h1p(:,:) = 0d0
@ -278,6 +296,8 @@ subroutine CCGW(maxSCF,thresh,nBas,nC,nO,nV,nR,ERI,ENuc,ERHF,e)
end do end do
end do end do
! Diagonalize non-Hermitian matrix
call diagonalize_general_matrix(nBas,SigGW,eGW,cGW) call diagonalize_general_matrix(nBas,SigGW,eGW,cGW)
do p=1,nBas do p=1,nBas

View File

@ -984,7 +984,7 @@ program QuAcK
else else
call G0W0(doACFDT,exchange_kernel,doXBS,COHSEX,BSE,BSE2,TDA_W,TDA,dBSE,dTDA,evDyn,ppBSE,singlet,triplet, & call G0W0(doACFDT,exchange_kernel,doXBS,COHSEX,BSE,BSE2,TDA_W,TDA,dBSE,dTDA,evDyn,ppBSE,singlet,triplet, &
linGW,eta_GW,regGW,nBas,nC,nO,nV,nR,nS,ENuc,ERHF,ERI_AO,ERI_MO,dipole_int_MO,PHF,cHF,eHF,Vxc,eG0W0) linGW,eta_GW,regGW,nBas,nC,nO,nV,nR,nS,ENuc,ERHF,ERI_AO,ERI_MO,dipole_int_MO,PHF,cHF,eHF,Vxc,eG0W0)
! call soG0W0(doACFDT,exchange_kernel,doXBS,COHSEX,BSE,TDA_W,TDA,dBSE,dTDA,evDyn,ppBSE,singlet,triplet, & ! call ehTM(doACFDT,exchange_kernel,doXBS,COHSEX,BSE,TDA_W,TDA,dBSE,dTDA,evDyn,ppBSE,singlet,triplet, &
! linGW,eta_GW,regGW,nBas,nC,nO,nV,nR,nS,ENuc,ERHF,ERI_AO,ERI_MO,dipole_int_MO,PHF,cHF,eHF,Vxc,eG0W0) ! linGW,eta_GW,regGW,nBas,nC,nO,nV,nR,nS,ENuc,ERHF,ERI_AO,ERI_MO,dipole_int_MO,PHF,cHF,eHF,Vxc,eG0W0)
end if end if