mirror of
https://github.com/pfloos/quack
synced 2025-01-10 13:08:19 +01:00
working on structure eDFT code
This commit is contained in:
parent
0271024041
commit
05acc90332
@ -32,10 +32,6 @@ subroutine select_rung(rung,DFA)
|
|||||||
case(4)
|
case(4)
|
||||||
write(*,*) "* 4th rung of Jacob's ladder: hybrid functional *"
|
write(*,*) "* 4th rung of Jacob's ladder: hybrid functional *"
|
||||||
|
|
||||||
! Hartree-Fock calculation
|
|
||||||
case(666)
|
|
||||||
write(*,*) "* rung 666: Hartree-Fock calculation *"
|
|
||||||
|
|
||||||
! Default
|
! Default
|
||||||
case default
|
case default
|
||||||
write(*,*) "!!! rung not available !!!"
|
write(*,*) "!!! rung not available !!!"
|
||||||
|
@ -45,6 +45,13 @@ subroutine unrestricted_correlation_derivative_discontinuity(rung,DFA,nEns,wEns,
|
|||||||
call print_warning('!!! derivative discontinuity NYI for GGAs !!!')
|
call print_warning('!!! derivative discontinuity NYI for GGAs !!!')
|
||||||
stop
|
stop
|
||||||
|
|
||||||
|
! MGGA functionals
|
||||||
|
|
||||||
|
case(3)
|
||||||
|
|
||||||
|
call print_warning('!!! derivative discontinuity NYI for MGGAs !!!')
|
||||||
|
stop
|
||||||
|
|
||||||
! Hybrid functionals
|
! Hybrid functionals
|
||||||
|
|
||||||
case(4)
|
case(4)
|
||||||
@ -54,12 +61,6 @@ subroutine unrestricted_correlation_derivative_discontinuity(rung,DFA,nEns,wEns,
|
|||||||
|
|
||||||
aC = 0.81d0
|
aC = 0.81d0
|
||||||
|
|
||||||
! Hartree-Fock calculation
|
|
||||||
|
|
||||||
case(666)
|
|
||||||
|
|
||||||
Ec(:,:) = 0d0
|
|
||||||
|
|
||||||
end select
|
end select
|
||||||
|
|
||||||
end subroutine unrestricted_correlation_derivative_discontinuity
|
end subroutine unrestricted_correlation_derivative_discontinuity
|
||||||
|
@ -46,6 +46,12 @@ subroutine unrestricted_correlation_energy(rung,DFA,nEns,wEns,nGrid,weight,rho,d
|
|||||||
|
|
||||||
call unrestricted_gga_correlation_energy(DFA,nEns,wEns,nGrid,weight,rho,drho,Ec)
|
call unrestricted_gga_correlation_energy(DFA,nEns,wEns,nGrid,weight,rho,drho,Ec)
|
||||||
|
|
||||||
|
! MGGA functionals
|
||||||
|
|
||||||
|
case(3)
|
||||||
|
|
||||||
|
call unrestricted_mgga_correlation_energy(DFA,nEns,wEns,nGrid,weight,rho,drho,Ec)
|
||||||
|
|
||||||
! Hybrid functionals
|
! Hybrid functionals
|
||||||
|
|
||||||
case(4)
|
case(4)
|
||||||
@ -57,12 +63,6 @@ subroutine unrestricted_correlation_energy(rung,DFA,nEns,wEns,nGrid,weight,rho,d
|
|||||||
|
|
||||||
Ec(:) = EcLDA(:) + aC*(EcGGA(:) - EcLDA(:))
|
Ec(:) = EcLDA(:) + aC*(EcGGA(:) - EcLDA(:))
|
||||||
|
|
||||||
! Hartree-Fock calculation
|
|
||||||
|
|
||||||
case(666)
|
|
||||||
|
|
||||||
Ec(:) = 0d0
|
|
||||||
|
|
||||||
end select
|
end select
|
||||||
|
|
||||||
end subroutine unrestricted_correlation_energy
|
end subroutine unrestricted_correlation_energy
|
||||||
|
@ -50,6 +50,13 @@ subroutine unrestricted_correlation_individual_energy(rung,DFA,LDA_centered,nEns
|
|||||||
call print_warning('!!! Individual energies NYI for GGAs !!!')
|
call print_warning('!!! Individual energies NYI for GGAs !!!')
|
||||||
stop
|
stop
|
||||||
|
|
||||||
|
! MGGA functionals
|
||||||
|
|
||||||
|
case(3)
|
||||||
|
|
||||||
|
call print_warning('!!! Individual energies NYI for MGGAs !!!')
|
||||||
|
stop
|
||||||
|
|
||||||
! Hybrid functionals
|
! Hybrid functionals
|
||||||
|
|
||||||
case(4)
|
case(4)
|
||||||
@ -59,12 +66,6 @@ subroutine unrestricted_correlation_individual_energy(rung,DFA,LDA_centered,nEns
|
|||||||
|
|
||||||
aC = 0.81d0
|
aC = 0.81d0
|
||||||
|
|
||||||
! Hartree-Fock calculation
|
|
||||||
|
|
||||||
case(666)
|
|
||||||
|
|
||||||
Ec(:) = 0d0
|
|
||||||
|
|
||||||
end select
|
end select
|
||||||
|
|
||||||
end subroutine unrestricted_correlation_individual_energy
|
end subroutine unrestricted_correlation_individual_energy
|
||||||
|
@ -51,6 +51,12 @@ subroutine unrestricted_correlation_potential(rung,DFA,nEns,wEns,nGrid,weight,nB
|
|||||||
|
|
||||||
call unrestricted_gga_correlation_potential(DFA,nEns,wEns,nGrid,weight,nBas,AO,dAO,rho,drho,Fc)
|
call unrestricted_gga_correlation_potential(DFA,nEns,wEns,nGrid,weight,nBas,AO,dAO,rho,drho,Fc)
|
||||||
|
|
||||||
|
! MGGA functionals
|
||||||
|
|
||||||
|
case(3)
|
||||||
|
|
||||||
|
call unrestricted_mgga_correlation_potential(DFA,nEns,wEns,nGrid,weight,nBas,AO,dAO,rho,drho,Fc)
|
||||||
|
|
||||||
! Hybrid functionals
|
! Hybrid functionals
|
||||||
|
|
||||||
case(4)
|
case(4)
|
||||||
@ -64,12 +70,6 @@ subroutine unrestricted_correlation_potential(rung,DFA,nEns,wEns,nGrid,weight,nB
|
|||||||
|
|
||||||
Fc(:,:,:) = FcLDA(:,:,:) + aC*(FcGGA(:,:,:) - FcLDA(:,:,:))
|
Fc(:,:,:) = FcLDA(:,:,:) + aC*(FcGGA(:,:,:) - FcLDA(:,:,:))
|
||||||
|
|
||||||
! Hartree-Fock calculation
|
|
||||||
|
|
||||||
case(666)
|
|
||||||
|
|
||||||
Fc(:,:,:) = 0d0
|
|
||||||
|
|
||||||
end select
|
end select
|
||||||
|
|
||||||
end subroutine unrestricted_correlation_potential
|
end subroutine unrestricted_correlation_potential
|
||||||
|
@ -43,13 +43,18 @@ subroutine unrestricted_exchange_derivative_discontinuity(rung,DFA,nEns,wEns,aCC
|
|||||||
|
|
||||||
call unrestricted_lda_exchange_derivative_discontinuity(DFA,nEns,wEns(:),aCC_w1,aCC_w2,nGrid,weight(:),&
|
call unrestricted_lda_exchange_derivative_discontinuity(DFA,nEns,wEns(:),aCC_w1,aCC_w2,nGrid,weight(:),&
|
||||||
rhow(:),Cx_choice,doNcentered,kappa,ExDD(:))
|
rhow(:),Cx_choice,doNcentered,kappa,ExDD(:))
|
||||||
|
|
||||||
! GGA functionals
|
! GGA functionals
|
||||||
|
|
||||||
case(2)
|
case(2)
|
||||||
|
|
||||||
call unrestricted_gga_exchange_derivative_discontinuity(DFA,nEns,wEns(:),nGrid,weight(:),rhow(:),drhow(:,:),ExDD(:))
|
call unrestricted_gga_exchange_derivative_discontinuity(DFA,nEns,wEns(:),nGrid,weight(:),rhow(:),drhow(:,:),ExDD(:))
|
||||||
|
|
||||||
|
! MGGA functionals
|
||||||
|
|
||||||
|
case(3)
|
||||||
|
|
||||||
|
call unrestricted_mgga_exchange_derivative_discontinuity(DFA,nEns,wEns(:),nGrid,weight(:),rhow(:),drhow(:,:),ExDD(:))
|
||||||
|
|
||||||
! Hybrid functionals
|
! Hybrid functionals
|
||||||
|
|
||||||
case(4)
|
case(4)
|
||||||
@ -57,12 +62,6 @@ subroutine unrestricted_exchange_derivative_discontinuity(rung,DFA,nEns,wEns,aCC
|
|||||||
call print_warning('!!! exchange part of derivative discontinuity NYI for hybrids !!!')
|
call print_warning('!!! exchange part of derivative discontinuity NYI for hybrids !!!')
|
||||||
stop
|
stop
|
||||||
|
|
||||||
! Hartree-Fock calculation
|
|
||||||
|
|
||||||
case(666)
|
|
||||||
|
|
||||||
ExDD(:) = 0d0
|
|
||||||
|
|
||||||
end select
|
end select
|
||||||
|
|
||||||
end subroutine unrestricted_exchange_derivative_discontinuity
|
end subroutine unrestricted_exchange_derivative_discontinuity
|
||||||
|
@ -82,14 +82,6 @@ subroutine unrestricted_exchange_energy(rung,DFA,LDA_centered,nEns,wEns,aCC_w1,a
|
|||||||
+ cX*(ExHF - ExLDA) &
|
+ cX*(ExHF - ExLDA) &
|
||||||
+ aX*(ExGGA - ExLDA)
|
+ aX*(ExGGA - ExLDA)
|
||||||
|
|
||||||
! Hartree-Fock calculation
|
|
||||||
|
|
||||||
case(666)
|
|
||||||
|
|
||||||
call unrestricted_fock_exchange_energy(nBas,P,FxHF,ExHF)
|
|
||||||
|
|
||||||
Ex = ExHF
|
|
||||||
|
|
||||||
end select
|
end select
|
||||||
|
|
||||||
end subroutine unrestricted_exchange_energy
|
end subroutine unrestricted_exchange_energy
|
||||||
|
@ -33,6 +33,7 @@ subroutine unrestricted_exchange_individual_energy(rung,DFA,LDA_centered,nEns,wE
|
|||||||
|
|
||||||
double precision :: ExLDA
|
double precision :: ExLDA
|
||||||
double precision :: ExGGA
|
double precision :: ExGGA
|
||||||
|
double precision :: ExMGGA
|
||||||
double precision :: ExHF
|
double precision :: ExHF
|
||||||
|
|
||||||
! Output variables
|
! Output variables
|
||||||
@ -64,6 +65,14 @@ subroutine unrestricted_exchange_individual_energy(rung,DFA,LDA_centered,nEns,wE
|
|||||||
|
|
||||||
Ex = ExGGA
|
Ex = ExGGA
|
||||||
|
|
||||||
|
! MGGA functionals
|
||||||
|
|
||||||
|
case(3)
|
||||||
|
|
||||||
|
call unrestricted_mgga_exchange_individual_energy(DFA,nEns,wEns,nGrid,weight,rhow,drhow,rho,drho,ExMGGA)
|
||||||
|
|
||||||
|
Ex = ExMGGA
|
||||||
|
|
||||||
! Hybrid functionals
|
! Hybrid functionals
|
||||||
|
|
||||||
case(4)
|
case(4)
|
||||||
@ -71,14 +80,6 @@ subroutine unrestricted_exchange_individual_energy(rung,DFA,LDA_centered,nEns,wE
|
|||||||
call print_warning('!!! Individual energies NYI for Hybrids !!!')
|
call print_warning('!!! Individual energies NYI for Hybrids !!!')
|
||||||
stop
|
stop
|
||||||
|
|
||||||
! Hartree-Fock calculation
|
|
||||||
|
|
||||||
case(666)
|
|
||||||
|
|
||||||
call unrestricted_fock_exchange_individual_energy(nBas,Pw,P,ERI,ExHF)
|
|
||||||
|
|
||||||
Ex = ExHF
|
|
||||||
|
|
||||||
end select
|
end select
|
||||||
|
|
||||||
end subroutine unrestricted_exchange_individual_energy
|
end subroutine unrestricted_exchange_individual_energy
|
||||||
|
@ -57,6 +57,12 @@ subroutine unrestricted_exchange_potential(rung,DFA,LDA_centered,nEns,wEns,aCC_w
|
|||||||
|
|
||||||
call unrestricted_gga_exchange_potential(DFA,nEns,wEns,nGrid,weight,nBas,AO,dAO,rho,drho,Fx)
|
call unrestricted_gga_exchange_potential(DFA,nEns,wEns,nGrid,weight,nBas,AO,dAO,rho,drho,Fx)
|
||||||
|
|
||||||
|
! MGGA functionals
|
||||||
|
|
||||||
|
case(3)
|
||||||
|
|
||||||
|
call unrestricted_mgga_exchange_potential(DFA,nEns,wEns,nGrid,weight,nBas,AO,dAO,rho,drho,Fx)
|
||||||
|
|
||||||
! Hybrid functionals
|
! Hybrid functionals
|
||||||
|
|
||||||
case(4)
|
case(4)
|
||||||
@ -74,14 +80,6 @@ subroutine unrestricted_exchange_potential(rung,DFA,LDA_centered,nEns,wEns,aCC_w
|
|||||||
+ cX*(FxHF(:,:) - FxLDA(:,:)) &
|
+ cX*(FxHF(:,:) - FxLDA(:,:)) &
|
||||||
+ aX*(FxGGA(:,:) - FxLDA(:,:))
|
+ aX*(FxGGA(:,:) - FxLDA(:,:))
|
||||||
|
|
||||||
! Hartree-Fock calculation
|
|
||||||
|
|
||||||
case(666)
|
|
||||||
|
|
||||||
call unrestricted_fock_exchange_potential(nBas,P,ERI,FxHF)
|
|
||||||
|
|
||||||
Fx(:,:) = FxHF(:,:)
|
|
||||||
|
|
||||||
end select
|
end select
|
||||||
|
|
||||||
end subroutine unrestricted_exchange_potential
|
end subroutine unrestricted_exchange_potential
|
||||||
|
38
src/eDFT/unrestricted_mgga_correlation_potential.f90
Normal file
38
src/eDFT/unrestricted_mgga_correlation_potential.f90
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
subroutine unrestricted_mgga_correlation_potential(DFA,nEns,wEns,nGrid,weight,nBas,AO,dAO,rho,drho,Fc)
|
||||||
|
|
||||||
|
! Compute unrestricted MGGA correlation potential
|
||||||
|
|
||||||
|
implicit none
|
||||||
|
include 'parameters.h'
|
||||||
|
|
||||||
|
! Input variables
|
||||||
|
|
||||||
|
character(len=12),intent(in) :: DFA
|
||||||
|
integer,intent(in) :: nEns
|
||||||
|
double precision,intent(in) :: wEns(nEns)
|
||||||
|
integer,intent(in) :: nGrid
|
||||||
|
double precision,intent(in) :: weight(nGrid)
|
||||||
|
integer,intent(in) :: nBas
|
||||||
|
double precision,intent(in) :: AO(nBas,nGrid)
|
||||||
|
double precision,intent(in) :: dAO(3,nBas,nGrid)
|
||||||
|
double precision,intent(in) :: rho(nGrid,nspin)
|
||||||
|
double precision,intent(in) :: drho(3,nGrid,nspin)
|
||||||
|
|
||||||
|
! Local variables
|
||||||
|
|
||||||
|
! Output variables
|
||||||
|
|
||||||
|
double precision,intent(out) :: Fc(nBas,nBas,nspin)
|
||||||
|
|
||||||
|
! Select MGGA exchange functional
|
||||||
|
|
||||||
|
select case (DFA)
|
||||||
|
|
||||||
|
case default
|
||||||
|
|
||||||
|
call print_warning('!!! MGGA correlation potential not available !!!')
|
||||||
|
stop
|
||||||
|
|
||||||
|
end select
|
||||||
|
|
||||||
|
end subroutine unrestricted_mgga_correlation_potential
|
@ -0,0 +1,36 @@
|
|||||||
|
subroutine unrestricted_mgga_exchange_derivative_discontinuity(DFA,nEns,wEns,nGrid,weight,rhow,drhow,ExDD)
|
||||||
|
|
||||||
|
! Compute the exchange MGGA part of the derivative discontinuity
|
||||||
|
|
||||||
|
implicit none
|
||||||
|
include 'parameters.h'
|
||||||
|
|
||||||
|
! Input variables
|
||||||
|
|
||||||
|
character(len=12),intent(in) :: DFA
|
||||||
|
integer,intent(in) :: nEns
|
||||||
|
double precision,intent(in) :: wEns(nEns)
|
||||||
|
integer,intent(in) :: nGrid
|
||||||
|
double precision,intent(in) :: weight(nGrid)
|
||||||
|
double precision,intent(in) :: rhow(nGrid)
|
||||||
|
double precision,intent(in) :: drhow(ncart,nGrid)
|
||||||
|
|
||||||
|
! Local variables
|
||||||
|
|
||||||
|
|
||||||
|
! Output variables
|
||||||
|
|
||||||
|
double precision,intent(out) :: ExDD(nEns)
|
||||||
|
|
||||||
|
! Select exchange functional
|
||||||
|
|
||||||
|
select case (DFA)
|
||||||
|
|
||||||
|
case default
|
||||||
|
|
||||||
|
call print_warning('!!! MGGA exchange derivative discontinuity not available !!!')
|
||||||
|
stop
|
||||||
|
|
||||||
|
end select
|
||||||
|
|
||||||
|
end subroutine unrestricted_mgga_exchange_derivative_discontinuity
|
35
src/eDFT/unrestricted_mgga_exchange_individual_energy.f90
Normal file
35
src/eDFT/unrestricted_mgga_exchange_individual_energy.f90
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
subroutine unrestricted_mgga_exchange_individual_energy(DFA,nEns,wEns,nGrid,weight,rhow,drhow,rho,drho,Ex)
|
||||||
|
|
||||||
|
! Compute MGGA exchange energy for individual states
|
||||||
|
|
||||||
|
implicit none
|
||||||
|
include 'parameters.h'
|
||||||
|
|
||||||
|
! Input variables
|
||||||
|
|
||||||
|
character(len=12),intent(in) :: DFA
|
||||||
|
integer,intent(in) :: nEns
|
||||||
|
double precision,intent(in) :: wEns(nEns)
|
||||||
|
integer,intent(in) :: nGrid
|
||||||
|
double precision,intent(in) :: weight(nGrid)
|
||||||
|
double precision,intent(in) :: rhow(nGrid)
|
||||||
|
double precision,intent(in) :: drhow(ncart,nGrid)
|
||||||
|
double precision,intent(in) :: rho(nGrid)
|
||||||
|
double precision,intent(in) :: drho(ncart,nGrid)
|
||||||
|
|
||||||
|
! Output variables
|
||||||
|
|
||||||
|
double precision :: Ex
|
||||||
|
|
||||||
|
! Select correlation functional
|
||||||
|
|
||||||
|
select case (DFA)
|
||||||
|
|
||||||
|
case default
|
||||||
|
|
||||||
|
call print_warning('!!! MGGA exchange individual energy not available !!!')
|
||||||
|
stop
|
||||||
|
|
||||||
|
end select
|
||||||
|
|
||||||
|
end subroutine unrestricted_mgga_exchange_individual_energy
|
36
src/eDFT/unrestricted_mgga_exchange_potential.f90
Normal file
36
src/eDFT/unrestricted_mgga_exchange_potential.f90
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
subroutine unrestricted_mgga_exchange_potential(DFA,nEns,wEns,nGrid,weight,nBas,AO,dAO,rho,drho,Fx)
|
||||||
|
|
||||||
|
! Select MGGA exchange functional for potential calculation
|
||||||
|
|
||||||
|
implicit none
|
||||||
|
include 'parameters.h'
|
||||||
|
|
||||||
|
! Input variables
|
||||||
|
|
||||||
|
character(len=12),intent(in) :: DFA
|
||||||
|
integer,intent(in) :: nEns
|
||||||
|
double precision,intent(in) :: wEns(nEns)
|
||||||
|
integer,intent(in) :: nGrid
|
||||||
|
double precision,intent(in) :: weight(nGrid)
|
||||||
|
integer,intent(in) :: nBas
|
||||||
|
double precision,intent(in) :: AO(nBas,nGrid)
|
||||||
|
double precision,intent(in) :: dAO(3,nBas,nGrid)
|
||||||
|
double precision,intent(in) :: rho(nGrid)
|
||||||
|
double precision,intent(in) :: drho(3,nGrid)
|
||||||
|
|
||||||
|
! Output variables
|
||||||
|
|
||||||
|
double precision,intent(out) :: Fx(nBas,nBas)
|
||||||
|
|
||||||
|
! Select MGGA exchange functional
|
||||||
|
|
||||||
|
select case (DFA)
|
||||||
|
|
||||||
|
case default
|
||||||
|
|
||||||
|
call print_warning('!!! MGGA exchange potential not available !!!')
|
||||||
|
stop
|
||||||
|
|
||||||
|
end select
|
||||||
|
|
||||||
|
end subroutine unrestricted_mgga_exchange_potential
|
Loading…
Reference in New Issue
Block a user