mirror of
https://gitlab.com/scemama/qmcchem.git
synced 2024-10-18 05:51:30 +02:00
195 lines
4.9 KiB
FortranFixed
195 lines
4.9 KiB
FortranFixed
|
! Simple Jastrow
|
||
|
! --------------
|
||
|
|
||
|
BEGIN_PROVIDER [ double precision , jast_elec_Simple_value, (elec_num_8) ]
|
||
|
implicit none
|
||
|
BEGIN_DOC
|
||
|
! J(i) = \sum_j a.rij/(1+b^2.rij) - \sum_A (a.riA/(1+a.riA))^2
|
||
|
END_DOC
|
||
|
integer :: i,j
|
||
|
double precision :: a, b, rij, tmp
|
||
|
|
||
|
do i=1,elec_num
|
||
|
jast_elec_Simple_value(i) = 0.d0
|
||
|
!DIR$ LOOP COUNT (100)
|
||
|
do j=1,nucl_num
|
||
|
a = jast_pen(j)
|
||
|
rij = nucl_elec_dist(j,i)
|
||
|
tmp = a*rij/(1.d0+a*rij)
|
||
|
jast_elec_Simple_value(i) -= tmp*tmp
|
||
|
enddo
|
||
|
enddo
|
||
|
|
||
|
a = 0.5*jast_a_up_up
|
||
|
b = jast_b_up_up
|
||
|
|
||
|
do j=1,elec_alpha_num
|
||
|
!DIR$ LOOP COUNT (50)
|
||
|
do i=j+1,elec_alpha_num
|
||
|
rij = elec_dist(i,j)
|
||
|
tmp = a*rij/(1.d0+b*rij)
|
||
|
jast_elec_Simple_value(i) += tmp
|
||
|
jast_elec_Simple_value(j) += tmp
|
||
|
enddo
|
||
|
enddo
|
||
|
|
||
|
do j=elec_alpha_num+1,elec_num
|
||
|
!DIR$ LOOP COUNT (50)
|
||
|
do i=j+1,elec_num
|
||
|
rij = elec_dist(i,j)
|
||
|
tmp = a*rij/(1.d0+b*rij)
|
||
|
jast_elec_Simple_value(i) += tmp
|
||
|
jast_elec_Simple_value(j) += tmp
|
||
|
enddo
|
||
|
enddo
|
||
|
|
||
|
a = 0.5*jast_a_up_dn
|
||
|
b = jast_b_up_dn
|
||
|
|
||
|
do j=1,elec_alpha_num
|
||
|
!DIR$ LOOP COUNT (50)
|
||
|
do i=elec_alpha_num+1,elec_num
|
||
|
rij = elec_dist(i,j)
|
||
|
tmp = a*rij/(1.d0+b*rij)
|
||
|
jast_elec_Simple_value(i) += tmp
|
||
|
jast_elec_Simple_value(j) += tmp
|
||
|
enddo
|
||
|
enddo
|
||
|
|
||
|
END_PROVIDER
|
||
|
|
||
|
BEGIN_PROVIDER [ double precision , jast_elec_Simple_grad_x, (elec_num_8) ]
|
||
|
&BEGIN_PROVIDER [ double precision , jast_elec_Simple_grad_y, (elec_num_8) ]
|
||
|
&BEGIN_PROVIDER [ double precision , jast_elec_Simple_grad_z, (elec_num_8) ]
|
||
|
implicit none
|
||
|
BEGIN_DOC
|
||
|
! Gradient of the Jastrow factor
|
||
|
END_DOC
|
||
|
|
||
|
integer :: i,j
|
||
|
double precision :: a, b, rij, tmp, x, y, z
|
||
|
|
||
|
do i=1,elec_num
|
||
|
jast_elec_Simple_grad_x(i) = 0.d0
|
||
|
jast_elec_Simple_grad_y(i) = 0.d0
|
||
|
jast_elec_Simple_grad_z(i) = 0.d0
|
||
|
!DIR$ LOOP COUNT (100)
|
||
|
do j=1,nucl_num
|
||
|
a = jast_pen(j)
|
||
|
rij = a*nucl_elec_dist(j,i)
|
||
|
tmp = (a+a)*a/(1.d0+rij*(3.d0+rij*(3.d0+rij)))
|
||
|
jast_elec_Simple_grad_x(i) -= nucl_elec_dist_vec(1,j,i)*tmp
|
||
|
jast_elec_Simple_grad_y(i) -= nucl_elec_dist_vec(2,j,i)*tmp
|
||
|
jast_elec_Simple_grad_z(i) -= nucl_elec_dist_vec(3,j,i)*tmp
|
||
|
enddo
|
||
|
enddo
|
||
|
|
||
|
a = jast_a_up_up
|
||
|
b = jast_b_up_up
|
||
|
|
||
|
do j=1,elec_alpha_num
|
||
|
!DIR$ LOOP COUNT (50)
|
||
|
do i=1,j-1
|
||
|
rij = elec_dist(i,j)
|
||
|
tmp = a/(rij*(1.d0+b*rij*(2.d0+b*rij)))
|
||
|
jast_elec_Simple_grad_x(i) += elec_dist_vec_x(i,j)*tmp
|
||
|
jast_elec_Simple_grad_y(i) += elec_dist_vec_y(i,j)*tmp
|
||
|
jast_elec_Simple_grad_z(i) += elec_dist_vec_z(i,j)*tmp
|
||
|
jast_elec_Simple_grad_x(j) -= elec_dist_vec_x(i,j)*tmp
|
||
|
jast_elec_Simple_grad_y(j) -= elec_dist_vec_y(i,j)*tmp
|
||
|
jast_elec_Simple_grad_z(j) -= elec_dist_vec_z(i,j)*tmp
|
||
|
enddo
|
||
|
enddo
|
||
|
|
||
|
do j=elec_alpha_num+1,elec_num
|
||
|
!DIR$ LOOP COUNT (50)
|
||
|
do i=elec_alpha_num+1,j-1
|
||
|
rij = elec_dist(i,j)
|
||
|
tmp = a/(rij*(1.d0+b*rij*(2.d0+b*rij)))
|
||
|
jast_elec_Simple_grad_x(i) += elec_dist_vec_x(i,j)*tmp
|
||
|
jast_elec_Simple_grad_y(i) += elec_dist_vec_y(i,j)*tmp
|
||
|
jast_elec_Simple_grad_z(i) += elec_dist_vec_z(i,j)*tmp
|
||
|
jast_elec_Simple_grad_x(j) -= elec_dist_vec_x(i,j)*tmp
|
||
|
jast_elec_Simple_grad_y(j) -= elec_dist_vec_y(i,j)*tmp
|
||
|
jast_elec_Simple_grad_z(j) -= elec_dist_vec_z(i,j)*tmp
|
||
|
enddo
|
||
|
enddo
|
||
|
|
||
|
a = jast_a_up_dn
|
||
|
b = jast_b_up_dn
|
||
|
|
||
|
do j=1,elec_alpha_num
|
||
|
!DIR$ LOOP COUNT (50)
|
||
|
do i=elec_alpha_num+1,elec_num
|
||
|
rij = elec_dist(i,j)
|
||
|
tmp = a/(rij*(1.d0+b*rij*(2.d0+b*rij)))
|
||
|
jast_elec_Simple_grad_x(i) += elec_dist_vec_x(i,j)*tmp
|
||
|
jast_elec_Simple_grad_y(i) += elec_dist_vec_y(i,j)*tmp
|
||
|
jast_elec_Simple_grad_z(i) += elec_dist_vec_z(i,j)*tmp
|
||
|
jast_elec_Simple_grad_x(j) -= elec_dist_vec_x(i,j)*tmp
|
||
|
jast_elec_Simple_grad_y(j) -= elec_dist_vec_y(i,j)*tmp
|
||
|
jast_elec_Simple_grad_z(j) -= elec_dist_vec_z(i,j)*tmp
|
||
|
enddo
|
||
|
enddo
|
||
|
|
||
|
END_PROVIDER
|
||
|
|
||
|
BEGIN_PROVIDER [ double precision , jast_elec_Simple_lapl, (elec_num_8) ]
|
||
|
implicit none
|
||
|
BEGIN_DOC
|
||
|
! Laplacian of the Jastrow factor
|
||
|
END_DOC
|
||
|
|
||
|
integer :: i,j
|
||
|
double precision :: a, b, rij, tmp, x, y, z
|
||
|
|
||
|
do i=1,elec_num
|
||
|
jast_elec_Simple_lapl(i) = 0.d0
|
||
|
!DIR$ LOOP COUNT (100)
|
||
|
do j=1,nucl_num
|
||
|
a = jast_pen(j)
|
||
|
rij = a*nucl_elec_dist(j,i)
|
||
|
tmp = 6.d0*a*a/(1.d0+rij*(4.d0+rij*(6.d0+rij*(4.d0+rij))))
|
||
|
jast_elec_Simple_lapl(i) -= tmp
|
||
|
enddo
|
||
|
enddo
|
||
|
|
||
|
|
||
|
a = jast_a_up_up+jast_a_up_up
|
||
|
b = jast_b_up_up
|
||
|
do j=1,elec_alpha_num
|
||
|
!DIR$ LOOP COUNT (50)
|
||
|
do i=1,j-1
|
||
|
rij = b*elec_dist(i,j)
|
||
|
tmp = a/(elec_dist(i,j)*(1.d0+rij*(3.d0+rij*(3.d0+rij))))
|
||
|
jast_elec_Simple_lapl(i) += tmp
|
||
|
jast_elec_Simple_lapl(j) += tmp
|
||
|
enddo
|
||
|
enddo
|
||
|
|
||
|
do j=elec_alpha_num+1,elec_num
|
||
|
!DIR$ LOOP COUNT (100)
|
||
|
do i=j+1,elec_num
|
||
|
rij = b*elec_dist(i,j)
|
||
|
tmp = a/(elec_dist(i,j)*(1.d0+rij*(3.d0+rij*(3.d0+rij))))
|
||
|
jast_elec_Simple_lapl(i) += tmp
|
||
|
jast_elec_Simple_lapl(j) += tmp
|
||
|
enddo
|
||
|
enddo
|
||
|
|
||
|
a = jast_a_up_dn+jast_a_up_dn
|
||
|
b = jast_b_up_dn
|
||
|
|
||
|
do j=1,elec_alpha_num
|
||
|
!DIR$ LOOP COUNT (100)
|
||
|
do i=elec_alpha_num+1,elec_num
|
||
|
rij = b*elec_dist(i,j)
|
||
|
tmp = a/(elec_dist(i,j)*(1.d0+rij*(3.d0+rij*(3.d0+rij))))
|
||
|
jast_elec_Simple_lapl(i) += tmp
|
||
|
jast_elec_Simple_lapl(j) += tmp
|
||
|
enddo
|
||
|
enddo
|
||
|
|
||
|
|
||
|
END_PROVIDER
|