mirror of
https://gitlab.com/scemama/qmcchem.git
synced 2025-01-03 01:55:39 +01:00
Split mo_grad_lapl in alpha/beta
This commit is contained in:
parent
052b2db389
commit
6208018b4a
102
src/det.irp.f
102
src/det.irp.f
@ -221,11 +221,9 @@ subroutine det_update$n(n,LDS,m,l,S,S_inv,d)
|
|||||||
!DIR$ ASSUME (LDS >= $n)
|
!DIR$ ASSUME (LDS >= $n)
|
||||||
integer :: i,j
|
integer :: i,j
|
||||||
|
|
||||||
!$OMP SIMD
|
|
||||||
do i=1,$n
|
do i=1,$n
|
||||||
u(i) = m(i) - S(i,l)
|
u(i) = m(i) - S(i,l)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
|
|
||||||
z(l) = S_inv($n,l)*u($n)
|
z(l) = S_inv($n,l)*u($n)
|
||||||
!DIR$ VECTOR ALIGNED
|
!DIR$ VECTOR ALIGNED
|
||||||
@ -255,23 +253,19 @@ subroutine det_update$n(n,LDS,m,l,S,S_inv,d)
|
|||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
!$OMP SIMD
|
|
||||||
do i=1,$n
|
do i=1,$n
|
||||||
w(i) = S_inv(i,l)*d_inv
|
w(i) = S_inv(i,l)*d_inv
|
||||||
S(i,l) = m(i)
|
S(i,l) = m(i)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
|
|
||||||
do i=1,$n,4
|
do i=1,$n,4
|
||||||
!DIR$ VECTOR ALIGNED
|
!DIR$ VECTOR ALIGNED
|
||||||
!$OMP SIMD
|
|
||||||
do j=1,$n
|
do j=1,$n
|
||||||
S_inv(j,i ) = S_inv(j,i )*lambda -z(i )*w(j)
|
S_inv(j,i ) = S_inv(j,i )*lambda -z(i )*w(j)
|
||||||
S_inv(j,i+1) = S_inv(j,i+1)*lambda -z(i+1)*w(j)
|
S_inv(j,i+1) = S_inv(j,i+1)*lambda -z(i+1)*w(j)
|
||||||
S_inv(j,i+2) = S_inv(j,i+2)*lambda -z(i+2)*w(j)
|
S_inv(j,i+2) = S_inv(j,i+2)*lambda -z(i+2)*w(j)
|
||||||
S_inv(j,i+3) = S_inv(j,i+3)*lambda -z(i+3)*w(j)
|
S_inv(j,i+3) = S_inv(j,i+3)*lambda -z(i+3)*w(j)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
end
|
end
|
||||||
@ -354,14 +348,12 @@ subroutine det_update$n(n,LDS,m,l,S,S_inv,d)
|
|||||||
enddo
|
enddo
|
||||||
|
|
||||||
do i=1,$n-1,4
|
do i=1,$n-1,4
|
||||||
!$OMP SIMD
|
|
||||||
do j=1,$n-1
|
do j=1,$n-1
|
||||||
S_inv(j,i ) = S_inv(j,i )*lambda - w(j)*z(i )
|
S_inv(j,i ) = S_inv(j,i )*lambda - w(j)*z(i )
|
||||||
S_inv(j,i+1) = S_inv(j,i+1)*lambda - w(j)*z(i+1)
|
S_inv(j,i+1) = S_inv(j,i+1)*lambda - w(j)*z(i+1)
|
||||||
S_inv(j,i+2) = S_inv(j,i+2)*lambda - w(j)*z(i+2)
|
S_inv(j,i+2) = S_inv(j,i+2)*lambda - w(j)*z(i+2)
|
||||||
S_inv(j,i+3) = S_inv(j,i+3)*lambda - w(j)*z(i+3)
|
S_inv(j,i+3) = S_inv(j,i+3)*lambda - w(j)*z(i+3)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
do i=1,$n-1,4
|
do i=1,$n-1,4
|
||||||
@ -416,11 +408,9 @@ subroutine det_update$n(n,LDS,m,l,S,S_inv,d)
|
|||||||
!DIR$ ASSUME (LDS >= $n)
|
!DIR$ ASSUME (LDS >= $n)
|
||||||
integer :: i,j
|
integer :: i,j
|
||||||
|
|
||||||
!$OMP SIMD
|
|
||||||
do i=1,$n
|
do i=1,$n
|
||||||
u(i) = m(i) - S(i,l)
|
u(i) = m(i) - S(i,l)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
|
|
||||||
z(l) = S_inv($n,l)*u($n)
|
z(l) = S_inv($n,l)*u($n)
|
||||||
!DIR$ VECTOR ALIGNED
|
!DIR$ VECTOR ALIGNED
|
||||||
@ -459,33 +449,27 @@ subroutine det_update$n(n,LDS,m,l,S,S_inv,d)
|
|||||||
z(j+1) = z(j+1) + S_inv(i,j+1)*u(i)
|
z(j+1) = z(j+1) + S_inv(i,j+1)*u(i)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
!$OMP SIMD
|
|
||||||
do i=1,$n
|
do i=1,$n
|
||||||
w(i) = S_inv(i,l)*d_inv
|
w(i) = S_inv(i,l)*d_inv
|
||||||
S(i,l) = m(i)
|
S(i,l) = m(i)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
|
|
||||||
do i=1,$n-2,4
|
do i=1,$n-2,4
|
||||||
!DIR$ VECTOR ALIGNED
|
!DIR$ VECTOR ALIGNED
|
||||||
!$OMP SIMD
|
|
||||||
do j=1,$n
|
do j=1,$n
|
||||||
S_inv(j,i ) = S_inv(j,i )*lambda -z(i )*w(j)
|
S_inv(j,i ) = S_inv(j,i )*lambda -z(i )*w(j)
|
||||||
S_inv(j,i+1) = S_inv(j,i+1)*lambda -z(i+1)*w(j)
|
S_inv(j,i+1) = S_inv(j,i+1)*lambda -z(i+1)*w(j)
|
||||||
S_inv(j,i+2) = S_inv(j,i+2)*lambda -z(i+2)*w(j)
|
S_inv(j,i+2) = S_inv(j,i+2)*lambda -z(i+2)*w(j)
|
||||||
S_inv(j,i+3) = S_inv(j,i+3)*lambda -z(i+3)*w(j)
|
S_inv(j,i+3) = S_inv(j,i+3)*lambda -z(i+3)*w(j)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
i=$n-1
|
i=$n-1
|
||||||
!DIR$ VECTOR ALIGNED
|
!DIR$ VECTOR ALIGNED
|
||||||
!$OMP SIMD
|
|
||||||
do j=1,$n
|
do j=1,$n
|
||||||
S_inv(j,i ) = S_inv(j,i )*lambda -z(i )*w(j)
|
S_inv(j,i ) = S_inv(j,i )*lambda -z(i )*w(j)
|
||||||
S_inv(j,i+1) = S_inv(j,i+1)*lambda -z(i+1)*w(j)
|
S_inv(j,i+1) = S_inv(j,i+1)*lambda -z(i+1)*w(j)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -575,24 +559,20 @@ subroutine det_update$n(n,LDS,m,l,S,S_inv,d)
|
|||||||
enddo
|
enddo
|
||||||
|
|
||||||
do i=1,$n-3,4
|
do i=1,$n-3,4
|
||||||
!$OMP SIMD
|
|
||||||
do j=1,$n
|
do j=1,$n
|
||||||
S_inv(j,i ) = S_inv(j,i )*lambda - w(j)*z(i )
|
S_inv(j,i ) = S_inv(j,i )*lambda - w(j)*z(i )
|
||||||
S_inv(j,i+1) = S_inv(j,i+1)*lambda - w(j)*z(i+1)
|
S_inv(j,i+1) = S_inv(j,i+1)*lambda - w(j)*z(i+1)
|
||||||
S_inv(j,i+2) = S_inv(j,i+2)*lambda - w(j)*z(i+2)
|
S_inv(j,i+2) = S_inv(j,i+2)*lambda - w(j)*z(i+2)
|
||||||
S_inv(j,i+3) = S_inv(j,i+3)*lambda - w(j)*z(i+3)
|
S_inv(j,i+3) = S_inv(j,i+3)*lambda - w(j)*z(i+3)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
i=$n-2
|
i=$n-2
|
||||||
!$OMP SIMD
|
|
||||||
do j=1,$n
|
do j=1,$n
|
||||||
S_inv(j,i ) = S_inv(j,i )*lambda - w(j)*z(i )
|
S_inv(j,i ) = S_inv(j,i )*lambda - w(j)*z(i )
|
||||||
S_inv(j,i+1) = S_inv(j,i+1)*lambda - w(j)*z(i+1)
|
S_inv(j,i+1) = S_inv(j,i+1)*lambda - w(j)*z(i+1)
|
||||||
S_inv(j,i+2) = S_inv(j,i+2)*lambda - w(j)*z(i+2)
|
S_inv(j,i+2) = S_inv(j,i+2)*lambda - w(j)*z(i+2)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -634,11 +614,9 @@ subroutine det_update_general(n,LDS,m,l,S,S_inv,d)
|
|||||||
!DIR$ ASSUME (MOD(LDS,$IRP_ALIGN/8) == 0)
|
!DIR$ ASSUME (MOD(LDS,$IRP_ALIGN/8) == 0)
|
||||||
integer :: i,j,n4
|
integer :: i,j,n4
|
||||||
|
|
||||||
!$OMP SIMD
|
|
||||||
do i=1,n
|
do i=1,n
|
||||||
u(i) = m(i) - S(i,l)
|
u(i) = m(i) - S(i,l)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
|
|
||||||
z(l) = 0.d0
|
z(l) = 0.d0
|
||||||
!DIR$ VECTOR ALIGNED
|
!DIR$ VECTOR ALIGNED
|
||||||
@ -686,20 +664,16 @@ subroutine det_update_general(n,LDS,m,l,S,S_inv,d)
|
|||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
!$OMP SIMD
|
|
||||||
do i=1,n
|
do i=1,n
|
||||||
w(i) = S_inv(i,l)*d_inv
|
w(i) = S_inv(i,l)*d_inv
|
||||||
S(i,l) = m(i)
|
S(i,l) = m(i)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
|
|
||||||
do i=1,n
|
do i=1,n
|
||||||
!DIR$ VECTOR ALIGNED
|
!DIR$ VECTOR ALIGNED
|
||||||
!$OMP SIMD aligned(S_inv,z)
|
|
||||||
do j=1,n
|
do j=1,n
|
||||||
S_inv(j,i) = S_inv(j,i)*lambda -z(i)*w(j)
|
S_inv(j,i) = S_inv(j,i)*lambda -z(i)*w(j)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
end
|
end
|
||||||
@ -1034,11 +1008,9 @@ END_PROVIDER
|
|||||||
|
|
||||||
det_alpha_value(det_i) = det_alpha_value_curr
|
det_alpha_value(det_i) = det_alpha_value_curr
|
||||||
do i=1,elec_alpha_num
|
do i=1,elec_alpha_num
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
det_alpha_grad_lapl(k,i,det_i) = det_alpha_grad_lapl_curr(k,i)
|
det_alpha_grad_lapl(k,i,det_i) = det_alpha_grad_lapl_curr(k,i)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
if (do_pseudo) then
|
if (do_pseudo) then
|
||||||
det_alpha_pseudo(i,det_i) = det_alpha_pseudo_curr(i)
|
det_alpha_pseudo(i,det_i) = det_alpha_pseudo_curr(i)
|
||||||
endif
|
endif
|
||||||
@ -1088,11 +1060,9 @@ END_PROVIDER
|
|||||||
det_beta_value(det_j) = det_beta_value_curr
|
det_beta_value(det_j) = det_beta_value_curr
|
||||||
!DIR$ LOOP COUNT (200)
|
!DIR$ LOOP COUNT (200)
|
||||||
do i=elec_alpha_num+1,elec_num
|
do i=elec_alpha_num+1,elec_num
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
det_beta_grad_lapl(k,i,det_j) = det_beta_grad_lapl_curr(k,i)
|
det_beta_grad_lapl(k,i,det_j) = det_beta_grad_lapl_curr(k,i)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
if (do_pseudo) then
|
if (do_pseudo) then
|
||||||
det_beta_pseudo(i,det_j) = det_beta_pseudo_curr(i)
|
det_beta_pseudo(i,det_j) = det_beta_pseudo_curr(i)
|
||||||
endif
|
endif
|
||||||
@ -1223,11 +1193,9 @@ END_PROVIDER
|
|||||||
! -----
|
! -----
|
||||||
|
|
||||||
psidet_value = 0.d0
|
psidet_value = 0.d0
|
||||||
!$OMP SIMD reduction(+:psidet_value)
|
|
||||||
do j=1,det_beta_num
|
do j=1,det_beta_num
|
||||||
psidet_value = psidet_value + det_beta_value(j) * DaC(j)
|
psidet_value = psidet_value + det_beta_value(j) * DaC(j)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
|
|
||||||
|
|
||||||
if (psidet_value == 0.d0) then
|
if (psidet_value == 0.d0) then
|
||||||
@ -1246,22 +1214,18 @@ END_PROVIDER
|
|||||||
|
|
||||||
do i=1,det_alpha_num
|
do i=1,det_alpha_num
|
||||||
do j=1,elec_alpha_num
|
do j=1,elec_alpha_num
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
psidet_grad_lapl(k,j) = psidet_grad_lapl(k,j) + det_alpha_grad_lapl(k,j,i)*CDb(i)
|
psidet_grad_lapl(k,j) = psidet_grad_lapl(k,j) + det_alpha_grad_lapl(k,j,i)*CDb(i)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
pseudo_non_local(j) = pseudo_non_local(j) + det_alpha_pseudo(j,i)*CDb(i)
|
pseudo_non_local(j) = pseudo_non_local(j) + det_alpha_pseudo(j,i)*CDb(i)
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
do i=1,det_beta_num
|
do i=1,det_beta_num
|
||||||
do j=elec_alpha_num+1,elec_num
|
do j=elec_alpha_num+1,elec_num
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
psidet_grad_lapl(k,j) = psidet_grad_lapl(k,j) + det_beta_grad_lapl(k,j,i)*DaC(i)
|
psidet_grad_lapl(k,j) = psidet_grad_lapl(k,j) + det_beta_grad_lapl(k,j,i)*DaC(i)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
pseudo_non_local(j) = pseudo_non_local(j) + det_beta_pseudo(j,i)*DaC(i)
|
pseudo_non_local(j) = pseudo_non_local(j) + det_beta_pseudo(j,i)*DaC(i)
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
@ -1278,21 +1242,17 @@ END_PROVIDER
|
|||||||
|
|
||||||
do i=1,det_alpha_num
|
do i=1,det_alpha_num
|
||||||
do j=1,elec_alpha_num
|
do j=1,elec_alpha_num
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
psidet_grad_lapl(k,j) = psidet_grad_lapl(k,j) + det_alpha_grad_lapl(k,j,i)*CDb(i)
|
psidet_grad_lapl(k,j) = psidet_grad_lapl(k,j) + det_alpha_grad_lapl(k,j,i)*CDb(i)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
do i=1,det_beta_num
|
do i=1,det_beta_num
|
||||||
do j=elec_alpha_num+1,elec_num
|
do j=elec_alpha_num+1,elec_num
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
psidet_grad_lapl(k,j) = psidet_grad_lapl(k,j) + det_beta_grad_lapl(k,j,i)*DaC(i)
|
psidet_grad_lapl(k,j) = psidet_grad_lapl(k,j) + det_beta_grad_lapl(k,j,i)*DaC(i)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
@ -1392,14 +1352,12 @@ BEGIN_PROVIDER [ double precision, det_alpha_grad_lapl_curr, (4,elec_alpha_num)
|
|||||||
imo = mo_list_alpha_curr(j )
|
imo = mo_list_alpha_curr(j )
|
||||||
imo2 = mo_list_alpha_curr(j+1)
|
imo2 = mo_list_alpha_curr(j+1)
|
||||||
do i=1,elec_alpha_num,2
|
do i=1,elec_alpha_num,2
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
det_alpha_grad_lapl_curr(k,i ) = det_alpha_grad_lapl_curr(k,i ) + mo_grad_lapl(k,i ,imo )*slater_matrix_alpha_inv_det(i ,j ) &
|
det_alpha_grad_lapl_curr(k,i ) = det_alpha_grad_lapl_curr(k,i ) + mo_grad_lapl_alpha(k,i ,imo )*slater_matrix_alpha_inv_det(i ,j ) &
|
||||||
+ mo_grad_lapl(k,i ,imo2)*slater_matrix_alpha_inv_det(i ,j+1)
|
+ mo_grad_lapl_alpha(k,i ,imo2)*slater_matrix_alpha_inv_det(i ,j+1)
|
||||||
det_alpha_grad_lapl_curr(k,i+1) = det_alpha_grad_lapl_curr(k,i+1) + mo_grad_lapl(k,i+1,imo )*slater_matrix_alpha_inv_det(i+1,j ) &
|
det_alpha_grad_lapl_curr(k,i+1) = det_alpha_grad_lapl_curr(k,i+1) + mo_grad_lapl_alpha(k,i+1,imo )*slater_matrix_alpha_inv_det(i+1,j ) &
|
||||||
+ mo_grad_lapl(k,i+1,imo2)*slater_matrix_alpha_inv_det(i+1,j+1)
|
+ mo_grad_lapl_alpha(k,i+1,imo2)*slater_matrix_alpha_inv_det(i+1,j+1)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
@ -1409,32 +1367,26 @@ BEGIN_PROVIDER [ double precision, det_alpha_grad_lapl_curr, (4,elec_alpha_num)
|
|||||||
imo = mo_list_alpha_curr(j )
|
imo = mo_list_alpha_curr(j )
|
||||||
imo2 = mo_list_alpha_curr(j+1)
|
imo2 = mo_list_alpha_curr(j+1)
|
||||||
do i=1,elec_alpha_num-1,2
|
do i=1,elec_alpha_num-1,2
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
det_alpha_grad_lapl_curr(k,i ) = det_alpha_grad_lapl_curr(k,i ) + mo_grad_lapl(k,i ,imo )*slater_matrix_alpha_inv_det(i ,j ) &
|
det_alpha_grad_lapl_curr(k,i ) = det_alpha_grad_lapl_curr(k,i ) + mo_grad_lapl_alpha(k,i ,imo )*slater_matrix_alpha_inv_det(i ,j ) &
|
||||||
+ mo_grad_lapl(k,i ,imo2)*slater_matrix_alpha_inv_det(i ,j+1)
|
+ mo_grad_lapl_alpha(k,i ,imo2)*slater_matrix_alpha_inv_det(i ,j+1)
|
||||||
det_alpha_grad_lapl_curr(k,i+1) = det_alpha_grad_lapl_curr(k,i+1) + mo_grad_lapl(k,i+1,imo )*slater_matrix_alpha_inv_det(i+1,j ) &
|
det_alpha_grad_lapl_curr(k,i+1) = det_alpha_grad_lapl_curr(k,i+1) + mo_grad_lapl_alpha(k,i+1,imo )*slater_matrix_alpha_inv_det(i+1,j ) &
|
||||||
+ mo_grad_lapl(k,i+1,imo2)*slater_matrix_alpha_inv_det(i+1,j+1)
|
+ mo_grad_lapl_alpha(k,i+1,imo2)*slater_matrix_alpha_inv_det(i+1,j+1)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
i=elec_alpha_num
|
i=elec_alpha_num
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
det_alpha_grad_lapl_curr(k,i) = det_alpha_grad_lapl_curr(k,i) + mo_grad_lapl(k,i,imo )*slater_matrix_alpha_inv_det(i,j ) &
|
det_alpha_grad_lapl_curr(k,i) = det_alpha_grad_lapl_curr(k,i) + mo_grad_lapl_alpha(k,i,imo )*slater_matrix_alpha_inv_det(i,j ) &
|
||||||
+ mo_grad_lapl(k,i,imo2)*slater_matrix_alpha_inv_det(i,j+1)
|
+ mo_grad_lapl_alpha(k,i,imo2)*slater_matrix_alpha_inv_det(i,j+1)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
j=elec_alpha_num
|
j=elec_alpha_num
|
||||||
imo = mo_list_alpha_curr(j)
|
imo = mo_list_alpha_curr(j)
|
||||||
do i=1,elec_alpha_num
|
do i=1,elec_alpha_num
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
det_alpha_grad_lapl_curr(k,i ) = det_alpha_grad_lapl_curr(k,i ) + mo_grad_lapl(k,i ,imo)*slater_matrix_alpha_inv_det(i ,j)
|
det_alpha_grad_lapl_curr(k,i ) = det_alpha_grad_lapl_curr(k,i ) + mo_grad_lapl_alpha(k,i ,imo)*slater_matrix_alpha_inv_det(i ,j)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
endif
|
endif
|
||||||
@ -1469,7 +1421,7 @@ BEGIN_PROVIDER [ double precision, det_beta_grad_lapl_curr, (4,elec_alpha_num+1
|
|||||||
! do i=elec_alpha_num+1,elec_num
|
! do i=elec_alpha_num+1,elec_num
|
||||||
! do k=1,4
|
! do k=1,4
|
||||||
! det_beta_grad_lapl_curr(k,i) = det_beta_grad_lapl_curr(k,i) +&
|
! det_beta_grad_lapl_curr(k,i) = det_beta_grad_lapl_curr(k,i) +&
|
||||||
! mo_grad_lapl(k,i,imo)*slater_matrix_beta_inv_det(i-elec_alpha_num,j)
|
! mo_grad_lapl_alpha(k,i,imo)*slater_matrix_beta_inv_det(i-elec_alpha_num,j)
|
||||||
! enddo
|
! enddo
|
||||||
! enddo
|
! enddo
|
||||||
! enddo
|
! enddo
|
||||||
@ -1484,16 +1436,14 @@ BEGIN_PROVIDER [ double precision, det_beta_grad_lapl_curr, (4,elec_alpha_num+1
|
|||||||
!DIR$ LOOP COUNT (16)
|
!DIR$ LOOP COUNT (16)
|
||||||
do i=elec_alpha_num+1,elec_num,2
|
do i=elec_alpha_num+1,elec_num,2
|
||||||
l = i-elec_alpha_num
|
l = i-elec_alpha_num
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
det_beta_grad_lapl_curr(k,i) = det_beta_grad_lapl_curr(k,i) +&
|
det_beta_grad_lapl_curr(k,i) = det_beta_grad_lapl_curr(k,i) +&
|
||||||
mo_grad_lapl(k,i,imo )*slater_matrix_beta_inv_det(l,j ) + &
|
mo_grad_lapl_beta(k,i,imo )*slater_matrix_beta_inv_det(l,j ) + &
|
||||||
mo_grad_lapl(k,i,imo2)*slater_matrix_beta_inv_det(l,j+1)
|
mo_grad_lapl_beta(k,i,imo2)*slater_matrix_beta_inv_det(l,j+1)
|
||||||
det_beta_grad_lapl_curr(k,i+1) = det_beta_grad_lapl_curr(k,i+1) +&
|
det_beta_grad_lapl_curr(k,i+1) = det_beta_grad_lapl_curr(k,i+1) +&
|
||||||
mo_grad_lapl(k,i+1,imo )*slater_matrix_beta_inv_det(l+1,j ) + &
|
mo_grad_lapl_beta(k,i+1,imo )*slater_matrix_beta_inv_det(l+1,j ) + &
|
||||||
mo_grad_lapl(k,i+1,imo2)*slater_matrix_beta_inv_det(l+1,j+1)
|
mo_grad_lapl_beta(k,i+1,imo2)*slater_matrix_beta_inv_det(l+1,j+1)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
@ -1505,26 +1455,22 @@ BEGIN_PROVIDER [ double precision, det_beta_grad_lapl_curr, (4,elec_alpha_num+1
|
|||||||
!DIR$ LOOP COUNT (16)
|
!DIR$ LOOP COUNT (16)
|
||||||
do i=elec_alpha_num+1,elec_num-1,2
|
do i=elec_alpha_num+1,elec_num-1,2
|
||||||
l = i-elec_alpha_num
|
l = i-elec_alpha_num
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
det_beta_grad_lapl_curr(k,i) = det_beta_grad_lapl_curr(k,i) +&
|
det_beta_grad_lapl_curr(k,i) = det_beta_grad_lapl_curr(k,i) +&
|
||||||
mo_grad_lapl(k,i,imo )*slater_matrix_beta_inv_det(l,j ) + &
|
mo_grad_lapl_beta(k,i,imo )*slater_matrix_beta_inv_det(l,j ) + &
|
||||||
mo_grad_lapl(k,i,imo2)*slater_matrix_beta_inv_det(l,j+1)
|
mo_grad_lapl_beta(k,i,imo2)*slater_matrix_beta_inv_det(l,j+1)
|
||||||
det_beta_grad_lapl_curr(k,i+1) = det_beta_grad_lapl_curr(k,i+1) +&
|
det_beta_grad_lapl_curr(k,i+1) = det_beta_grad_lapl_curr(k,i+1) +&
|
||||||
mo_grad_lapl(k,i+1,imo )*slater_matrix_beta_inv_det(l+1,j ) + &
|
mo_grad_lapl_beta(k,i+1,imo )*slater_matrix_beta_inv_det(l+1,j ) + &
|
||||||
mo_grad_lapl(k,i+1,imo2)*slater_matrix_beta_inv_det(l+1,j+1)
|
mo_grad_lapl_beta(k,i+1,imo2)*slater_matrix_beta_inv_det(l+1,j+1)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
i = elec_num
|
i = elec_num
|
||||||
l = elec_num-elec_alpha_num
|
l = elec_num-elec_alpha_num
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
det_beta_grad_lapl_curr(k,i) = det_beta_grad_lapl_curr(k,i) +&
|
det_beta_grad_lapl_curr(k,i) = det_beta_grad_lapl_curr(k,i) +&
|
||||||
mo_grad_lapl(k,i,imo )*slater_matrix_beta_inv_det(l,j ) + &
|
mo_grad_lapl_beta(k,i,imo )*slater_matrix_beta_inv_det(l,j ) + &
|
||||||
mo_grad_lapl(k,i,imo2)*slater_matrix_beta_inv_det(l,j+1)
|
mo_grad_lapl_beta(k,i,imo2)*slater_matrix_beta_inv_det(l,j+1)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
j = elec_beta_num
|
j = elec_beta_num
|
||||||
@ -1532,12 +1478,10 @@ BEGIN_PROVIDER [ double precision, det_beta_grad_lapl_curr, (4,elec_alpha_num+1
|
|||||||
!DIR$ LOOP COUNT (16)
|
!DIR$ LOOP COUNT (16)
|
||||||
do i=elec_alpha_num+1,elec_num
|
do i=elec_alpha_num+1,elec_num
|
||||||
l = i-elec_alpha_num
|
l = i-elec_alpha_num
|
||||||
!$OMP SIMD
|
|
||||||
do k=1,4
|
do k=1,4
|
||||||
det_beta_grad_lapl_curr(k,i) = det_beta_grad_lapl_curr(k,i) +&
|
det_beta_grad_lapl_curr(k,i) = det_beta_grad_lapl_curr(k,i) +&
|
||||||
mo_grad_lapl(k,i,imo)*slater_matrix_beta_inv_det(l,j)
|
mo_grad_lapl_beta(k,i,imo)*slater_matrix_beta_inv_det(l,j)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END SIMD
|
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
21
src/mo.irp.f
21
src/mo.irp.f
@ -349,18 +349,27 @@ BEGIN_PROVIDER [ double precision, mo_lapl, (elec_num_8,mo_num) ]
|
|||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
|
|
||||||
BEGIN_PROVIDER [ double precision, mo_grad_lapl, (4,elec_num,mo_num) ]
|
BEGIN_PROVIDER [ double precision, mo_grad_lapl_alpha, (4,elec_alpha_num,mo_num) ]
|
||||||
|
&BEGIN_PROVIDER [ double precision, mo_grad_lapl_beta , (4,elec_alpha_num+1:elec_num,mo_num) ]
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! Gradients and laplacian
|
! Gradients and laplacian
|
||||||
END_DOC
|
END_DOC
|
||||||
integer :: i,j
|
integer :: i,j
|
||||||
do j=1,mo_num
|
do j=1,mo_num
|
||||||
do i=1,elec_num
|
do i=1,elec_alpha_num
|
||||||
mo_grad_lapl(1,i,j) = mo_grad_transp_x(j,i)
|
mo_grad_lapl_alpha(1,i,j) = mo_grad_transp_x(j,i)
|
||||||
mo_grad_lapl(2,i,j) = mo_grad_transp_y(j,i)
|
mo_grad_lapl_alpha(2,i,j) = mo_grad_transp_y(j,i)
|
||||||
mo_grad_lapl(3,i,j) = mo_grad_transp_z(j,i)
|
mo_grad_lapl_alpha(3,i,j) = mo_grad_transp_z(j,i)
|
||||||
mo_grad_lapl(4,i,j) = mo_lapl_transp (j,i)
|
mo_grad_lapl_alpha(4,i,j) = mo_lapl_transp (j,i)
|
||||||
|
enddo
|
||||||
|
enddo
|
||||||
|
do j=1,mo_num
|
||||||
|
do i=elec_alpha_num+1,elec_num
|
||||||
|
mo_grad_lapl_beta(1,i,j) = mo_grad_transp_x(j,i)
|
||||||
|
mo_grad_lapl_beta(2,i,j) = mo_grad_transp_y(j,i)
|
||||||
|
mo_grad_lapl_beta(3,i,j) = mo_grad_transp_z(j,i)
|
||||||
|
mo_grad_lapl_beta(4,i,j) = mo_lapl_transp (j,i)
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user