4
1
mirror of https://github.com/pfloos/quack synced 2024-06-26 15:12:17 +02:00
quack/src/eDFT/fock_exchange_individual_energy.f90

47 lines
1.2 KiB
Fortran
Raw Normal View History

2022-01-07 09:13:38 +01:00
subroutine fock_exchange_individual_energy(nBas,nEns,Pw,P,ERI,LZx,Ex)
2020-03-31 22:15:45 +02:00
2021-11-08 09:55:39 +01:00
! Compute the HF individual energy in the unrestricted formalism
2020-03-31 22:15:45 +02:00
implicit none
2021-12-01 10:54:51 +01:00
include 'parameters.h'
2020-03-31 22:15:45 +02:00
! Input variables
integer,intent(in) :: nBas
2021-12-01 10:54:51 +01:00
integer,intent(in) :: nEns
double precision,intent(in) :: Pw(nBas,nBas,nspin)
double precision,intent(in) :: P(nBas,nBas,nspin,nEns)
2020-03-31 22:15:45 +02:00
double precision,intent(in) :: ERI(nBas,nBas,nBas,nBas)
! Local variables
2021-12-01 10:54:51 +01:00
double precision,allocatable :: Fx(:,:,:)
2020-03-31 22:15:45 +02:00
double precision,external :: trace_matrix
2021-12-01 10:54:51 +01:00
integer :: iEns
integer :: ispin
2020-03-31 22:15:45 +02:00
! Output variables
2021-12-01 10:54:51 +01:00
double precision,intent(out) :: LZx(nspin)
double precision,intent(out) :: Ex(nspin,nEns)
2020-03-31 22:15:45 +02:00
! Compute HF exchange matrix
2021-12-01 10:54:51 +01:00
allocate(Fx(nBas,nBas,nspin))
do ispin=1,nspin
2022-01-07 09:13:38 +01:00
call fock_exchange_potential(nBas,Pw(:,:,ispin),ERI,Fx(:,:,ispin))
2021-12-01 10:54:51 +01:00
LZx(ispin) = - 0.5d0*trace_matrix(nBas,matmul(Pw(:,:,ispin),Fx(:,:,ispin)))
do iEns=1,nEns
Ex(ispin,iEns) = - 0.5d0*trace_matrix(nBas,matmul(P(:,:,ispin,iEns),Fx(:,:,ispin)))
end do
2020-03-31 22:15:45 +02:00
2021-12-01 10:54:51 +01:00
end do
2021-11-08 09:55:39 +01:00
2020-03-31 22:15:45 +02:00
2022-01-07 09:13:38 +01:00
end subroutine fock_exchange_individual_energy