2024-10-30 09:36:36 +01:00
|
|
|
subroutine GGTpp_ppBSE_static_kernel_C(eta,nOrb,nC,nO,nV,nR,nOO,nVV,lambda,ERI,eGF,Om1,rho1,Om2,rho2,T,KC_sta)
|
2024-09-08 17:23:23 +02:00
|
|
|
|
2024-10-30 09:36:36 +01:00
|
|
|
! Compute the VVVV block of the T-matrix static pp kernels
|
2024-09-08 17:23:23 +02:00
|
|
|
|
|
|
|
implicit none
|
|
|
|
include 'parameters.h'
|
|
|
|
|
|
|
|
! Input variables
|
|
|
|
|
|
|
|
double precision,intent(in) :: eta
|
2024-10-30 09:36:36 +01:00
|
|
|
integer,intent(in) :: nOrb
|
2024-09-08 17:23:23 +02:00
|
|
|
integer,intent(in) :: nC
|
|
|
|
integer,intent(in) :: nO
|
|
|
|
integer,intent(in) :: nV
|
|
|
|
integer,intent(in) :: nR
|
|
|
|
integer,intent(in) :: nOO
|
|
|
|
integer,intent(in) :: nVV
|
|
|
|
double precision,intent(in) :: lambda
|
2024-10-30 09:36:36 +01:00
|
|
|
double precision,intent(in) :: ERI(nOrb,nOrb,nOrb,nOrb)
|
|
|
|
double precision,intent(in) :: eGF(nOrb)
|
2024-09-08 17:23:23 +02:00
|
|
|
double precision,intent(in) :: Om1(nVV)
|
2024-10-30 09:36:36 +01:00
|
|
|
double precision,intent(in) :: rho1(nOrb,nOrb,nVV)
|
2024-09-08 17:23:23 +02:00
|
|
|
double precision,intent(in) :: Om2(nOO)
|
2024-10-30 09:36:36 +01:00
|
|
|
double precision,intent(in) :: rho2(nOrb,nOrb,nOO)
|
|
|
|
double precision,intent(in) :: T(nOrb,nOrb,nOrb,nOrb)
|
|
|
|
|
2024-09-08 17:23:23 +02:00
|
|
|
|
|
|
|
! Local variables
|
|
|
|
|
2024-10-30 09:36:36 +01:00
|
|
|
double precision :: dem,num
|
|
|
|
integer :: p,q,r,s,e,m
|
|
|
|
integer :: a,b,c,d,k,l
|
|
|
|
integer :: ab,kl,cd
|
2024-09-08 17:23:23 +02:00
|
|
|
|
|
|
|
! Output variables
|
|
|
|
|
2024-10-30 09:36:36 +01:00
|
|
|
double precision,intent(out) :: KC_sta(nVV,nVV)
|
2024-09-08 17:23:23 +02:00
|
|
|
|
2024-10-30 09:36:36 +01:00
|
|
|
! Initialization
|
|
|
|
KC_sta(:,:) = 0d0
|
|
|
|
|
|
|
|
! Computing the kernel
|
|
|
|
! This is the same code as for the GF(2) kernel with elements T instead of ERI
|
2024-09-08 17:23:23 +02:00
|
|
|
ab = 0
|
2024-10-30 09:36:36 +01:00
|
|
|
do a=nO+1,nOrb-nR
|
|
|
|
do b=a+1,nOrb-nR
|
2024-09-08 17:23:23 +02:00
|
|
|
ab = ab + 1
|
2024-10-30 09:36:36 +01:00
|
|
|
|
2024-09-08 17:23:23 +02:00
|
|
|
cd = 0
|
2024-10-30 09:36:36 +01:00
|
|
|
do c=nO+1,nOrb-nR
|
|
|
|
do d=c+1,nOrb-nR
|
2024-09-08 17:23:23 +02:00
|
|
|
cd = cd + 1
|
2024-10-30 09:36:36 +01:00
|
|
|
|
|
|
|
do m=nC+1,nO
|
|
|
|
do e=nO+1,nOrb-nR
|
|
|
|
|
|
|
|
dem = eGF(m) - eGF(e)
|
|
|
|
num = (T(a,m,c,e) - T(a,m,e,c)) * (T(e,b,m,d) - T(e,b,d,m))
|
|
|
|
num = num + (T(a,e,c,m) - T(a,e,m,c)) * (T(m,b,e,d) - T(m,b,d,e))
|
|
|
|
num = num - (T(b,m,c,e) - T(b,m,e,c)) * (T(e,a,m,d) - T(e,a,d,m))
|
|
|
|
num = num - (T(b,e,c,m) - T(b,e,m,c)) * (T(m,a,e,d) - T(m,a,d,e))
|
|
|
|
|
|
|
|
KC_sta(ab,cd) = KC_sta(ab,cd) + num*dem/(dem**2 + eta**2)
|
|
|
|
|
|
|
|
end do
|
2024-09-08 17:23:23 +02:00
|
|
|
end do
|
2024-10-30 09:36:36 +01:00
|
|
|
|
2024-09-08 17:23:23 +02:00
|
|
|
end do
|
|
|
|
end do
|
2024-10-30 09:36:36 +01:00
|
|
|
|
2024-09-08 17:23:23 +02:00
|
|
|
end do
|
|
|
|
end do
|
|
|
|
|
|
|
|
end subroutine
|