mirror of
https://github.com/pfloos/quack
synced 2025-01-05 02:48:57 +01:00
introduce nBas_MOs in RHF_search
This commit is contained in:
parent
56db8456b9
commit
a4eb01b589
@ -1,6 +1,9 @@
|
|||||||
subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rNuc,ENuc, &
|
|
||||||
nBas,nC,nO,nV,nR,S,T,V,Hc,ERI_AO,ERI_MO,dipole_int_AO,dipole_int_MO, &
|
! ---
|
||||||
X,ERHF,e,c,P)
|
|
||||||
|
subroutine RHF_search(maxSCF, thresh, max_diis, guess_type, level_shift, nNuc, ZNuc, rNuc, ENuc, &
|
||||||
|
nBas_AOs, nBas_MOs, nC, nO, nV, nR, S, T, V, Hc, ERI_AO, ERI_MO, dipole_int_AO, dipole_int_MO, &
|
||||||
|
X, ERHF, e, c, P)
|
||||||
|
|
||||||
! Search for RHF solutions
|
! Search for RHF solutions
|
||||||
|
|
||||||
@ -13,7 +16,7 @@ subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rN
|
|||||||
double precision,intent(in) :: thresh
|
double precision,intent(in) :: thresh
|
||||||
double precision,intent(in) :: level_shift
|
double precision,intent(in) :: level_shift
|
||||||
|
|
||||||
integer,intent(in) :: nBas
|
integer,intent(in) :: nBas_AOs, nBas_MOs
|
||||||
integer,intent(in) :: nC
|
integer,intent(in) :: nC
|
||||||
integer,intent(in) :: nO
|
integer,intent(in) :: nO
|
||||||
integer,intent(in) :: nV
|
integer,intent(in) :: nV
|
||||||
@ -22,15 +25,15 @@ subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rN
|
|||||||
double precision,intent(in) :: ZNuc(nNuc)
|
double precision,intent(in) :: ZNuc(nNuc)
|
||||||
double precision,intent(in) :: rNuc(nNuc,ncart)
|
double precision,intent(in) :: rNuc(nNuc,ncart)
|
||||||
double precision,intent(in) :: ENuc
|
double precision,intent(in) :: ENuc
|
||||||
double precision,intent(in) :: S(nBas,nBas)
|
double precision,intent(in) :: S(nBas_AOs,nBas_AOs)
|
||||||
double precision,intent(in) :: T(nBas,nBas)
|
double precision,intent(in) :: T(nBas_AOs,nBas_AOs)
|
||||||
double precision,intent(in) :: V(nBas,nBas)
|
double precision,intent(in) :: V(nBas_AOs,nBas_AOs)
|
||||||
double precision,intent(in) :: Hc(nBas,nBas)
|
double precision,intent(in) :: Hc(nBas_AOs,nBas_AOs)
|
||||||
double precision,intent(in) :: X(nBas,nBas)
|
double precision,intent(in) :: X(nBas_AOs,nBas_MOs)
|
||||||
double precision,intent(in) :: ERI_AO(nBas,nBas,nBas,nBas)
|
double precision,intent(in) :: ERI_AO(nBas_AOs,nBas_AOs,nBas_AOs,nBas_AOs)
|
||||||
double precision,intent(inout):: ERI_MO(nBas,nBas,nBas,nBas)
|
double precision,intent(inout):: ERI_MO(nBas_MOs,nBas_MOs,nBas_MOs,nBas_MOs)
|
||||||
double precision,intent(in) :: dipole_int_AO(nBas,nBas,ncart)
|
double precision,intent(in) :: dipole_int_AO(nBas_AOs,nBas_AOs,ncart)
|
||||||
double precision,intent(inout):: dipole_int_MO(nBas,nBas,ncart)
|
double precision,intent(inout):: dipole_int_MO(nBas_MOs,nBas_MOs,ncart)
|
||||||
|
|
||||||
! Local variables
|
! Local variables
|
||||||
|
|
||||||
@ -59,9 +62,9 @@ subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rN
|
|||||||
! Output variables
|
! Output variables
|
||||||
|
|
||||||
double precision,intent(out) :: ERHF
|
double precision,intent(out) :: ERHF
|
||||||
double precision,intent(out) :: e(nBas)
|
double precision,intent(out) :: e(nBas_MOs)
|
||||||
double precision,intent(inout):: c(nBas,nBas)
|
double precision,intent(inout):: c(nBas_AOs,nBas_MOs)
|
||||||
double precision,intent(out) :: P(nBas,nBas)
|
double precision,intent(out) :: P(nBas_AOs,nBas_AOs)
|
||||||
|
|
||||||
! Memory allocation
|
! Memory allocation
|
||||||
|
|
||||||
@ -76,7 +79,8 @@ 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(Aph(nS,nS),Bph(nS,nS),AB(nS,nS),Om(nS),R(nBas,nBas),ExpR(nBas,nBas))
|
allocate(Aph(nS,nS), Bph(nS,nS), AB(nS,nS), Om(nS))
|
||||||
|
allocate(R(nBas_MOs,nBas_MOs), ExpR(nBas_MOs,nBas_MOs))
|
||||||
|
|
||||||
!------------------!
|
!------------------!
|
||||||
! Search algorithm !
|
! Search algorithm !
|
||||||
@ -92,12 +96,12 @@ subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rN
|
|||||||
!---------------------!
|
!---------------------!
|
||||||
|
|
||||||
call wall_time(start_HF)
|
call wall_time(start_HF)
|
||||||
call RHF(.false.,maxSCF,thresh,max_diis,guess,level_shift,nNuc,ZNuc,rNuc,ENuc, &
|
call RHF(.false., maxSCF, thresh, max_diis, guess, level_shift, nNuc, ZNuc, rNuc, ENuc, &
|
||||||
nBas,nO,S,T,V,Hc,ERI_AO,dipole_int_AO,X,ERHF,e,c,P)
|
nBas_AOs, nBas_MOs, nO, S, T, V, Hc, ERI_AO, dipole_int_AO, X, ERHF, e, c, P)
|
||||||
call wall_time(end_HF)
|
call wall_time(end_HF)
|
||||||
|
|
||||||
t_HF = end_HF - start_HF
|
t_HF = end_HF - start_HF
|
||||||
write(*,'(A65,1X,F9.3,A8)') 'Total CPU time for RHF = ',t_HF,' seconds'
|
write(*,'(A65,1X,F9.3,A8)') 'Total wall time for RHF = ',t_HF,' seconds'
|
||||||
write(*,*)
|
write(*,*)
|
||||||
|
|
||||||
!----------------------------------!
|
!----------------------------------!
|
||||||
@ -108,14 +112,14 @@ subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rN
|
|||||||
write(*,*)
|
write(*,*)
|
||||||
write(*,*) 'AO to MO transformation... Please be patient'
|
write(*,*) 'AO to MO transformation... Please be patient'
|
||||||
write(*,*)
|
write(*,*)
|
||||||
do ixyz=1,ncart
|
do ixyz = 1, ncart
|
||||||
call AOtoMO(nBas,nBas,c,dipole_int_AO(:,:,ixyz),dipole_int_MO(:,:,ixyz))
|
call AOtoMO(nBas_AOs, nBas_MOs, c, dipole_int_AO(1,1,ixyz), dipole_int_MO(1,1,ixyz))
|
||||||
end do
|
end do
|
||||||
call AOtoMO_ERI_RHF(nBas,nBas,c,ERI_AO,ERI_MO)
|
call AOtoMO_ERI_RHF(nBas_AOs, nBas_MOs, c, ERI_AO, ERI_MO)
|
||||||
call wall_time(end_AOtoMO)
|
call wall_time(end_AOtoMO)
|
||||||
|
|
||||||
t_AOtoMO = end_AOtoMO - start_AOtoMO
|
t_AOtoMO = end_AOtoMO - start_AOtoMO
|
||||||
write(*,'(A65,1X,F9.3,A8)') 'Total CPU time for AO to MO transformation = ',t_AOtoMO,' seconds'
|
write(*,'(A65,1X,F9.3,A8)') 'Total wall time for AO to MO transformation = ',t_AOtoMO,' seconds'
|
||||||
write(*,*)
|
write(*,*)
|
||||||
|
|
||||||
!-------------------------------------------------------------!
|
!-------------------------------------------------------------!
|
||||||
@ -124,12 +128,12 @@ subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rN
|
|||||||
|
|
||||||
ispin = 1
|
ispin = 1
|
||||||
|
|
||||||
call phLR_A(ispin,.false.,nBas,nC,nO,nV,nR,nS,1d0,e,ERI_MO,Aph)
|
call phLR_A(ispin,.false.,nBas_MOs,nC,nO,nV,nR,nS,1d0,e,ERI_MO,Aph)
|
||||||
call phLR_B(ispin,.false.,nBas,nC,nO,nV,nR,nS,1d0,ERI_MO,Bph)
|
call phLR_B(ispin,.false.,nBas_MOs,nC,nO,nV,nR,nS,1d0,ERI_MO,Bph)
|
||||||
|
|
||||||
AB(:,:) = Aph(:,:) + Bph(:,:)
|
AB(:,:) = Aph(:,:) + Bph(:,:)
|
||||||
|
|
||||||
call diagonalize_matrix(nS,AB,Om)
|
call diagonalize_matrix(nS, AB, Om)
|
||||||
Om(:) = 2d0*Om(:)
|
Om(:) = 2d0*Om(:)
|
||||||
|
|
||||||
write(*,*)'-------------------------------------------------------------'
|
write(*,*)'-------------------------------------------------------------'
|
||||||
@ -156,6 +160,7 @@ subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rN
|
|||||||
if(eig < 0 .or. eig > nS) then
|
if(eig < 0 .or. eig > nS) then
|
||||||
write(*,'(1X,A40,1X,A10)') 'Invalid option...','Stop...'
|
write(*,'(1X,A40,1X,A10)') 'Invalid option...','Stop...'
|
||||||
write(*,*)
|
write(*,*)
|
||||||
|
deallocate(Aph, Bph, AB, Om, R, ExpR)
|
||||||
stop
|
stop
|
||||||
end if
|
end if
|
||||||
|
|
||||||
@ -164,15 +169,15 @@ subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rN
|
|||||||
R(:,:) = 0d0
|
R(:,:) = 0d0
|
||||||
ia = 0
|
ia = 0
|
||||||
do i=nC+1,nO
|
do i=nC+1,nO
|
||||||
do a=nO+1,nBas-nR
|
do a=nO+1,nBas_MOs-nR
|
||||||
ia = ia + 1
|
ia = ia + 1
|
||||||
R(a,i) = +AB(ia,eig)
|
R(a,i) = +AB(ia,eig)
|
||||||
R(i,a) = -AB(ia,eig)
|
R(i,a) = -AB(ia,eig)
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
call matrix_exponential(nBas,R,ExpR)
|
call matrix_exponential(nBas_MOs, R, ExpR)
|
||||||
c = matmul(c,ExpR)
|
c = matmul(c, ExpR)
|
||||||
|
|
||||||
else
|
else
|
||||||
|
|
||||||
@ -191,4 +196,6 @@ subroutine RHF_search(maxSCF,thresh,max_diis,guess_type,level_shift,nNuc,ZNuc,rN
|
|||||||
!---------------!
|
!---------------!
|
||||||
end do
|
end do
|
||||||
|
|
||||||
|
deallocate(Aph, Bph, AB, Om, R, ExpR)
|
||||||
|
|
||||||
end subroutine
|
end subroutine
|
||||||
|
@ -30,7 +30,7 @@ subroutine RHF_stability(nBas,nC,nO,nV,nR,nS,eHF,ERI)
|
|||||||
|
|
||||||
! Memory allocation
|
! Memory allocation
|
||||||
|
|
||||||
allocate(A(nS,nS),B(nS,nS),AB(nS,nS),Om(nS))
|
allocate(A(nS,nS), B(nS,nS), AB(nS,nS), Om(nS))
|
||||||
|
|
||||||
!-------------------------------------------------------------!
|
!-------------------------------------------------------------!
|
||||||
! Stability analysis: Real RHF -> Real RHF
|
! Stability analysis: Real RHF -> Real RHF
|
||||||
@ -149,4 +149,6 @@ subroutine RHF_stability(nBas,nC,nO,nV,nR,nS,eHF,ERI)
|
|||||||
write(*,*)'-------------------------------------------------------------'
|
write(*,*)'-------------------------------------------------------------'
|
||||||
write(*,*)
|
write(*,*)
|
||||||
|
|
||||||
|
deallocate(A, B, AB, Om)
|
||||||
|
|
||||||
end subroutine
|
end subroutine
|
||||||
|
@ -180,7 +180,7 @@ subroutine RQuAcK(dotest,doRHF,doROHF,dostab,dosearch,doMP2,doMP3,doCCD,dopCCD,d
|
|||||||
if(dostab) then
|
if(dostab) then
|
||||||
|
|
||||||
call wall_time(start_stab)
|
call wall_time(start_stab)
|
||||||
call RHF_stability(nBas_AOs,nC,nO,nV,nR,nS,eHF,ERI_MO)
|
call RHF_stability(nBas_MOs, nC, nO, nV, nR, nS, eHF, ERI_MO)
|
||||||
call wall_time(end_stab)
|
call wall_time(end_stab)
|
||||||
|
|
||||||
t_stab = end_stab - start_stab
|
t_stab = end_stab - start_stab
|
||||||
@ -192,9 +192,9 @@ subroutine RQuAcK(dotest,doRHF,doROHF,dostab,dosearch,doMP2,doMP3,doCCD,dopCCD,d
|
|||||||
if(dosearch) then
|
if(dosearch) then
|
||||||
|
|
||||||
call wall_time(start_stab)
|
call wall_time(start_stab)
|
||||||
! TODO
|
call RHF_search(maxSCF_HF, thresh_HF, max_diis_HF, guess_type, level_shift, nNuc, ZNuc, rNuc, ENuc, &
|
||||||
call RHF_search(maxSCF_HF,thresh_HF,max_diis_HF,guess_type,level_shift,nNuc,ZNuc,rNuc,ENuc, &
|
nBas_AOs, nBas_MOs, nC, nO, nV, nR, S, T, V, Hc, ERI_AO, ERI_MO, dipole_int_AO, &
|
||||||
nBas_AOs,nC,nO,nV,nR,S,T,V,Hc,ERI_AO,ERI_MO,dipole_int_AO,dipole_int_MO,X,ERHF,eHF,cHF,PHF)
|
dipole_int_MO, X, ERHF, eHF, cHF, PHF)
|
||||||
call wall_time(end_stab)
|
call wall_time(end_stab)
|
||||||
|
|
||||||
t_stab = end_stab - start_stab
|
t_stab = end_stab - start_stab
|
||||||
|
@ -65,7 +65,7 @@ subroutine diagonal_matrix(N,D,A)
|
|||||||
end subroutine
|
end subroutine
|
||||||
|
|
||||||
!------------------------------------------------------------------------
|
!------------------------------------------------------------------------
|
||||||
subroutine matrix_exponential(N,A,ExpA)
|
subroutine matrix_exponential(N, A, ExpA)
|
||||||
|
|
||||||
! Compute Exp(A)
|
! Compute Exp(A)
|
||||||
|
|
||||||
@ -81,7 +81,7 @@ subroutine matrix_exponential(N,A,ExpA)
|
|||||||
|
|
||||||
! Memory allocation
|
! Memory allocation
|
||||||
|
|
||||||
allocate(W(N,N),tau(N),t(N,N))
|
allocate(W(N,N), tau(N), t(N,N))
|
||||||
|
|
||||||
! Initialize
|
! Initialize
|
||||||
|
|
||||||
@ -89,8 +89,8 @@ subroutine matrix_exponential(N,A,ExpA)
|
|||||||
|
|
||||||
! Diagonalize
|
! Diagonalize
|
||||||
|
|
||||||
W(:,:) = - matmul(A,A)
|
W(:,:) = - matmul(A, A)
|
||||||
call diagonalize_matrix(N,W,tau)
|
call diagonalize_matrix(N, W, tau)
|
||||||
|
|
||||||
! do i=1,N
|
! do i=1,N
|
||||||
! tau(i) = max(abs(tau(i)),1d-14)
|
! tau(i) = max(abs(tau(i)),1d-14)
|
||||||
@ -99,16 +99,18 @@ subroutine matrix_exponential(N,A,ExpA)
|
|||||||
|
|
||||||
! Construct cos part
|
! Construct cos part
|
||||||
|
|
||||||
call diagonal_matrix(N,cos(tau),t)
|
call diagonal_matrix(N, cos(tau), t)
|
||||||
t(:,:) = matmul(t,transpose(W))
|
t(:,:) = matmul(t, transpose(W))
|
||||||
ExpA(:,:) = ExpA(:,:) + matmul(W,t)
|
ExpA(:,:) = ExpA(:,:) + matmul(W, t)
|
||||||
|
|
||||||
! Construct sin part
|
! Construct sin part
|
||||||
|
|
||||||
call diagonal_matrix(N,sin(tau)/tau,t)
|
call diagonal_matrix(N, sin(tau)/tau, t)
|
||||||
t(:,:) = matmul(t,transpose(W))
|
t(:,:) = matmul(t, transpose(W))
|
||||||
t(:,:) = matmul(t,A)
|
t(:,:) = matmul(t, A)
|
||||||
ExpA(:,:) = ExpA(:,:) + matmul(W,t)
|
ExpA(:,:) = ExpA(:,:) + matmul(W, t)
|
||||||
|
|
||||||
|
deallocate(W, tau, t)
|
||||||
|
|
||||||
end subroutine
|
end subroutine
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user