mirror of
https://github.com/pfloos/quack
synced 2025-01-13 22:36:04 +01:00
reversing loops in HF
This commit is contained in:
parent
b450829846
commit
e41097e8c2
@ -126,11 +126,11 @@ subroutine CCGW(maxSCF,thresh,nBas,nC,nO,nV,nR,ERI,ENuc,ERHF,e)
|
|||||||
|
|
||||||
do while(Conv > thresh .and. nSCF < maxSCF)
|
do while(Conv > thresh .and. nSCF < maxSCF)
|
||||||
|
|
||||||
! Increment
|
! Increment
|
||||||
|
|
||||||
nSCF = nSCF + 1
|
nSCF = nSCF + 1
|
||||||
|
|
||||||
! Compute energy differences
|
! Compute energy differences
|
||||||
|
|
||||||
do i=nC+1,nO
|
do i=nC+1,nO
|
||||||
do j=nC+1,nO
|
do j=nC+1,nO
|
||||||
@ -156,7 +156,7 @@ subroutine CCGW(maxSCF,thresh,nBas,nC,nO,nV,nR,ERI,ENuc,ERHF,e)
|
|||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
! Compute intermediates
|
! Compute intermediates
|
||||||
|
|
||||||
x_2h1p(:,:) = 0d0
|
x_2h1p(:,:) = 0d0
|
||||||
|
|
||||||
@ -194,7 +194,7 @@ subroutine CCGW(maxSCF,thresh,nBas,nC,nO,nV,nR,ERI,ENuc,ERHF,e)
|
|||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
! Compute residual for 2h1p sector
|
! Compute residual for 2h1p sector
|
||||||
|
|
||||||
do i=nC+1,nO
|
do i=nC+1,nO
|
||||||
do j=nC+1,nO
|
do j=nC+1,nO
|
||||||
@ -224,7 +224,7 @@ subroutine CCGW(maxSCF,thresh,nBas,nC,nO,nV,nR,ERI,ENuc,ERHF,e)
|
|||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
! Compute residual for 2p1h sector
|
! Compute residual for 2p1h sector
|
||||||
|
|
||||||
do i=nC+1,nO
|
do i=nC+1,nO
|
||||||
do a=1,nV-nR
|
do a=1,nV-nR
|
||||||
@ -254,16 +254,16 @@ subroutine CCGW(maxSCF,thresh,nBas,nC,nO,nV,nR,ERI,ENuc,ERHF,e)
|
|||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
! Check convergence
|
! Check convergence
|
||||||
|
|
||||||
Conv = max(maxval(abs(r_2h1p)),maxval(abs(r_2p1h)))
|
Conv = max(maxval(abs(r_2h1p)),maxval(abs(r_2p1h)))
|
||||||
|
|
||||||
! Update amplitudes
|
! Update amplitudes
|
||||||
|
|
||||||
t_2h1p(:,:,:,:) = t_2h1p(:,:,:,:) - r_2h1p(:,:,:,:)/delta_2h1p(:,:,:,:)
|
t_2h1p(:,:,:,:) = t_2h1p(:,:,:,:) - r_2h1p(:,:,:,:)/delta_2h1p(:,:,:,:)
|
||||||
t_2p1h(:,:,:,:) = t_2p1h(:,:,:,:) - r_2p1h(:,:,:,:)/delta_2p1h(:,:,:,:)
|
t_2p1h(:,:,:,:) = t_2p1h(:,:,:,:) - r_2p1h(:,:,:,:)/delta_2p1h(:,:,:,:)
|
||||||
|
|
||||||
! Compute correlation energy
|
! Compute self-energy
|
||||||
|
|
||||||
SigGW(:,:) = 0d0
|
SigGW(:,:) = 0d0
|
||||||
|
|
||||||
@ -296,7 +296,7 @@ subroutine CCGW(maxSCF,thresh,nBas,nC,nO,nV,nR,ERI,ENuc,ERHF,e)
|
|||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
! Diagonalize non-Hermitian matrix
|
! Diagonalize non-Hermitian matrix
|
||||||
|
|
||||||
call diagonalize_general_matrix(nBas,SigGW,eGW,cGW)
|
call diagonalize_general_matrix(nBas,SigGW,eGW,cGW)
|
||||||
|
|
||||||
@ -307,11 +307,11 @@ subroutine CCGW(maxSCF,thresh,nBas,nC,nO,nV,nR,ERI,ENuc,ERHF,e)
|
|||||||
call quick_sort(eGW,order,nBas)
|
call quick_sort(eGW,order,nBas)
|
||||||
call set_order(cGW,order,nBas,nBas)
|
call set_order(cGW,order,nBas,nBas)
|
||||||
|
|
||||||
! Renormalization factor
|
! Renormalization factor
|
||||||
|
|
||||||
Z(:) = 1d0
|
Z(:) = 1d0
|
||||||
|
|
||||||
! Dump results
|
! Dump results
|
||||||
|
|
||||||
write(*,'(1X,A1,1X,I3,1X,A1,1X,F10.6,1X,A1,1X,F10.6,1X,A1,1X,F10.6,1X,A1,1X)') &
|
write(*,'(1X,A1,1X,I3,1X,A1,1X,F10.6,1X,A1,1X,F10.6,1X,A1,1X,F10.6,1X,A1,1X)') &
|
||||||
'|',nSCF,'|',eGW(nO)*HaToeV,'|',eGW(nO+1)*HaToeV,'|',Conv,'|'
|
'|',nSCF,'|',eGW(nO)*HaToeV,'|',eGW(nO+1)*HaToeV,'|',Conv,'|'
|
||||||
|
@ -19,9 +19,9 @@ subroutine density_matrix(nBas,ON,c,P)
|
|||||||
|
|
||||||
P(:,:) = 0d0
|
P(:,:) = 0d0
|
||||||
|
|
||||||
do mu=1,nBas
|
do i=1,nBas
|
||||||
do nu=1,nBas
|
do nu=1,nBas
|
||||||
do i=1,nBas
|
do mu=1,nBas
|
||||||
P(mu,nu) = P(mu,nu) + 2d0*ON(i)*c(mu,i)*c(nu,i)
|
P(mu,nu) = P(mu,nu) + 2d0*ON(i)*c(mu,i)*c(nu,i)
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
@ -42,8 +42,8 @@ subroutine dipole_moment(nBas,P,nNuc,ZNuc,rNuc,dipole_int,dipole)
|
|||||||
|
|
||||||
! Electronic part
|
! Electronic part
|
||||||
|
|
||||||
do mu=1,nBas
|
do nu=1,nBas
|
||||||
do nu=1,nBas
|
do mu=1,nBas
|
||||||
dipole(ixyz) = dipole(ixyz) - P(mu,nu)*dipole_int(mu,nu,ixyz)
|
dipole(ixyz) = dipole(ixyz) - P(mu,nu)*dipole_int(mu,nu,ixyz)
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
Loading…
x
Reference in New Issue
Block a user