2023-11-14 13:50:53 +01:00
|
|
|
subroutine GRPA(dotest,dophRPA,dophRPAx,docrRPA,doppRPA,TDA,nBas,nC,nO,nV,nR,nS,ENuc,EGHF,ERI,dipole_int,eHF)
|
2023-10-26 18:00:16 +02:00
|
|
|
|
|
|
|
! Random-phase approximation module
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
include 'parameters.h'
|
|
|
|
|
|
|
|
! Input variables
|
|
|
|
|
2023-11-11 23:00:00 +01:00
|
|
|
logical,intent(in) :: dotest
|
|
|
|
|
|
|
|
logical,intent(in) :: dophRPA
|
|
|
|
logical,intent(in) :: dophRPAx
|
2023-11-14 13:50:53 +01:00
|
|
|
logical,intent(in) :: docrRPA
|
2023-11-11 23:00:00 +01:00
|
|
|
logical,intent(in) :: doppRPA
|
2023-10-26 18:00:16 +02:00
|
|
|
|
|
|
|
logical,intent(in) :: TDA
|
|
|
|
integer,intent(in) :: nBas
|
2023-10-26 23:28:53 +02:00
|
|
|
integer,intent(in) :: nC
|
|
|
|
integer,intent(in) :: nO
|
|
|
|
integer,intent(in) :: nV
|
|
|
|
integer,intent(in) :: nR
|
|
|
|
integer,intent(in) :: nS
|
2023-10-26 18:00:16 +02:00
|
|
|
double precision,intent(in) :: ENuc
|
2023-11-14 13:50:53 +01:00
|
|
|
double precision,intent(in) :: EGHF
|
|
|
|
double precision,intent(in) :: eHF(nBas)
|
2023-10-26 18:00:16 +02:00
|
|
|
double precision,intent(in) :: ERI(nBas,nBas,nBas,nBas)
|
|
|
|
double precision,intent(in) :: dipole_int(nBas,nBas,ncart)
|
|
|
|
|
|
|
|
! Local variables
|
|
|
|
|
|
|
|
double precision :: start_RPA ,end_RPA ,t_RPA
|
|
|
|
|
|
|
|
!------------------------------------------------------------------------
|
|
|
|
! Compute (direct) RPA excitations
|
|
|
|
!------------------------------------------------------------------------
|
|
|
|
|
|
|
|
if(dophRPA) then
|
|
|
|
|
|
|
|
call wall_time(start_RPA)
|
2023-11-14 13:50:53 +01:00
|
|
|
call phGRPA(dotest,TDA,nBas,nC,nO,nV,nR,nS,ENuc,EGHF,ERI,dipole_int,eHF)
|
2023-10-26 18:00:16 +02:00
|
|
|
call wall_time(end_RPA)
|
|
|
|
|
|
|
|
t_RPA = end_RPA - start_RPA
|
|
|
|
write(*,'(A65,1X,F9.3,A8)') 'Total CPU time for RPA = ',t_RPA,' seconds'
|
|
|
|
write(*,*)
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
!------------------------------------------------------------------------
|
|
|
|
! Compute RPAx (RPA with exchange) excitations
|
|
|
|
!------------------------------------------------------------------------
|
|
|
|
|
|
|
|
if(dophRPAx) then
|
|
|
|
|
|
|
|
call wall_time(start_RPA)
|
2023-11-14 13:50:53 +01:00
|
|
|
call phGRPAx(dotest,TDA,nBas,nC,nO,nV,nR,nS,ENuc,EGHF,ERI,dipole_int,eHF)
|
2023-10-26 18:00:16 +02:00
|
|
|
|
|
|
|
call wall_time(end_RPA)
|
|
|
|
|
|
|
|
t_RPA = end_RPA - start_RPA
|
|
|
|
write(*,'(A65,1X,F9.3,A8)') 'Total CPU time for RPAx = ',t_RPA,' seconds'
|
|
|
|
write(*,*)
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
2023-11-14 13:50:53 +01:00
|
|
|
!------------------------------------------------------------------------
|
|
|
|
! Compute crRPA excitations
|
|
|
|
!------------------------------------------------------------------------
|
|
|
|
|
|
|
|
if(docrRPA) then
|
|
|
|
|
|
|
|
call wall_time(start_RPA)
|
|
|
|
call crGRPA(dotest,TDA,nBas,nC,nO,nV,nR,nS,ENuc,EGHF,ERI,dipole_int,eHF)
|
|
|
|
call wall_time(end_RPA)
|
|
|
|
|
|
|
|
t_RPA = end_RPA - start_RPA
|
|
|
|
write(*,'(A65,1X,F9.3,A8)') 'Total CPU time for cr-RPA = ',t_RPA,' seconds'
|
|
|
|
write(*,*)
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
2023-10-26 18:00:16 +02:00
|
|
|
!------------------------------------------------------------------------
|
|
|
|
! Compute ppRPA excitations
|
|
|
|
!------------------------------------------------------------------------
|
|
|
|
|
|
|
|
if(doppRPA) then
|
|
|
|
|
|
|
|
call wall_time(start_RPA)
|
2023-11-14 13:50:53 +01:00
|
|
|
call ppGRPA(dotest,TDA,nBas,nC,nO,nV,nR,nS,ENuc,EGHF,ERI,dipole_int,eHF)
|
2023-10-26 18:00:16 +02:00
|
|
|
call wall_time(end_RPA)
|
|
|
|
|
|
|
|
t_RPA = end_RPA - start_RPA
|
|
|
|
write(*,'(A65,1X,F9.3,A8)') 'Total CPU time for pp-RPA = ',t_RPA,' seconds'
|
|
|
|
write(*,*)
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
end subroutine
|