mirror of
https://gitlab.com/scemama/qmcchem.git
synced 2025-01-18 00:21:39 +01:00
Fixed bug without pseudos
This commit is contained in:
parent
4cbb4f6a2d
commit
2381c904db
@ -131,21 +131,23 @@ BEGIN_PROVIDER [ double precision, ci_h_matrix, (size_ci_h_matrix) ]
|
|||||||
h = 0.d0
|
h = 0.d0
|
||||||
do e=1,elec_beta_num
|
do e=1,elec_beta_num
|
||||||
h += &
|
h += &
|
||||||
det_beta_grad_lapl(1,e,n) * jast_grad_jast_inv_x(e) + &
|
det_beta_grad_lapl(1,e,n) * jast_grad_jast_inv_x(elec_alpha_num+e) + &
|
||||||
det_beta_grad_lapl(2,e,n) * jast_grad_jast_inv_y(e) + &
|
det_beta_grad_lapl(2,e,n) * jast_grad_jast_inv_y(elec_alpha_num+e) + &
|
||||||
det_beta_grad_lapl(3,e,n) * jast_grad_jast_inv_z(e)
|
det_beta_grad_lapl(3,e,n) * jast_grad_jast_inv_z(elec_alpha_num+e)
|
||||||
enddo
|
enddo
|
||||||
T += 2.d0*( g * det_beta_value(n) + h * det_alpha_value(m) )
|
T += 2.d0*( g * det_beta_value(n) + h * det_alpha_value(m) )
|
||||||
g = det_alpha_value(m)*det_beta_value(n)
|
g = det_alpha_value(m)*det_beta_value(n)
|
||||||
V = E_pot* g
|
V = E_pot* g
|
||||||
do e=1,elec_alpha_num
|
if (do_pseudo) then
|
||||||
V -= pseudo_non_local(e)* g
|
do e=1,elec_alpha_num
|
||||||
V += det_alpha_pseudo(e,m) * det_beta_value(n)
|
V -= pseudo_non_local(e)* g
|
||||||
enddo
|
V += det_alpha_pseudo(e,m) * det_beta_value(n)
|
||||||
do e=1,elec_beta_num
|
enddo
|
||||||
V -= pseudo_non_local(e)* g
|
do e=1,elec_beta_num
|
||||||
V += det_alpha_value(m) * det_beta_pseudo(e,n)
|
V -= pseudo_non_local(e)* g
|
||||||
enddo
|
V += det_alpha_value(m) * det_beta_pseudo(e,n)
|
||||||
|
enddo
|
||||||
|
endif
|
||||||
f = -0.5d0*T + V
|
f = -0.5d0*T + V
|
||||||
f *= psidet_inv * psidet_inv
|
f *= psidet_inv * psidet_inv
|
||||||
do k=1,det_num
|
do k=1,det_num
|
||||||
@ -202,21 +204,23 @@ BEGIN_PROVIDER [ double precision, ci_h_matrix_diag, (size_ci_h_matrix_diag) ]
|
|||||||
h = 0.d0
|
h = 0.d0
|
||||||
do e=1,elec_beta_num
|
do e=1,elec_beta_num
|
||||||
h += &
|
h += &
|
||||||
det_beta_grad_lapl(1,e,n) * jast_grad_jast_inv_x(e) + &
|
det_beta_grad_lapl(1,e,n) * jast_grad_jast_inv_x(elec_alpha_num+e) + &
|
||||||
det_beta_grad_lapl(2,e,n) * jast_grad_jast_inv_y(e) + &
|
det_beta_grad_lapl(2,e,n) * jast_grad_jast_inv_y(elec_alpha_num+e) + &
|
||||||
det_beta_grad_lapl(3,e,n) * jast_grad_jast_inv_z(e)
|
det_beta_grad_lapl(3,e,n) * jast_grad_jast_inv_z(elec_alpha_num+e)
|
||||||
enddo
|
enddo
|
||||||
T += 2.d0*( g * det_beta_value(n) + h * det_alpha_value(m) )
|
T += 2.d0*( g * det_beta_value(n) + h * det_alpha_value(m) )
|
||||||
g = det_alpha_value(m)*det_beta_value(n)
|
g = det_alpha_value(m)*det_beta_value(n)
|
||||||
V = E_pot* g
|
V = E_pot* g
|
||||||
do e=1,elec_alpha_num
|
if (do_pseudo) then
|
||||||
V -= pseudo_non_local(e)* g
|
do e=1,elec_alpha_num
|
||||||
V += det_alpha_pseudo(e,m) * det_beta_value(n)
|
V -= pseudo_non_local(e)* g
|
||||||
enddo
|
V += det_alpha_pseudo(e,m) * det_beta_value(n)
|
||||||
do e=1,elec_beta_num
|
enddo
|
||||||
V -= pseudo_non_local(e)* g
|
do e=1,elec_beta_num
|
||||||
V += det_alpha_value(m) * det_beta_pseudo(e,n)
|
V -= pseudo_non_local(e)* g
|
||||||
enddo
|
V += det_alpha_value(m) * det_beta_pseudo(e,n)
|
||||||
|
enddo
|
||||||
|
endif
|
||||||
f = -0.5d0*T + V
|
f = -0.5d0*T + V
|
||||||
f *= psidet_inv * psidet_inv
|
f *= psidet_inv * psidet_inv
|
||||||
ci_h_matrix_diag(l) = f * &
|
ci_h_matrix_diag(l) = f * &
|
||||||
|
@ -1683,6 +1683,7 @@ END_PROVIDER
|
|||||||
if (ifirst == 0) then
|
if (ifirst == 0) then
|
||||||
ifirst = 1
|
ifirst = 1
|
||||||
psidet_grad_lapl = 0.d0
|
psidet_grad_lapl = 0.d0
|
||||||
|
pseudo_non_local = 0.d0
|
||||||
endif
|
endif
|
||||||
|
|
||||||
integer :: i,j,k, l
|
integer :: i,j,k, l
|
||||||
|
Loading…
x
Reference in New Issue
Block a user