4
1
mirror of https://github.com/pfloos/quack synced 2024-06-22 21:22:20 +02:00
quack/src/HF/huckel_guess.f90

48 lines
814 B
Fortran
Raw Normal View History

2022-02-02 15:06:51 +01:00
subroutine huckel_guess(nBas,S,Hc,X,c)
2019-10-05 22:06:25 +02:00
2022-02-02 15:06:51 +01:00
! Hickel guess
2019-10-05 22:06:25 +02:00
implicit none
! Input variables
integer,intent(in) :: nBas
double precision,intent(in) :: S(nBas,nBas)
double precision,intent(in) :: Hc(nBas,nBas)
double precision,intent(in) :: X(nBas,nBas)
! Local variables
integer :: mu,nu
double precision :: a
2022-02-02 15:06:51 +01:00
double precision,allocatable :: F(:,:)
2019-10-05 22:06:25 +02:00
! Output variables
double precision,intent(out) :: c(nBas,nBas)
2022-02-02 15:06:51 +01:00
! Memory allocation
2019-10-05 22:06:25 +02:00
2022-02-02 15:06:51 +01:00
allocate(F(nBas,nBas))
2020-01-17 17:35:40 +01:00
2022-02-02 15:06:51 +01:00
! Extended Huckel parameter
a = 1.75d0
2020-01-17 17:35:40 +01:00
2022-02-02 15:06:51 +01:00
! GWH approximation
2020-01-15 09:22:54 +01:00
do mu=1,nBas
2022-02-02 15:06:51 +01:00
F(mu,mu) = Hc(mu,mu)
2020-01-15 09:22:54 +01:00
do nu=mu+1,nBas
2020-01-15 22:29:43 +01:00
F(mu,nu) = 0.5d0*a*S(mu,nu)*(Hc(mu,mu) + Hc(nu,nu))
F(nu,mu) = F(mu,nu)
2020-01-15 09:22:54 +01:00
enddo
enddo
2022-02-02 15:06:51 +01:00
call core_guess(nBas,F,X,c)
2019-10-05 22:06:25 +02:00
end subroutine