10
1
mirror of https://github.com/pfloos/quack synced 2025-01-05 02:48:48 +01:00

RHF earch seems to work

This commit is contained in:
Pierre-Francois Loos 2023-11-04 12:02:38 +01:00
parent 3b958f5610
commit 67abf13740
3 changed files with 18 additions and 33 deletions

View File

@ -13,6 +13,6 @@
# G0F2 evGF2 qsGF2 G0F3 evGF3 # G0F2 evGF2 qsGF2 G0F3 evGF3
F F F F F F F F F F
# G0W0 evGW qsGW SRG-qsGW ufG0W0 ufGW # G0W0 evGW qsGW SRG-qsGW ufG0W0 ufGW
T F F F F F F F F F F F
# G0T0pp evGTpp qsGTpp G0T0eh evGTeh qsGTeh # G0T0pp evGTpp qsGTpp G0T0eh evGTeh qsGTeh
F F F F F F F F F F F F

View File

@ -1,5 +1,5 @@
# HF: maxSCF thresh DIIS guess mix_guess level_shift stab search # HF: maxSCF thresh DIIS guess mix shift stab search
1000 0.00001 5 1 0.0 0.0 T T 1000 0.0000001 5 1 0.0 0.0 F T
# MP: reg # MP: reg
F F
# CC: maxSCF thresh DIIS # CC: maxSCF thresh DIIS

View File

@ -41,7 +41,7 @@ subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rN
integer :: nS integer :: nS
integer,parameter :: maxS = 20 integer,parameter :: maxS = 20
integer :: ia,i,a integer :: ia,i,a,mu
integer :: ispin integer :: ispin
double precision,allocatable :: Aph(:,:) double precision,allocatable :: Aph(:,:)
@ -51,8 +51,7 @@ subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rN
double precision,allocatable :: R(:,:) double precision,allocatable :: R(:,:)
integer :: eig integer :: eig
double precision :: eigval double precision :: kick,step
double precision,allocatable :: eigvec(:)
! Output variables ! Output variables
@ -74,8 +73,7 @@ subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rN
!-------------------! !-------------------!
nS = (nO - nC)*(nV - nR) nS = (nO - nC)*(nV - nR)
allocate(ERI_MO(nBas,nBas,nBas,nBas),eigvec(nS)) allocate(ERI_MO(nBas,nBas,nBas,nBas),Aph(nS,nS),Bph(nS,nS),AB(nS,nS),Om(nS),R(nBas,nBas))
allocate(Aph(nS,nS),Bph(nS,nS),AB(nS,nS),Om(nS),R(nBas,nBas))
!------------------! !------------------!
! Search algorithm ! ! Search algorithm !
@ -148,33 +146,20 @@ subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rN
write(*,'(1X,A40,1X)') 'Which one would you like to follow?' write(*,'(1X,A40,1X)') 'Which one would you like to follow?'
read(*,*) eig read(*,*) eig
eigval = Om(eig) step = 1d0
eigvec(:) = AB(:,eig)
print*,eigval do mu=1,nBas
call matout(nS,1,eigvec)
R(:,:) = 0d0
ia = 0 ia = 0
do i=nC+1,nO do i=nC+1,nO
kick = 0d0
do a=nO+1,nBas-nR do a=nO+1,nBas-nR
ia = ia + 1 ia = ia + 1
R(i,a) = +eigvec(ia) kick = kick + AB(ia,eig)*c(mu,a)
R(a,i) = -eigvec(ia) end do
c(mu,i) = c(mu,i) + step*kick
end do end do
end do end do
print*,'rotation matrix'
call matout(nBas,nBas,R)
print*,'old coefficients'
call matout(nBas,nBas,c)
c = c - 0.1d0*matmul(c,R)
print*,'new coefficients'
call matout(nBas,nBas,c)
else else
write(*,'(1X,A40,1X)') 'Well done, RHF solution is stable!' write(*,'(1X,A40,1X)') 'Well done, RHF solution is stable!'