4
1
mirror of https://github.com/pfloos/quack synced 2025-01-12 05:58:26 +01:00
quack/src/GT/GTeh_excitation_density.f90

63 lines
1.7 KiB
Fortran
Raw Normal View History

2023-07-03 23:15:07 +02:00
subroutine GTeh_excitation_density(nBas,nC,nO,nR,nS,ERI,XpY,XmY,rhoL,rhoR)
2023-06-29 18:54:00 +02:00
! Compute excitation densities
implicit none
! Input variables
integer,intent(in) :: nBas,nC,nO,nR,nS
double precision,intent(in) :: ERI(nBas,nBas,nBas,nBas)
double precision,intent(in) :: XpY(nS,nS)
double precision,intent(in) :: XmY(nS,nS)
! Local variables
integer :: m,jb,p,q,j,b
2023-07-17 13:35:24 +02:00
double precision :: X,Y,Xt,Yt
2023-06-29 18:54:00 +02:00
! Output variables
2023-07-17 13:35:24 +02:00
double precision,intent(out) :: rhoL(nBas,nBas,nS,2)
double precision,intent(out) :: rhoR(nBas,nBas,nS,2)
2023-06-29 18:54:00 +02:00
! Initialization
2023-07-17 13:35:24 +02:00
rhoL(:,:,:,:) = 0d0
rhoR(:,:,:,:) = 0d0
2023-06-29 18:54:00 +02:00
!$OMP PARALLEL &
!$OMP SHARED(nC,nBas,nR,nO,nS,rhoL,rhoR,ERI,XpY,XmY) &
!$OMP PRIVATE(q,p,jb,m,X,Y) &
2023-06-29 18:54:00 +02:00
!$OMP DEFAULT(NONE)
!$OMP DO
do q=nC+1,nBas-nR
do p=nC+1,nBas-nR
jb = 0
do j=nC+1,nO
do b=nO+1,nBas-nR
jb = jb + 1
do m=1,nS
X = 0.5d0*(XpY(m,jb) + XmY(m,jb))
Y = 0.5d0*(XpY(m,jb) - XmY(m,jb))
2023-07-17 13:35:24 +02:00
Xt = 0.5d0*(XpY(jb,m) + XmY(jb,m))
Yt = 0.5d0*(XpY(jb,m) - XmY(jb,m))
rhoL(p,q,m,1) = rhoL(p,q,m,1) + ERI(p,j,b,q)*X + ERI(p,b,j,q)*Y
rhoL(p,q,m,2) = rhoL(p,q,m,2) + ERI(p,b,j,q)*X + ERI(p,j,b,q)*Y
rhoR(p,q,m,1) = rhoR(p,q,m,1) + (2d0*ERI(p,j,b,q) - ERI(p,j,q,b))*X + (2d0*ERI(p,b,j,q) - ERI(p,b,q,j))*Y
rhoR(p,q,m,2) = rhoR(p,q,m,2) + (2d0*ERI(p,b,j,q) - ERI(p,b,q,j))*X + (2d0*ERI(p,j,b,q) - ERI(p,j,q,b))*Y
2023-06-29 18:54:00 +02:00
enddo
enddo
enddo
enddo
enddo
!$OMP END DO
!$OMP END PARALLEL
end subroutine