10
1
mirror of https://github.com/pfloos/quack synced 2024-12-31 08:35:51 +01:00

correct a few bugs in ppBSE

This commit is contained in:
Pierre-Francois Loos 2022-08-17 16:53:59 +02:00
parent 3acc640eee
commit 13ed518704
9 changed files with 31 additions and 29 deletions

View File

@ -1,5 +1,5 @@
# HF: maxSCF thresh DIIS n_diis guess_type ortho_type mix_guess level_shift stability # HF: maxSCF thresh DIIS n_diis guess_type ortho_type mix_guess level_shift stability
512 0.0000001 T 5 2 1 F 0.0 F 512 0.0000001 T 5 2 1 F 1.0 F
# MP: # MP:
# CC: maxSCF thresh DIIS n_diis # CC: maxSCF thresh DIIS n_diis

View File

@ -1,5 +1,5 @@
4 4
Formaldehyde,^1A_1,CC3,aug-cc-pVTZ
C 0.00000000 0.00000000 -0.60298508 C 0.00000000 0.00000000 -0.60298508
O 0.00000000 0.00000000 0.60539399 O 0.00000000 0.00000000 0.60539399
H 0.00000000 0.93467313 -1.18217476 H 0.00000000 0.93467313 -1.18217476

View File

@ -1,4 +1,4 @@
2 2
H 0. 0. 0. H 0. 0. 0.
H 0. 0. 1.0 H 0. 0. 0.7

View File

@ -94,8 +94,8 @@ subroutine Bethe_Salpeter_pp(TDA_W,TDA,singlet,triplet,eta,nBas,nC,nO,nV,nR,nS,E
call linear_response_pp_BSE(ispin,TDA,.true.,nBas,nC,nO,nV,nR,nOO,nVV,1d0,eGW,ERI,WB,WC,WD, & call linear_response_pp_BSE(ispin,TDA,.true.,nBas,nC,nO,nV,nR,nOO,nVV,1d0,eGW,ERI,WB,WC,WD, &
Omega1,X1,Y1,Omega2,X2,Y2,EcBSE(ispin)) Omega1,X1,Y1,Omega2,X2,Y2,EcBSE(ispin))
call print_excitation('pp-BSE (N+2)',ispin,nVV,Omega1) ! call print_excitation('pp-BSE (N+2)',ispin,nVV,Omega1)
call print_excitation('pp-BSE (N-2)',ispin,nOO,Omega2) ! call print_excitation('pp-BSE (N-2)',ispin,nOO,Omega2)
call print_transition_vectors_pp(.true.,nBas,nC,nO,nV,nR,nOO,nVV,dipole_int,Omega1,X1,Y1,Omega2,X2,Y2) call print_transition_vectors_pp(.true.,nBas,nC,nO,nV,nR,nOO,nVV,dipole_int,Omega1,X1,Y1,Omega2,X2,Y2)
@ -128,8 +128,8 @@ subroutine Bethe_Salpeter_pp(TDA_W,TDA,singlet,triplet,eta,nBas,nC,nO,nV,nR,nS,E
call linear_response_pp_BSE(ispin,TDA,.true.,nBas,nC,nO,nV,nR,nOO,nVV,1d0,eGW,ERI,WB,WC,WD, & call linear_response_pp_BSE(ispin,TDA,.true.,nBas,nC,nO,nV,nR,nOO,nVV,1d0,eGW,ERI,WB,WC,WD, &
Omega1,X1,Y1,Omega2,X2,Y2,EcBSE(ispin)) Omega1,X1,Y1,Omega2,X2,Y2,EcBSE(ispin))
call print_excitation('pp-BSE (N+2)',ispin,nVV,Omega1) ! call print_excitation('pp-BSE (N+2)',ispin,nVV,Omega1)
call print_excitation('pp-BSE (N-2)',ispin,nOO,Omega2) ! call print_excitation('pp-BSE (N-2)',ispin,nOO,Omega2)
call print_transition_vectors_pp(.false.,nBas,nC,nO,nV,nR,nOO,nVV,dipole_int,Omega1,X1,Y1,Omega2,X2,Y2) call print_transition_vectors_pp(.false.,nBas,nC,nO,nV,nR,nOO,nVV,dipole_int,Omega1,X1,Y1,Omega2,X2,Y2)

View File

@ -24,6 +24,7 @@ subroutine static_screening_WB_pp(ispin,eta,nBas,nC,nO,nV,nR,nS,nOO,nVV,lambda,E
! Local variables ! Local variables
double precision,external :: Kronecker_delta
double precision :: chi double precision :: chi
double precision :: eps double precision :: eps
integer :: a,b,i,j,ab,ij,m integer :: a,b,i,j,ab,ij,m
@ -57,7 +58,7 @@ subroutine static_screening_WB_pp(ispin,eta,nBas,nC,nO,nV,nR,nS,nOO,nVV,lambda,E
chi = chi + rho(a,j,m)*rho(b,i,m)*Omega(m)/eps chi = chi + rho(a,j,m)*rho(b,i,m)*Omega(m)/eps
enddo enddo
WB(ab,ij) = WB(ab,ij) - 4d0*lambda*chi WB(ab,ij) = WB(ab,ij) + 4d0*lambda*chi/sqrt((1d0 + Kronecker_delta(a,b))*(1d0 + Kronecker_delta(i,j)))
end do end do
end do end do

View File

@ -24,6 +24,7 @@ subroutine static_screening_WC_pp(ispin,eta,nBas,nC,nO,nV,nR,nS,nOO,nVV,lambda,E
! Local variables ! Local variables
double precision,external :: Kronecker_delta
double precision :: chi double precision :: chi
double precision :: eps double precision :: eps
integer :: a,b,c,d,ab,cd,m integer :: a,b,c,d,ab,cd,m
@ -57,8 +58,7 @@ subroutine static_screening_WC_pp(ispin,eta,nBas,nC,nO,nV,nR,nS,nOO,nVV,lambda,E
chi = chi + rho(a,d,m)*rho(b,c,m)*Omega(m)/eps chi = chi + rho(a,d,m)*rho(b,c,m)*Omega(m)/eps
enddo enddo
WC(ab,cd) = WC(ab,cd) - 4d0*lambda*chi WC(ab,cd) = WC(ab,cd) + 4d0*lambda*chi/sqrt((1d0 + Kronecker_delta(a,b))*(1d0 + Kronecker_delta(c,d)))
end do end do
end do end do

View File

@ -24,6 +24,7 @@ subroutine static_screening_WD_pp(ispin,eta,nBas,nC,nO,nV,nR,nS,nOO,nVV,lambda,E
! Local variables ! Local variables
double precision,external :: Kronecker_delta
double precision :: chi double precision :: chi
double precision :: eps double precision :: eps
integer :: i,j,k,l,ij,kl,m integer :: i,j,k,l,ij,kl,m
@ -57,7 +58,7 @@ subroutine static_screening_WD_pp(ispin,eta,nBas,nC,nO,nV,nR,nS,nOO,nVV,lambda,E
chi = chi + rho(i,l,m)*rho(j,k,m)*Omega(m)/eps chi = chi + rho(i,l,m)*rho(j,k,m)*Omega(m)/eps
enddo enddo
WD(ij,kl) = WD(ij,kl) - 4d0*lambda*chi WD(ij,kl) = WD(ij,kl) + 4d0*lambda*chi/sqrt((1d0 + Kronecker_delta(i,j))*(1d0 + Kronecker_delta(k,l)))
end do end do
end do end do

View File

@ -27,24 +27,24 @@ subroutine print_transition_vectors_pp(spin_allowed,nBas,nC,nO,nV,nR,nOO,nVV,dip
integer :: a,b,c,d,ab,cd integer :: a,b,c,d,ab,cd
integer :: i,j,k,l,ij,kl integer :: i,j,k,l,ij,kl
integer :: maxOO integer :: maxOO = 10
integer :: maxVV = 10 integer :: maxVV = 10
double precision :: S2 double precision :: S2
double precision,parameter :: thres_vec = 0.1d0 double precision,parameter :: thres_vec = 0.1d0
double precision,allocatable :: osOO(:) double precision,allocatable :: os1(:)
double precision,allocatable :: osVV(:) double precision,allocatable :: os2(:)
! Memory allocation ! Memory allocation
maxOO = min(nOO,maxOO) maxOO = min(nOO,maxOO)
maxVV = min(nVV,maxVV) maxVV = min(nVV,maxVV)
allocate(osOO(maxOO),osVV(maxVV)) allocate(os1(nVV),os2(nOO))
! Compute oscillator strengths ! Compute oscillator strengths
osOO(:) = 0d0 os1(:) = 0d0
osVV(:) = 0d0 os2(:) = 0d0
! if(spin_allowed) call oscillator_strength(nBas,nC,nO,nV,nR,nS,maxS,dipole_int,Omega,XpY,XmY,os) ! if(spin_allowed) call oscillator_strength(nBas,nC,nO,nV,nR,nS,maxS,dipole_int,Omega,XpY,XmY,os)
@ -63,8 +63,8 @@ subroutine print_transition_vectors_pp(spin_allowed,nBas,nC,nO,nV,nR,nOO,nVV,dip
end if end if
print*,'-------------------------------------------------------------' print*,'-------------------------------------------------------------'
write(*,'(A20,I3,A2,F10.6,A3,A6,F6.4,A11,F6.4)') & write(*,'(A20,I3,A2,F10.4,A3,A6,F6.4,A11,F6.4)') &
' p-p excitation n. ',ab,': ',Omega1(ab)*HaToeV,' eV',' f = ',osVV(ab),' <S**2> = ',S2 ' p-p excitation n. ',ab,': ',Omega1(ab)*HaToeV,' eV',' f = ',os1(ab),' <S**2> = ',S2
print*,'-------------------------------------------------------------' print*,'-------------------------------------------------------------'
if(spin_allowed) then if(spin_allowed) then
@ -111,14 +111,14 @@ subroutine print_transition_vectors_pp(spin_allowed,nBas,nC,nO,nV,nR,nOO,nVV,dip
! Thomas-Reiche-Kuhn sum rule ! Thomas-Reiche-Kuhn sum rule
write(*,'(A50,F10.6)') 'Thomas-Reiche-Kuhn sum rule for p-p sector = ',sum(osVV(:)) write(*,'(A50,F10.6)') 'Thomas-Reiche-Kuhn sum rule for p-p sector = ',sum(os1(:))
write(*,*) write(*,*)
!-----------------------------------------------! !-----------------------------------------------!
! Print details about excitations for hh sector ! ! Print details about excitations for hh sector !
!-----------------------------------------------! !-----------------------------------------------!
do ij=1,maxOO do ij=nOO,nOO-maxOO+1,-1
! <S**2> values ! <S**2> values
@ -129,8 +129,8 @@ subroutine print_transition_vectors_pp(spin_allowed,nBas,nC,nO,nV,nR,nOO,nVV,dip
end if end if
print*,'-------------------------------------------------------------' print*,'-------------------------------------------------------------'
write(*,'(A20,I3,A2,F10.6,A3,A6,F6.4,A11,F6.4)') & write(*,'(A20,I3,A2,F10.4,A3,A6,F6.4,A11,F6.4)') &
' h-h excitation n. ',ij,': ',Omega2(ij)*HaToeV,' eV',' f = ',osOO(ij),' <S**2> = ',S2 ' h-h excitation n. ',ij,': ',Omega2(ij)*HaToeV,' eV',' f = ',os2(ij),' <S**2> = ',S2
print*,'-------------------------------------------------------------' print*,'-------------------------------------------------------------'
if(spin_allowed) then if(spin_allowed) then
@ -177,7 +177,7 @@ subroutine print_transition_vectors_pp(spin_allowed,nBas,nC,nO,nV,nR,nOO,nVV,dip
! Thomas-Reiche-Kuhn sum rule ! Thomas-Reiche-Kuhn sum rule
write(*,'(A50,F10.6)') 'Thomas-Reiche-Kuhn sum rule for h-h sector = ',sum(osOO(:)) write(*,'(A50,F10.6)') 'Thomas-Reiche-Kuhn sum rule for h-h sector = ',sum(os2(:))
write(*,*) write(*,*)
end subroutine print_transition_vectors_pp end subroutine print_transition_vectors_pp

View File

@ -69,8 +69,8 @@ subroutine ppRPA(TDA,doACFDT,singlet,triplet,nBas,nC,nO,nV,nR,ENuc,ERHF,ERI,dipo
call linear_response_pp(ispin,TDA,nBas,nC,nO,nV,nR,nOO,nVV,1d0,e,ERI, & call linear_response_pp(ispin,TDA,nBas,nC,nO,nV,nR,nOO,nVV,1d0,e,ERI, &
Omega1,X1,Y1,Omega2,X2,Y2,Ec_ppRPA(ispin)) Omega1,X1,Y1,Omega2,X2,Y2,Ec_ppRPA(ispin))
call print_excitation('pp-RPA (N+2)',ispin,nVV,Omega1) ! call print_excitation('pp-RPA (N+2)',ispin,nVV,Omega1)
call print_excitation('pp-RPA (N-2)',ispin,nOO,Omega2) ! call print_excitation('pp-RPA (N-2)',ispin,nOO,Omega2)
call print_transition_vectors_pp(.true.,nBas,nC,nO,nV,nR,nOO,nVV,dipole_int,Omega1,X1,Y1,Omega2,X2,Y2) call print_transition_vectors_pp(.true.,nBas,nC,nO,nV,nR,nOO,nVV,dipole_int,Omega1,X1,Y1,Omega2,X2,Y2)
@ -92,8 +92,8 @@ subroutine ppRPA(TDA,doACFDT,singlet,triplet,nBas,nC,nO,nV,nR,ENuc,ERHF,ERI,dipo
call linear_response_pp(ispin,TDA,nBas,nC,nO,nV,nR,nOO,nVV,1d0,e,ERI, & call linear_response_pp(ispin,TDA,nBas,nC,nO,nV,nR,nOO,nVV,1d0,e,ERI, &
Omega1,X1,Y1,Omega2,X2,Y2,Ec_ppRPA(ispin)) Omega1,X1,Y1,Omega2,X2,Y2,Ec_ppRPA(ispin))
call print_excitation('pp-RPA (N+2)',ispin,nVV,Omega1) ! call print_excitation('pp-RPA (N+2)',ispin,nVV,Omega1)
call print_excitation('pp-RPA (N-2)',ispin,nOO,Omega2) ! call print_excitation('pp-RPA (N-2)',ispin,nOO,Omega2)
call print_transition_vectors_pp(.false.,nBas,nC,nO,nV,nR,nOO,nVV,dipole_int,Omega1,X1,Y1,Omega2,X2,Y2) call print_transition_vectors_pp(.false.,nBas,nC,nO,nV,nR,nOO,nVV,dipole_int,Omega1,X1,Y1,Omega2,X2,Y2)