From 9b32dbd749ac9402c16ba1a8945b3f2f71c1e79f Mon Sep 17 00:00:00 2001 From: pfloos Date: Wed, 30 Oct 2024 09:28:39 +0100 Subject: [PATCH] fix stupid bug in UGW static kernel --- src/GW/UGW_phBSE.f90 | 7 ++++--- src/GW/UGW_phBSE_static_kernel_A.f90 | 2 ++ src/GW/UGW_phBSE_static_kernel_B.f90 | 2 ++ src/HF/print_UHF.f90 | 15 --------------- 4 files changed, 8 insertions(+), 18 deletions(-) diff --git a/src/GW/UGW_phBSE.f90 b/src/GW/UGW_phBSE.f90 index 1bf4cdc..e876484 100644 --- a/src/GW/UGW_phBSE.f90 +++ b/src/GW/UGW_phBSE.f90 @@ -117,11 +117,11 @@ subroutine UGW_phBSE(exchange_kernel,TDA_W,TDA,dBSE,dTDA,spin_conserved,spin_fli call phULR_A(ispin,dRPA,nBas,nC,nO,nV,nR,nS_aa,nS_bb,nS_sc,1d0,eGW,ERI_aaaa,ERI_aabb,ERI_bbbb,Aph) if(.not.TDA) call phULR_B(ispin,dRPA,nBas,nC,nO,nV,nR,nS_aa,nS_bb,nS_sc,1d0,ERI_aaaa,ERI_aabb,ERI_bbbb,Bph) - call UGW_phBSE_static_kernel_A(ispin,eta,nBas,nC,nO,nV,nR,nS_aa,nS_bb,nS_sc,nS_sc,1d0,OmRPA,rho_RPA,KA) + call UGW_phBSE_static_kernel_A(ispin,eta,nBas,nC,nO,nV,nR,nS_aa,nS_bb,nS_sc,nS_sc,1d0,OmRPA,rho_RPA,KA) if(.not.TDA) call UGW_phBSE_static_kernel_B(ispin,eta,nBas,nC,nO,nV,nR,nS_aa,nS_bb,nS_sc,nS_sc,1d0,OmRPA,rho_RPA,KB) Aph(:,:) = Aph(:,:) + KA(:,:) -! if(.not.TDA) Bph(:,:) = Bph(:,:) + KB(:,:) + if(.not.TDA) Bph(:,:) = Bph(:,:) + KB(:,:) call phULR(TDA,nS_aa,nS_bb,nS_sc,Aph,Bph,EcBSE(ispin),OmBSE,XpY_BSE,XmY_BSE) @@ -155,10 +155,11 @@ subroutine UGW_phBSE(exchange_kernel,TDA_W,TDA,dBSE,dTDA,spin_conserved,spin_fli allocate(OmBSE(nS_sf),XpY_BSE(nS_sf,nS_sf),XmY_BSE(nS_sf,nS_sf)) ! Compute spin-conserved BSE excitation energies + call phULR_A(ispin,dRPA,nBas,nC,nO,nV,nR,nS_aa,nS_bb,nS_sf,1d0,eGW,ERI_aaaa,ERI_aabb,ERI_bbbb,Aph) if(.not.TDA) call phULR_B(ispin,dRPA,nBas,nC,nO,nV,nR,nS_aa,nS_bb,nS_sf,1d0,ERI_aaaa,ERI_aabb,ERI_bbbb,Bph) - call UGW_phBSE_static_kernel_A(ispin,eta,nBas,nC,nO,nV,nR,nS_aa,nS_bb,nS_sc,nS_sf,1d0,OmRPA,rho_RPA,KA) + call UGW_phBSE_static_kernel_A(ispin,eta,nBas,nC,nO,nV,nR,nS_aa,nS_bb,nS_sc,nS_sf,1d0,OmRPA,rho_RPA,KA) if(.not.TDA) call UGW_phBSE_static_kernel_B(ispin,eta,nBas,nC,nO,nV,nR,nS_aa,nS_bb,nS_sc,nS_sf,1d0,OmRPA,rho_RPA,KB) Aph(:,:) = Aph(:,:) + KA(:,:) diff --git a/src/GW/UGW_phBSE_static_kernel_A.f90 b/src/GW/UGW_phBSE_static_kernel_A.f90 index ef08ef3..71eb7cf 100644 --- a/src/GW/UGW_phBSE_static_kernel_A.f90 +++ b/src/GW/UGW_phBSE_static_kernel_A.f90 @@ -36,6 +36,8 @@ subroutine UGW_phBSE_static_kernel_A(ispin,eta,nBas,nC,nO,nV,nR,nSa,nSb,nSt,nS_s ! Build BSE matrix for spin-conserving transitions ! !--------------------------------------------------! + KA(:,:) = 0d0 + if(ispin == 1) then ! aaaa block diff --git a/src/GW/UGW_phBSE_static_kernel_B.f90 b/src/GW/UGW_phBSE_static_kernel_B.f90 index c374bf2..9d63068 100644 --- a/src/GW/UGW_phBSE_static_kernel_B.f90 +++ b/src/GW/UGW_phBSE_static_kernel_B.f90 @@ -36,6 +36,8 @@ subroutine UGW_phBSE_static_kernel_B(ispin,eta,nBas,nC,nO,nV,nR,nSa,nSb,nSt,nS_s ! Build BSE matrix for spin-conserving transitions ! !--------------------------------------------------! + KB(:,:) = 0d0 + if(ispin == 1) then ! aaaa block diff --git a/src/HF/print_UHF.f90 b/src/HF/print_UHF.f90 index 70dc834..82e744c 100644 --- a/src/HF/print_UHF.f90 +++ b/src/HF/print_UHF.f90 @@ -31,7 +31,6 @@ subroutine print_UHF(nBas,nO,S,eHF,c,P,ENuc,ET,EV,EJ,Ex,EUHF,dipole) double precision :: Sz double precision :: Sx2,Sy2,Sz2 integer :: mu,nu - double precision,allocatable :: qa(:),qb(:) logical :: dump_orb = .false. @@ -119,18 +118,4 @@ subroutine print_UHF(nBas,nO,S,eHF,c,P,ENuc,ET,EV,EJ,Ex,EUHF,dipole) call vecout(nBas,eHF(:,2)) write(*,*) - allocate(qa(nBas),qb(nBas)) - - qa(:) = 0d0 - qb(:) = 0d0 - do mu=1,nBas - do nu=1,nBas - qa(mu) = qa(mu) + P(mu,nu,1)*S(nu,mu) - qb(mu) = qb(mu) + P(mu,nu,2)*S(nu,mu) - end do - end do - - call vecout(nBas,qa) - call vecout(nBas,qb) - end subroutine