9
1
mirror of https://github.com/QuantumPackage/qp2.git synced 2025-01-11 12:38:09 +01:00

added Overlap for general cGTOs

This commit is contained in:
AbdAmmar 2024-10-14 15:57:52 +02:00
parent 6edaaef524
commit fd51b73310
6 changed files with 159 additions and 123 deletions

View File

@ -1,10 +1,10 @@
! --- ! ---
BEGIN_PROVIDER [ double precision, ao_overlap , (ao_num, ao_num) ] BEGIN_PROVIDER [double precision, ao_overlap , (ao_num, ao_num)]
&BEGIN_PROVIDER [ double precision, ao_overlap_x, (ao_num, ao_num) ] &BEGIN_PROVIDER [double precision, ao_overlap_x, (ao_num, ao_num)]
&BEGIN_PROVIDER [ double precision, ao_overlap_y, (ao_num, ao_num) ] &BEGIN_PROVIDER [double precision, ao_overlap_y, (ao_num, ao_num)]
&BEGIN_PROVIDER [ double precision, ao_overlap_z, (ao_num, ao_num) ] &BEGIN_PROVIDER [double precision, ao_overlap_z, (ao_num, ao_num)]
BEGIN_DOC BEGIN_DOC
! Overlap between atomic basis functions: ! Overlap between atomic basis functions:
@ -48,7 +48,7 @@
!$OMP DEFAULT(NONE) & !$OMP DEFAULT(NONE) &
!$OMP PRIVATE(A_center,B_center,power_A,power_B,& !$OMP PRIVATE(A_center,B_center,power_A,power_B,&
!$OMP overlap_x,overlap_y, overlap_z, overlap, & !$OMP overlap_x,overlap_y, overlap_z, overlap, &
!$OMP alpha, beta,i,j,c) & !$OMP alpha, beta,i,j,n,l,c) &
!$OMP SHARED(nucl_coord,ao_power,ao_prim_num, & !$OMP SHARED(nucl_coord,ao_power,ao_prim_num, &
!$OMP ao_overlap_x,ao_overlap_y,ao_overlap_z,ao_overlap,ao_num,ao_coef_normalized_ordered_transp,ao_nucl, & !$OMP ao_overlap_x,ao_overlap_y,ao_overlap_z,ao_overlap,ao_num,ao_coef_normalized_ordered_transp,ao_nucl, &
!$OMP ao_expo_ordered_transp,dim1) !$OMP ao_expo_ordered_transp,dim1)

View File

@ -1,14 +1,14 @@
! --- ! ---
BEGIN_PROVIDER [double precision, ao_coef_norm_ord_transp_cgtos, (ao_prim_num_max, ao_num)] BEGIN_PROVIDER [double precision, ao_coef_cgtos_norm_ord_transp, (ao_prim_num_max, ao_num)]
implicit none implicit none
integer :: i, j integer :: i, j
do j = 1, ao_num do j = 1, ao_num
do i = 1, ao_prim_num_max do i = 1, ao_prim_num_max
ao_coef_norm_ord_transp_cgtos(i,j) = ao_coef_norm_ord_cgtos(j,i) ao_coef_cgtos_norm_ord_transp(i,j) = ao_coef_norm_cgtos_ord(j,i)
enddo enddo
enddo enddo
@ -16,14 +16,20 @@ END_PROVIDER
! --- ! ---
BEGIN_PROVIDER [complex*16, ao_expo_ord_transp_cgtos, (ao_prim_num_max, ao_num)] BEGIN_PROVIDER [complex*16, ao_expo_cgtos_ord_transp, (ao_prim_num_max, ao_num)]
&BEGIN_PROVIDER [complex*16, ao_expo_pw_ord_transp, (3, ao_prim_num_max, ao_num)]
&BEGIN_PROVIDER [complex*16, ao_expo_phase_ord_transp, (3, ao_prim_num_max, ao_num)]
implicit none implicit none
integer :: i, j integer :: i, j, m
do j = 1, ao_num do j = 1, ao_num
do i = 1, ao_prim_num_max do i = 1, ao_prim_num_max
ao_expo_ord_transp_cgtos(i,j) = ao_expo_ord_cgtos(j,i) ao_expo_cgtos_ord_transp(i,j) = ao_expo_cgtos_ord(j,i)
do m = 1, 3
ao_expo_pw_ord_transp(m,i,j) = ao_expo_pw_ord(m,j,i)
ao_expo_phase_ord_transp(m,i,j) = ao_expo_phase_ord(m,j,i)
enddo
enddo enddo
enddo enddo
@ -84,8 +90,8 @@ END_PROVIDER
! --- ! ---
BEGIN_PROVIDER [double precision, ao_coef_norm_ord_cgtos, (ao_num, ao_prim_num_max)] BEGIN_PROVIDER [double precision, ao_coef_norm_cgtos_ord, (ao_num, ao_prim_num_max)]
&BEGIN_PROVIDER [complex*16 , ao_expo_ord_cgtos, (ao_num, ao_prim_num_max)] &BEGIN_PROVIDER [complex*16 , ao_expo_cgtos_ord, (ao_num, ao_prim_num_max)]
&BEGIN_PROVIDER [double precision, ao_expo_pw_ord, (3, ao_num, ao_prim_num_max)] &BEGIN_PROVIDER [double precision, ao_expo_pw_ord, (3, ao_num, ao_prim_num_max)]
&BEGIN_PROVIDER [double precision, ao_expo_phase_ord, (3, ao_num, ao_prim_num_max)] &BEGIN_PROVIDER [double precision, ao_expo_phase_ord, (3, ao_num, ao_prim_num_max)]
@ -118,8 +124,8 @@ END_PROVIDER
enddo enddo
do j = 1, ao_prim_num(i) do j = 1, ao_prim_num(i)
ao_expo_ord_cgtos (i,j) = d(j,1) + (0.d0, 1.d0) * d(j,3) ao_expo_cgtos_ord (i,j) = d(j,1) + (0.d0, 1.d0) * d(j,3)
ao_coef_norm_ord_cgtos(i,j) = d(j,2) ao_coef_norm_cgtos_ord(i,j) = d(j,2)
ao_expo_pw_ord(i,j,1) = d(j,4) ao_expo_pw_ord(i,j,1) = d(j,4)
ao_expo_pw_ord(i,j,2) = d(j,5) ao_expo_pw_ord(i,j,2) = d(j,5)
ao_expo_pw_ord(i,j,3) = d(j,6) ao_expo_pw_ord(i,j,3) = d(j,6)
@ -139,9 +145,12 @@ END_PROVIDER
&BEGIN_PROVIDER [double precision, ao_overlap_cgtos_z, (ao_num, ao_num)] &BEGIN_PROVIDER [double precision, ao_overlap_cgtos_z, (ao_num, ao_num)]
implicit none implicit none
integer :: i, j, n, l, dim1, power_A(3), power_B(3)
integer :: i, j, m, n, l, ii, jj, dim1, power_A(3), power_B(3)
double precision :: c, overlap, overlap_x, overlap_y, overlap_z double precision :: c, overlap, overlap_x, overlap_y, overlap_z
complex*16 :: alpha, beta, A_center(3), B_center(3) complex*16 :: alpha, alpha_inv, A_center(3), KA2(3), phiA(3)
complex*16 :: beta, beta_inv, B_center(3), KB2(3), phiB(3)
complex*16 :: C1(1:4), C2(1:4)
complex*16 :: overlap1, overlap_x1, overlap_y1, overlap_z1 complex*16 :: overlap1, overlap_x1, overlap_y1, overlap_z1
complex*16 :: overlap2, overlap_x2, overlap_y2, overlap_z2 complex*16 :: overlap2, overlap_x2, overlap_y2, overlap_z2
@ -154,38 +163,65 @@ END_PROVIDER
!$OMP PARALLEL DO SCHEDULE(GUIDED) & !$OMP PARALLEL DO SCHEDULE(GUIDED) &
!$OMP DEFAULT(NONE) & !$OMP DEFAULT(NONE) &
!$OMP PRIVATE(A_center, B_center, power_A, power_B, alpha, beta, i, j, n, l, c, & !$OMP PRIVATE(i, j, m, n, l, ii, jj, c, C1, C2, &
!$OMP alpha, alpha_inv, A_center, power_A, KA2, phiA, &
!$OMP beta, beta_inv, B_center, power_B, KB2, phiB, &
!$OMP overlap_x , overlap_y , overlap_z , overlap, & !$OMP overlap_x , overlap_y , overlap_z , overlap, &
!$OMP overlap_x1, overlap_y1, overlap_z1, overlap1, & !$OMP overlap_x1, overlap_y1, overlap_z1, overlap1, &
!$OMP overlap_x2, overlap_y2, overlap_z2, overlap2) & !$OMP overlap_x2, overlap_y2, overlap_z2, overlap2) &
!$OMP SHARED(nucl_coord, ao_power, ao_prim_num, ao_num, ao_nucl, dim1, & !$OMP SHARED(nucl_coord, ao_power, ao_prim_num, ao_num, ao_nucl, dim1, &
!$OMP ao_overlap_cgtos_x, ao_overlap_cgtos_y, ao_overlap_cgtos_z, ao_overlap_cgtos, & !$OMP ao_coef_cgtos_norm_ord_transp, ao_expo_cgtos_ord_transp, &
!$OMP ao_coef_norm_ord_transp_cgtos, ao_expo_ord_transp_cgtos ) !$OMP ao_expo_pw_ord_transp, ao_expo_phase_ord_transp, &
!$OMP ao_overlap_cgtos_x, ao_overlap_cgtos_y, ao_overlap_cgtos_z, &
!$OMP ao_overlap_cgtos)
do j = 1, ao_num do j = 1, ao_num
A_center(1) = nucl_coord(ao_nucl(j),1) * (1.d0, 0.d0) jj = ao_nucl(j)
A_center(2) = nucl_coord(ao_nucl(j),2) * (1.d0, 0.d0)
A_center(3) = nucl_coord(ao_nucl(j),3) * (1.d0, 0.d0)
power_A(1) = ao_power(j,1) power_A(1) = ao_power(j,1)
power_A(2) = ao_power(j,2) power_A(2) = ao_power(j,2)
power_A(3) = ao_power(j,3) power_A(3) = ao_power(j,3)
do i = 1, ao_num do i = 1, ao_num
B_center(1) = nucl_coord(ao_nucl(i),1) * (1.d0, 0.d0) ii = ao_nucl(i)
B_center(2) = nucl_coord(ao_nucl(i),2) * (1.d0, 0.d0)
B_center(3) = nucl_coord(ao_nucl(i),3) * (1.d0, 0.d0)
power_B(1) = ao_power(i,1) power_B(1) = ao_power(i,1)
power_B(2) = ao_power(i,2) power_B(2) = ao_power(i,2)
power_B(3) = ao_power(i,3) power_B(3) = ao_power(i,3)
do n = 1, ao_prim_num(j) do n = 1, ao_prim_num(j)
alpha = ao_expo_ord_transp_cgtos(n,j)
alpha = ao_expo_cgtos_ord_transp(n,j)
alpha_inv = (1.d0, 0.d0) / alpha
do m = 1, 3
phiA(m) = ao_expo_phase_ord_transp(m,n,j)
A_center(m) = nucl_coord(jj,m) - (0.d0, 0.5d0) * alpha_inv * ao_expo_pw_ord_transp(m,n,j)
KA2(m) = ao_expo_pw_ord_transp(m,n,j) * ao_expo_pw_ord_transp(m,n,j)
enddo
do l = 1, ao_prim_num(i) do l = 1, ao_prim_num(i)
c = ao_coef_norm_ord_transp_cgtos(n,j) * ao_coef_norm_ord_transp_cgtos(l,i)
beta = ao_expo_ord_transp_cgtos(l,i) beta = ao_expo_cgtos_ord_transp(l,i)
beta_inv = (1.d0, 0.d0) / beta
do m = 1, 3
phiB(m) = ao_expo_phase_ord_transp(m,l,i)
B_center(m) = nucl_coord(ii,m) - (0.d0, 0.5d0) * beta_inv * ao_expo_pw_ord_transp(m,l,i)
KB2(m) = ao_expo_pw_ord_transp(m,l,i) * ao_expo_pw_ord_transp(m,l,i)
enddo
c = ao_coef_cgtos_norm_ord_transp(n,j) * ao_coef_cgtos_norm_ord_transp(l,i)
C1(1) = zexp((0.d0, 1.d0) * (-phiA(1) + phiB(1)) - 0.25d0 * (alpha_inv * KA2(1) + beta_inv * KB2(1)))
C1(2) = zexp((0.d0, 1.d0) * (-phiA(2) + phiB(2)) - 0.25d0 * (alpha_inv * KA2(2) + beta_inv * KB2(2)))
C1(3) = zexp((0.d0, 1.d0) * (-phiA(3) + phiB(3)) - 0.25d0 * (alpha_inv * KA2(3) + beta_inv * KB2(3)))
C1(4) = C1(1) * C1(2) * C1(3)
C2(1) = zexp((0.d0, 1.d0) * (phiA(1) + phiB(1)) - 0.25d0 * (conjg(alpha_inv) * KA2(1) + beta_inv * KB2(1)))
C2(2) = zexp((0.d0, 1.d0) * (phiA(2) + phiB(2)) - 0.25d0 * (conjg(alpha_inv) * KA2(2) + beta_inv * KB2(2)))
C2(3) = zexp((0.d0, 1.d0) * (phiA(3) + phiB(3)) - 0.25d0 * (conjg(alpha_inv) * KA2(3) + beta_inv * KB2(3)))
C2(4) = C2(1) * C2(2) * C2(3)
call overlap_cgaussian_xyz(A_center, B_center, alpha, beta, power_A, power_B, & call overlap_cgaussian_xyz(A_center, B_center, alpha, beta, power_A, power_B, &
overlap_x1, overlap_y1, overlap_z1, overlap1, dim1) overlap_x1, overlap_y1, overlap_z1, overlap1, dim1)
@ -193,14 +229,14 @@ END_PROVIDER
call overlap_cgaussian_xyz(A_center, B_center, conjg(alpha), beta, power_A, power_B, & call overlap_cgaussian_xyz(A_center, B_center, conjg(alpha), beta, power_A, power_B, &
overlap_x2, overlap_y2, overlap_z2, overlap2, dim1) overlap_x2, overlap_y2, overlap_z2, overlap2, dim1)
overlap_x = 2.d0 * real(overlap_x1 + overlap_x2) overlap_x = 2.d0 * real(C1(1) * overlap_x1 + C2(1) * overlap_x2)
overlap_y = 2.d0 * real(overlap_y1 + overlap_y2) overlap_y = 2.d0 * real(C1(2) * overlap_y1 + C2(2) * overlap_y2)
overlap_z = 2.d0 * real(overlap_z1 + overlap_z2) overlap_z = 2.d0 * real(C1(3) * overlap_z1 + C2(3) * overlap_z2)
overlap = 2.d0 * real(overlap1 + overlap2 ) overlap = 2.d0 * real(C1(4) * overlap1 + C2(4) * overlap2 )
ao_overlap_cgtos(i,j) = ao_overlap_cgtos(i,j) + c * overlap ao_overlap_cgtos(i,j) = ao_overlap_cgtos(i,j) + c * overlap
if( isnan(ao_overlap_cgtos(i,j)) ) then if(isnan(ao_overlap_cgtos(i,j))) then
print*,'i, j', i, j print*,'i, j', i, j
print*,'l, n', l, n print*,'l, n', l, n
print*,'c, overlap', c, overlap print*,'c, overlap', c, overlap

View File

@ -26,7 +26,7 @@ BEGIN_PROVIDER [ double precision, ao_integrals_n_e_cgtos, (ao_num, ao_num)]
!$OMP PRIVATE ( i, j, k, l, m, alpha, beta, A_center, B_center, C_center & !$OMP PRIVATE ( i, j, k, l, m, alpha, beta, A_center, B_center, C_center &
!$OMP , power_A, power_B, num_A, num_B, Z, c, c1, c2, n_pt_in ) & !$OMP , power_A, power_B, num_A, num_B, Z, c, c1, c2, n_pt_in ) &
!$OMP SHARED ( ao_num, ao_prim_num, ao_nucl, nucl_coord, ao_power, nucl_num, nucl_charge & !$OMP SHARED ( ao_num, ao_prim_num, ao_nucl, nucl_coord, ao_power, nucl_num, nucl_charge &
!$OMP , ao_expo_ord_transp_cgtos, ao_coef_norm_ord_transp_cgtos & !$OMP , ao_expo_cgtos_ord_transp, ao_coef_cgtos_norm_ord_transp &
!$OMP , n_pt_max_integrals, ao_integrals_n_e_cgtos ) !$OMP , n_pt_max_integrals, ao_integrals_n_e_cgtos )
n_pt_in = n_pt_max_integrals n_pt_in = n_pt_max_integrals
@ -44,10 +44,10 @@ BEGIN_PROVIDER [ double precision, ao_integrals_n_e_cgtos, (ao_num, ao_num)]
B_center(1:3) = nucl_coord(num_B,1:3) B_center(1:3) = nucl_coord(num_B,1:3)
do l = 1, ao_prim_num(j) do l = 1, ao_prim_num(j)
alpha = ao_expo_ord_transp_cgtos(l,j) alpha = ao_expo_cgtos_ord_transp(l,j)
do m = 1, ao_prim_num(i) do m = 1, ao_prim_num(i)
beta = ao_expo_ord_transp_cgtos(m,i) beta = ao_expo_cgtos_ord_transp(m,i)
c = 0.d0 c = 0.d0
do k = 1, nucl_num do k = 1, nucl_num
@ -74,8 +74,8 @@ BEGIN_PROVIDER [ double precision, ao_integrals_n_e_cgtos, (ao_num, ao_num)]
enddo enddo
ao_integrals_n_e_cgtos(i,j) = ao_integrals_n_e_cgtos(i,j) & ao_integrals_n_e_cgtos(i,j) = ao_integrals_n_e_cgtos(i,j) &
+ ao_coef_norm_ord_transp_cgtos(l,j) & + ao_coef_cgtos_norm_ord_transp(l,j) &
* ao_coef_norm_ord_transp_cgtos(m,i) * c * ao_coef_cgtos_norm_ord_transp(m,i) * c
enddo enddo
enddo enddo
enddo enddo

View File

@ -40,7 +40,7 @@
!$OMP , overlap_m2_1, overlap_p2_1, overlap_m2_2, overlap_p2_2 & !$OMP , overlap_m2_1, overlap_p2_1, overlap_m2_2, overlap_p2_2 &
!$OMP , overlap_x0_1, overlap_y0_1, overlap_z0_1, overlap_x0_2, overlap_y0_2, overlap_z0_2 ) & !$OMP , overlap_x0_1, overlap_y0_1, overlap_z0_1, overlap_x0_2, overlap_y0_2, overlap_z0_2 ) &
!$OMP SHARED( nucl_coord, ao_power, ao_prim_num, ao_num, ao_nucl, dim1 & !$OMP SHARED( nucl_coord, ao_power, ao_prim_num, ao_num, ao_nucl, dim1 &
!$OMP , ao_coef_norm_ord_transp_cgtos, ao_expo_ord_transp_cgtos & !$OMP , ao_coef_cgtos_norm_ord_transp, ao_expo_cgtos_ord_transp &
!$OMP , ao_deriv2_cgtos_x, ao_deriv2_cgtos_y, ao_deriv2_cgtos_z ) !$OMP , ao_deriv2_cgtos_x, ao_deriv2_cgtos_y, ao_deriv2_cgtos_z )
do j = 1, ao_num do j = 1, ao_num
@ -64,11 +64,11 @@
ao_deriv2_cgtos_z(i,j) = 0.d0 ao_deriv2_cgtos_z(i,j) = 0.d0
do n = 1, ao_prim_num(j) do n = 1, ao_prim_num(j)
alpha = ao_expo_ord_transp_cgtos(n,j) alpha = ao_expo_cgtos_ord_transp(n,j)
do l = 1, ao_prim_num(i) do l = 1, ao_prim_num(i)
c = ao_coef_norm_ord_transp_cgtos(n,j) * ao_coef_norm_ord_transp_cgtos(l,i) c = ao_coef_cgtos_norm_ord_transp(n,j) * ao_coef_cgtos_norm_ord_transp(l,i)
beta = ao_expo_ord_transp_cgtos(l,i) beta = ao_expo_cgtos_ord_transp(l,i)
call overlap_cgaussian_xyz( A_center, B_center, alpha, beta, power_A, power_B & call overlap_cgaussian_xyz( A_center, B_center, alpha, beta, power_A, power_B &
, overlap_x0_1, overlap_y0_1, overlap_z0_1, overlap, dim1 ) , overlap_x0_1, overlap_y0_1, overlap_z0_1, overlap, dim1 )

View File

@ -48,12 +48,12 @@ subroutine deb_ao_2eint_cgtos(i, j, k, l)
enddo enddo
do p = 1, ao_prim_num(i) do p = 1, ao_prim_num(i)
expo1 = ao_expo_ord_transp_cgtos(p,i) expo1 = ao_expo_cgtos_ord_transp(p,i)
!print*, "expo1 = ", expo1 !print*, "expo1 = ", expo1
!print*, "center1 = ", I_center !print*, "center1 = ", I_center
do q = 1, ao_prim_num(j) do q = 1, ao_prim_num(j)
expo2 = ao_expo_ord_transp_cgtos(q,j) expo2 = ao_expo_cgtos_ord_transp(q,j)
!print*, "expo2 = ", expo2 !print*, "expo2 = ", expo2
!print*, "center2 = ", J_center !print*, "center2 = ", J_center
@ -66,12 +66,12 @@ subroutine deb_ao_2eint_cgtos(i, j, k, l)
iorder_p2(1:3) = I_power(1:3) + J_power(1:3) iorder_p2(1:3) = I_power(1:3) + J_power(1:3)
do r = 1, ao_prim_num(k) do r = 1, ao_prim_num(k)
expo3 = ao_expo_ord_transp_cgtos(r,k) expo3 = ao_expo_cgtos_ord_transp(r,k)
!print*, "expo3 = ", expo3 !print*, "expo3 = ", expo3
!print*, "center3 = ", K_center !print*, "center3 = ", K_center
do s = 1, ao_prim_num(l) do s = 1, ao_prim_num(l)
expo4 = ao_expo_ord_transp_cgtos(s,l) expo4 = ao_expo_cgtos_ord_transp(s,l)
!print*, "expo4 = ", expo4 !print*, "expo4 = ", expo4
!print*, "center4 = ", L_center !print*, "center4 = ", L_center

View File

@ -60,12 +60,12 @@ double precision function ao_two_e_integral_cgtos(i, j, k, l)
enddo enddo
do p = 1, ao_prim_num(i) do p = 1, ao_prim_num(i)
coef1 = ao_coef_norm_ord_transp_cgtos(p,i) coef1 = ao_coef_cgtos_norm_ord_transp(p,i)
expo1 = ao_expo_ord_transp_cgtos(p,i) expo1 = ao_expo_cgtos_ord_transp(p,i)
do q = 1, ao_prim_num(j) do q = 1, ao_prim_num(j)
coef2 = coef1 * ao_coef_norm_ord_transp_cgtos(q,j) coef2 = coef1 * ao_coef_cgtos_norm_ord_transp(q,j)
expo2 = ao_expo_ord_transp_cgtos(q,j) expo2 = ao_expo_cgtos_ord_transp(q,j)
call give_explicit_cpoly_and_cgaussian(P1_new, P1_center, pp1, fact_p1, iorder_p1, & call give_explicit_cpoly_and_cgaussian(P1_new, P1_center, pp1, fact_p1, iorder_p1, &
expo1, expo2, I_power, J_power, I_center, J_center, dim1) expo1, expo2, I_power, J_power, I_center, J_center, dim1)
@ -76,12 +76,12 @@ double precision function ao_two_e_integral_cgtos(i, j, k, l)
p2_inv = (1.d0, 0.d0) / pp2 p2_inv = (1.d0, 0.d0) / pp2
do r = 1, ao_prim_num(k) do r = 1, ao_prim_num(k)
coef3 = coef2 * ao_coef_norm_ord_transp_cgtos(r,k) coef3 = coef2 * ao_coef_cgtos_norm_ord_transp(r,k)
expo3 = ao_expo_ord_transp_cgtos(r,k) expo3 = ao_expo_cgtos_ord_transp(r,k)
do s = 1, ao_prim_num(l) do s = 1, ao_prim_num(l)
coef4 = coef3 * ao_coef_norm_ord_transp_cgtos(s,l) coef4 = coef3 * ao_coef_cgtos_norm_ord_transp(s,l)
expo4 = ao_expo_ord_transp_cgtos(s,l) expo4 = ao_expo_cgtos_ord_transp(s,l)
call give_explicit_cpoly_and_cgaussian(Q1_new, Q1_center, qq1, fact_q1, iorder_q1, & call give_explicit_cpoly_and_cgaussian(Q1_new, Q1_center, qq1, fact_q1, iorder_q1, &
expo3, expo4, K_power, L_power, K_center, L_center, dim1) expo3, expo4, K_power, L_power, K_center, L_center, dim1)
@ -141,20 +141,20 @@ double precision function ao_two_e_integral_cgtos(i, j, k, l)
enddo enddo
do p = 1, ao_prim_num(i) do p = 1, ao_prim_num(i)
coef1 = ao_coef_norm_ord_transp_cgtos(p,i) coef1 = ao_coef_cgtos_norm_ord_transp(p,i)
expo1 = ao_expo_ord_transp_cgtos(p,i) expo1 = ao_expo_cgtos_ord_transp(p,i)
do q = 1, ao_prim_num(j) do q = 1, ao_prim_num(j)
coef2 = coef1 * ao_coef_norm_ord_transp_cgtos(q,j) coef2 = coef1 * ao_coef_cgtos_norm_ord_transp(q,j)
expo2 = ao_expo_ord_transp_cgtos(q,j) expo2 = ao_expo_cgtos_ord_transp(q,j)
do r = 1, ao_prim_num(k) do r = 1, ao_prim_num(k)
coef3 = coef2 * ao_coef_norm_ord_transp_cgtos(r,k) coef3 = coef2 * ao_coef_cgtos_norm_ord_transp(r,k)
expo3 = ao_expo_ord_transp_cgtos(r,k) expo3 = ao_expo_cgtos_ord_transp(r,k)
do s = 1, ao_prim_num(l) do s = 1, ao_prim_num(l)
coef4 = coef3 * ao_coef_norm_ord_transp_cgtos(s,l) coef4 = coef3 * ao_coef_cgtos_norm_ord_transp(s,l)
expo4 = ao_expo_ord_transp_cgtos(s,l) expo4 = ao_expo_cgtos_ord_transp(s,l)
integral1 = ERI_cgtos(expo1, expo2, expo3, expo4, & integral1 = ERI_cgtos(expo1, expo2, expo3, expo4, &
I_power(1), J_power(1), K_power(1), L_power(1), & I_power(1), J_power(1), K_power(1), L_power(1), &
@ -274,13 +274,13 @@ double precision function ao_2e_cgtos_schwartz_accel(i, j, k, l)
schwartz_kl(0,0) = 0.d0 schwartz_kl(0,0) = 0.d0
do r = 1, ao_prim_num(k) do r = 1, ao_prim_num(k)
coef1 = ao_coef_norm_ord_transp_cgtos(r,k) * ao_coef_norm_ord_transp_cgtos(r,k) coef1 = ao_coef_cgtos_norm_ord_transp(r,k) * ao_coef_cgtos_norm_ord_transp(r,k)
expo1 = ao_expo_ord_transp_cgtos(r,k) expo1 = ao_expo_cgtos_ord_transp(r,k)
schwartz_kl(0,r) = 0.d0 schwartz_kl(0,r) = 0.d0
do s = 1, ao_prim_num(l) do s = 1, ao_prim_num(l)
coef2 = coef1 * ao_coef_norm_ord_transp_cgtos(s,l) * ao_coef_norm_ord_transp_cgtos(s,l) coef2 = coef1 * ao_coef_cgtos_norm_ord_transp(s,l) * ao_coef_cgtos_norm_ord_transp(s,l)
expo2 = ao_expo_ord_transp_cgtos(s,l) expo2 = ao_expo_cgtos_ord_transp(s,l)
call give_explicit_cpoly_and_cgaussian(P1_new, P1_center, pp1, fact_p1, iorder_p1, & call give_explicit_cpoly_and_cgaussian(P1_new, P1_center, pp1, fact_p1, iorder_p1, &
expo1, expo2, K_power, L_power, K_center, L_center, dim1) expo1, expo2, K_power, L_power, K_center, L_center, dim1)
@ -334,12 +334,12 @@ double precision function ao_2e_cgtos_schwartz_accel(i, j, k, l)
do p = 1, ao_prim_num(i) do p = 1, ao_prim_num(i)
coef1 = ao_coef_norm_ord_transp_cgtos(p,i) coef1 = ao_coef_cgtos_norm_ord_transp(p,i)
expo1 = ao_expo_ord_transp_cgtos(p,i) expo1 = ao_expo_cgtos_ord_transp(p,i)
do q = 1, ao_prim_num(j) do q = 1, ao_prim_num(j)
coef2 = coef1 * ao_coef_norm_ord_transp_cgtos(q,j) coef2 = coef1 * ao_coef_cgtos_norm_ord_transp(q,j)
expo2 = ao_expo_ord_transp_cgtos(q,j) expo2 = ao_expo_cgtos_ord_transp(q,j)
call give_explicit_cpoly_and_cgaussian(P1_new, P1_center, pp1, fact_p1, iorder_p1, & call give_explicit_cpoly_and_cgaussian(P1_new, P1_center, pp1, fact_p1, iorder_p1, &
expo1, expo2, I_power, J_power, I_center, J_center, dim1) expo1, expo2, I_power, J_power, I_center, J_center, dim1)
@ -390,14 +390,14 @@ double precision function ao_2e_cgtos_schwartz_accel(i, j, k, l)
do r = 1, ao_prim_num(k) do r = 1, ao_prim_num(k)
if(schwartz_kl(0,r)*schwartz_ij < thr) cycle if(schwartz_kl(0,r)*schwartz_ij < thr) cycle
coef3 = coef2 * ao_coef_norm_ord_transp_cgtos(r,k) coef3 = coef2 * ao_coef_cgtos_norm_ord_transp(r,k)
expo3 = ao_expo_ord_transp_cgtos(r,k) expo3 = ao_expo_cgtos_ord_transp(r,k)
do s = 1, ao_prim_num(l) do s = 1, ao_prim_num(l)
if(schwartz_kl(s,r)*schwartz_ij < thr) cycle if(schwartz_kl(s,r)*schwartz_ij < thr) cycle
coef4 = coef3 * ao_coef_norm_ord_transp_cgtos(s,l) coef4 = coef3 * ao_coef_cgtos_norm_ord_transp(s,l)
expo4 = ao_expo_ord_transp_cgtos(s,l) expo4 = ao_expo_cgtos_ord_transp(s,l)
call give_explicit_cpoly_and_cgaussian(Q1_new, Q1_center, qq1, fact_q1, iorder_q1, & call give_explicit_cpoly_and_cgaussian(Q1_new, Q1_center, qq1, fact_q1, iorder_q1, &
expo3, expo4, K_power, L_power, K_center, L_center, dim1) expo3, expo4, K_power, L_power, K_center, L_center, dim1)
@ -458,13 +458,13 @@ double precision function ao_2e_cgtos_schwartz_accel(i, j, k, l)
schwartz_kl(0,0) = 0.d0 schwartz_kl(0,0) = 0.d0
do r = 1, ao_prim_num(k) do r = 1, ao_prim_num(k)
coef1 = ao_coef_norm_ord_transp_cgtos(r,k) * ao_coef_norm_ord_transp_cgtos(r,k) coef1 = ao_coef_cgtos_norm_ord_transp(r,k) * ao_coef_cgtos_norm_ord_transp(r,k)
expo1 = ao_expo_ord_transp_cgtos(r,k) expo1 = ao_expo_cgtos_ord_transp(r,k)
schwartz_kl(0,r) = 0.d0 schwartz_kl(0,r) = 0.d0
do s = 1, ao_prim_num(l) do s = 1, ao_prim_num(l)
coef2 = coef1 * ao_coef_norm_ord_transp_cgtos(s,l) * ao_coef_norm_ord_transp_cgtos(s,l) coef2 = coef1 * ao_coef_cgtos_norm_ord_transp(s,l) * ao_coef_cgtos_norm_ord_transp(s,l)
expo2 = ao_expo_ord_transp_cgtos(s,l) expo2 = ao_expo_cgtos_ord_transp(s,l)
integral1 = ERI_cgtos(expo1, expo2, expo1, expo2, & integral1 = ERI_cgtos(expo1, expo2, expo1, expo2, &
K_power(1), L_power(1), K_power(1), L_power(1), & K_power(1), L_power(1), K_power(1), L_power(1), &
@ -517,12 +517,12 @@ double precision function ao_2e_cgtos_schwartz_accel(i, j, k, l)
enddo enddo
do p = 1, ao_prim_num(i) do p = 1, ao_prim_num(i)
coef1 = ao_coef_norm_ord_transp_cgtos(p,i) coef1 = ao_coef_cgtos_norm_ord_transp(p,i)
expo1 = ao_expo_ord_transp_cgtos(p,i) expo1 = ao_expo_cgtos_ord_transp(p,i)
do q = 1, ao_prim_num(j) do q = 1, ao_prim_num(j)
coef2 = coef1 * ao_coef_norm_ord_transp_cgtos(q,j) coef2 = coef1 * ao_coef_cgtos_norm_ord_transp(q,j)
expo2 = ao_expo_ord_transp_cgtos(q,j) expo2 = ao_expo_cgtos_ord_transp(q,j)
integral1 = ERI_cgtos(expo1, expo2, expo1, expo2, & integral1 = ERI_cgtos(expo1, expo2, expo1, expo2, &
I_power(1), J_power(1), I_power(1), J_power(1), & I_power(1), J_power(1), I_power(1), J_power(1), &
@ -572,14 +572,14 @@ double precision function ao_2e_cgtos_schwartz_accel(i, j, k, l)
do r = 1, ao_prim_num(k) do r = 1, ao_prim_num(k)
if(schwartz_kl(0,r)*schwartz_ij < thr) cycle if(schwartz_kl(0,r)*schwartz_ij < thr) cycle
coef3 = coef2 * ao_coef_norm_ord_transp_cgtos(r,k) coef3 = coef2 * ao_coef_cgtos_norm_ord_transp(r,k)
expo3 = ao_expo_ord_transp_cgtos(r,k) expo3 = ao_expo_cgtos_ord_transp(r,k)
do s = 1, ao_prim_num(l) do s = 1, ao_prim_num(l)
if(schwartz_kl(s,r)*schwartz_ij < thr) cycle if(schwartz_kl(s,r)*schwartz_ij < thr) cycle
coef4 = coef3 * ao_coef_norm_ord_transp_cgtos(s,l) coef4 = coef3 * ao_coef_cgtos_norm_ord_transp(s,l)
expo4 = ao_expo_ord_transp_cgtos(s,l) expo4 = ao_expo_cgtos_ord_transp(s,l)
integral1 = ERI_cgtos(expo1, expo2, expo3, expo4, & integral1 = ERI_cgtos(expo1, expo2, expo3, expo4, &
I_power(1), J_power(1), K_power(1), L_power(1), & I_power(1), J_power(1), K_power(1), L_power(1), &