mirror of
https://github.com/QuantumPackage/qp2.git
synced 2024-11-08 06:23:37 +01:00
111 lines
5.3 KiB
Fortran
111 lines
5.3 KiB
Fortran
|
|
subroutine GGA_sr_type_functionals(r,rho_a,rho_b,grad_rho_a_2,grad_rho_b_2,grad_rho_a_b, &
|
|
ex,vx_rho_a,vx_rho_b,vx_grad_rho_a_2,vx_grad_rho_b_2,vx_grad_rho_a_b, &
|
|
ec,vc_rho_a,vc_rho_b,vc_grad_rho_a_2,vc_grad_rho_b_2,vc_grad_rho_a_b )
|
|
implicit none
|
|
BEGIN_DOC
|
|
! routine that helps in building the x/c potentials on the AO basis for a GGA functional with a short-range interaction
|
|
END_DOC
|
|
double precision, intent(in) :: r(3),rho_a(N_states),rho_b(N_states),grad_rho_a_2(N_states),grad_rho_b_2(N_states),grad_rho_a_b(N_states)
|
|
double precision, intent(out) :: ex(N_states),vx_rho_a(N_states),vx_rho_b(N_states),vx_grad_rho_a_2(N_states),vx_grad_rho_b_2(N_states),vx_grad_rho_a_b(N_states)
|
|
double precision, intent(out) :: ec(N_states),vc_rho_a(N_states),vc_rho_b(N_states),vc_grad_rho_a_2(N_states),vc_grad_rho_b_2(N_states),vc_grad_rho_a_b(N_states)
|
|
integer :: istate
|
|
double precision :: r2(3),dr2(3), local_potential,r12,dx2,mu
|
|
do istate = 1, N_states
|
|
if(exchange_functional.EQ."short_range_PBE")then
|
|
call ex_pbe_sr(mu_erf_dft,rho_a(istate),rho_b(istate),grad_rho_a_2(istate),grad_rho_b_2(istate),grad_rho_a_b(istate),ex(istate),vx_rho_a(istate),vx_rho_b(istate),vx_grad_rho_a_2(istate),vx_grad_rho_b_2(istate),vx_grad_rho_a_b(istate))
|
|
else if(exchange_functional.EQ."None")then
|
|
ex = 0.d0
|
|
vx_rho_a = 0.d0
|
|
vx_rho_b = 0.d0
|
|
vx_grad_rho_a_2 = 0.d0
|
|
vx_grad_rho_a_b = 0.d0
|
|
vx_grad_rho_b_2 = 0.d0
|
|
else
|
|
print*, 'Exchange functional required does not exist ...'
|
|
print*,'exchange_functional',exchange_functional
|
|
stop
|
|
endif
|
|
|
|
double precision :: rhoc,rhoo,sigmacc,sigmaco,sigmaoo,vrhoc,vrhoo,vsigmacc,vsigmaco,vsigmaoo
|
|
if(correlation_functional.EQ."short_range_PBE")then
|
|
! convertion from (alpha,beta) formalism to (closed, open) formalism
|
|
call rho_ab_to_rho_oc(rho_a(istate),rho_b(istate),rhoo,rhoc)
|
|
call grad_rho_ab_to_grad_rho_oc(grad_rho_a_2(istate),grad_rho_b_2(istate),grad_rho_a_b(istate),sigmaoo,sigmacc,sigmaco)
|
|
|
|
call ec_pbe_sr(mu_erf_dft,rhoc,rhoo,sigmacc,sigmaco,sigmaoo,ec(istate),vrhoc,vrhoo,vsigmacc,vsigmaco,vsigmaoo)
|
|
|
|
call v_rho_oc_to_v_rho_ab(vrhoo,vrhoc,vc_rho_a(istate),vc_rho_b(istate))
|
|
call v_grad_rho_oc_to_v_grad_rho_ab(vsigmaoo,vsigmacc,vsigmaco,vc_grad_rho_a_2(istate),vc_grad_rho_b_2(istate),vc_grad_rho_a_b(istate))
|
|
else if(correlation_functional.EQ."None")then
|
|
ec = 0.d0
|
|
vc_rho_a = 0.d0
|
|
vc_rho_b = 0.d0
|
|
vc_grad_rho_a_2 = 0.d0
|
|
vc_grad_rho_a_b = 0.d0
|
|
vc_grad_rho_b_2 = 0.d0
|
|
else
|
|
print*, 'Correlation functional required does not exist ...'
|
|
print*, 'correlation_functional',correlation_functional
|
|
stop
|
|
endif
|
|
enddo
|
|
end
|
|
|
|
|
|
subroutine GGA_type_functionals(r,rho_a,rho_b,grad_rho_a_2,grad_rho_b_2,grad_rho_a_b, &
|
|
ex,vx_rho_a,vx_rho_b,vx_grad_rho_a_2,vx_grad_rho_b_2,vx_grad_rho_a_b, &
|
|
ec,vc_rho_a,vc_rho_b,vc_grad_rho_a_2,vc_grad_rho_b_2,vc_grad_rho_a_b )
|
|
implicit none
|
|
BEGIN_DOC
|
|
! routine that helps in building the x/c potentials on the AO basis for a GGA functional
|
|
END_DOC
|
|
double precision, intent(in) :: r(3),rho_a(N_states),rho_b(N_states),grad_rho_a_2(N_states),grad_rho_b_2(N_states),grad_rho_a_b(N_states)
|
|
double precision, intent(out) :: ex(N_states),vx_rho_a(N_states),vx_rho_b(N_states),vx_grad_rho_a_2(N_states),vx_grad_rho_b_2(N_states),vx_grad_rho_a_b(N_states)
|
|
double precision, intent(out) :: ec(N_states),vc_rho_a(N_states),vc_rho_b(N_states),vc_grad_rho_a_2(N_states),vc_grad_rho_b_2(N_states),vc_grad_rho_a_b(N_states)
|
|
integer :: istate
|
|
double precision :: r2(3),dr2(3), local_potential,r12,dx2
|
|
double precision :: mu_local
|
|
mu_local = 1.d-9
|
|
do istate = 1, N_states
|
|
if(exchange_functional.EQ."PBE")then
|
|
call ex_pbe_sr(mu_local,rho_a(istate),rho_b(istate),grad_rho_a_2(istate),grad_rho_b_2(istate),grad_rho_a_b(istate),ex(istate),vx_rho_a(istate),vx_rho_b(istate),vx_grad_rho_a_2(istate),vx_grad_rho_b_2(istate),vx_grad_rho_a_b(istate))
|
|
else if(exchange_functional.EQ."None")then
|
|
ex = 0.d0
|
|
vx_rho_a = 0.d0
|
|
vx_rho_b = 0.d0
|
|
vx_grad_rho_a_2 = 0.d0
|
|
vx_grad_rho_a_b = 0.d0
|
|
vx_grad_rho_b_2 = 0.d0
|
|
else
|
|
print*, 'Exchange functional required does not exist ...'
|
|
print*,'exchange_functional',exchange_functional
|
|
stop
|
|
endif
|
|
|
|
double precision :: rhoc,rhoo,sigmacc,sigmaco,sigmaoo,vrhoc,vrhoo,vsigmacc,vsigmaco,vsigmaoo
|
|
if(correlation_functional.EQ."PBE")then
|
|
! convertion from (alpha,beta) formalism to (closed, open) formalism
|
|
call rho_ab_to_rho_oc(rho_a(istate),rho_b(istate),rhoo,rhoc)
|
|
call grad_rho_ab_to_grad_rho_oc(grad_rho_a_2(istate),grad_rho_b_2(istate),grad_rho_a_b(istate),sigmaoo,sigmacc,sigmaco)
|
|
|
|
call ec_pbe_sr(mu_local,rhoc,rhoo,sigmacc,sigmaco,sigmaoo,ec(istate),vrhoc,vrhoo,vsigmacc,vsigmaco,vsigmaoo)
|
|
|
|
call v_rho_oc_to_v_rho_ab(vrhoo,vrhoc,vc_rho_a(istate),vc_rho_b(istate))
|
|
call v_grad_rho_oc_to_v_grad_rho_ab(vsigmaoo,vsigmacc,vsigmaco,vc_grad_rho_a_2(istate),vc_grad_rho_b_2(istate),vc_grad_rho_a_b(istate))
|
|
else if(correlation_functional.EQ."None")then
|
|
ec = 0.d0
|
|
vc_rho_a = 0.d0
|
|
vc_rho_b = 0.d0
|
|
vc_grad_rho_a_2 = 0.d0
|
|
vc_grad_rho_a_b = 0.d0
|
|
vc_grad_rho_b_2 = 0.d0
|
|
else
|
|
print*, 'Correlation functional required does not exist ...'
|
|
print*, 'correlation_functional',correlation_functional
|
|
stop
|
|
endif
|
|
enddo
|
|
end
|
|
|