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
|