37 #include "../base/base_uses.f90"
43 LOGICAL,
PRIVATE,
PARAMETER :: debug_this_module = .false.
45 CHARACTER(len=*),
PARAMETER,
PRIVATE :: moduleN =
'eri_mme_integrate'
71 hab, o1, o2, G_count, R_count, normalize, potential, pot_par)
72 TYPE(eri_mme_param),
INTENT(IN) :: param
73 INTEGER,
INTENT(IN) :: la_min, la_max, lb_min, lb_max
74 REAL(kind=
dp),
INTENT(IN) :: zeta, zetb
75 REAL(kind=
dp),
DIMENSION(3),
INTENT(IN) :: rab
76 REAL(kind=
dp),
DIMENSION(:, :),
INTENT(INOUT) :: hab
77 INTEGER,
INTENT(IN) :: o1, o2
78 INTEGER,
INTENT(INOUT),
OPTIONAL :: g_count, r_count
79 LOGICAL,
INTENT(IN),
OPTIONAL :: normalize
80 INTEGER,
INTENT(IN),
OPTIONAL :: potential
81 REAL(kind=
dp),
INTENT(IN),
OPTIONAL :: pot_par
83 INTEGER :: ax, ay, az, bx, by, bz, grid, i_aw, &
84 i_xyz, ico, jco, l_max, la, lb, n_aw
85 INTEGER(KIND=int_8),
DIMENSION(2) :: n_sum_3d
86 INTEGER(KIND=int_8),
DIMENSION(2, 3) :: n_sum_1d
87 INTEGER,
DIMENSION(3) :: la_xyz, lb_xyz
88 LOGICAL :: do_g_sum, exact, is_ortho, norm
89 REAL(kind=
dp) :: alpha_g, alpha_r, cutoff, g_rad, g_res, &
90 imm, inv_lgth, ixyz, lgth, max_error, &
91 prefac, r_rad, r_res, vol
92 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:) :: s_g_1, s_g_2, s_g_no, s_g_no_h
93 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:, :, :) :: s_g
94 REAL(kind=
dp),
DIMENSION(3) :: g_bounds, r_bounds
95 REAL(kind=
dp),
DIMENSION(3, 3) :: h_inv, hmat
96 REAL(kind=
dp),
DIMENSION(:),
POINTER :: aw
98 cpassert(param%is_valid)
101 CALL eri_mme_2c_get_rads(la_max, lb_max, zeta, zetb, 0.0_dp, param%G_min, param%R_min, param%sum_precision, &
106 cpassert(grid .GT. 0)
113 IF (
PRESENT(normalize))
THEN
119 l_max = la_max + lb_max
121 IF (
PRESENT(potential))
THEN
130 is_ortho = param%is_ortho
134 ALLOCATE (s_g(0:l_max, 3, n_aw))
137 IF (param%debug)
THEN
138 ALLOCATE (s_g_1(0:l_max))
139 ALLOCATE (s_g_2(0:l_max))
142 ALLOCATE (s_g_no(
ncoset(l_max)))
144 ALLOCATE (s_g_no_h(
ncoset(l_max)))
148 alpha_g = 0.25_dp/zeta + 0.25_dp/zetb
150 g_res = 0.5_dp*param%G_min
151 r_res = 0.5_dp*param%R_min
153 g_rad =
exp_radius(l_max, alpha_g, 0.01*param%sum_precision, 1.0_dp, epsabs=g_res)
155 CALL pgf_sum_2c_gspace_3d(s_g_no, l_max, -rab, alpha_g, h_inv, g_bounds, g_rad, vol, potential, pot_par)
161 zeta, zetb, aw(i_aw), param%sum_precision, n_sum_1d, n_sum_3d, &
162 g_bounds, g_rad, r_bounds, r_rad)
163 alpha_g = aw(i_aw) + 0.25_dp/zeta + 0.25_dp/zetb
164 alpha_r = 0.25_dp/alpha_g
170 lgth = abs(hmat(i_xyz, i_xyz))
171 inv_lgth = abs(h_inv(i_xyz, i_xyz))
174 do_g_sum = n_sum_1d(1, i_xyz) < n_sum_1d(2, i_xyz)
178 IF (
PRESENT(g_count)) g_count = g_count + 1
181 IF (
PRESENT(r_count)) r_count = r_count + 1
184 IF (param%debug)
THEN
188 max_error = maxval(abs(s_g_1 - s_g_2)/(0.5_dp*(abs(s_g_1) + abs(s_g_2)) + 1.0_dp))
190 cpassert(max_error .LE. param%debug_delta)
196 do_g_sum = n_sum_3d(1) < n_sum_3d(2)
200 IF (
PRESENT(g_count)) g_count = g_count + 1
203 IF (
PRESENT(r_count)) r_count = r_count + 1
205 s_g_no(:) = s_g_no(:) + aw(n_aw + i_aw)*s_g_no_h
211 prefac = sqrt(1.0_dp/(zeta*zetb))
215 CALL get_l(jco, lb, bx, by, bz)
216 lb_xyz = [bx, by, bz]
218 CALL get_l(ico, la, ax, ay, az)
219 la_xyz = [ax, ay, az]
225 ixyz = ixyz*s_g(la_xyz(i_xyz) + lb_xyz(i_xyz), i_xyz, i_aw)*prefac
227 imm = imm + aw(n_aw + i_aw)*ixyz
230 imm = s_g_no(
coset(ax + bx, ay + by, az + bz))*prefac**3
232 IF (la + lb .EQ. 0 .AND. .NOT. exact)
THEN
233 imm = imm - sum(aw(n_aw + 1:2*n_aw))*prefac**3/vol
238 hab(o1 + ico, o2 + jco) = imm*4.0_dp*
pi**4/((2.0_dp*zeta)**la*(-2.0_dp*zetb)**lb)
272 SUBROUTINE eri_mme_3c_integrate(param, la_min, la_max, lb_min, lb_max, lc_min, lc_max, zeta, zetb, zetc, RA, RB, RC, &
273 habc, o1, o2, o3, GG_count, GR_count, RR_count)
274 TYPE(eri_mme_param),
INTENT(IN) :: param
275 INTEGER,
INTENT(IN) :: la_min, la_max, lb_min, lb_max, lc_min, &
277 REAL(kind=
dp),
INTENT(IN) :: zeta, zetb, zetc
278 REAL(kind=
dp),
DIMENSION(3),
INTENT(IN) :: ra, rb, rc
279 REAL(kind=
dp),
DIMENSION(:, :, :),
INTENT(INOUT) :: habc
280 INTEGER,
INTENT(IN) :: o1, o2, o3
281 INTEGER,
INTENT(INOUT),
OPTIONAL :: gg_count, gr_count, rr_count
283 cpassert(param%is_valid)
284 IF (param%is_ortho)
THEN
285 CALL eri_mme_3c_integrate_ortho(param, la_min, la_max, lb_min, lb_max, lc_min, lc_max, zeta, zetb, zetc, ra, rb, rc, &
286 habc, o1, o2, o3, rr_count)
289 CALL eri_mme_3c_integrate_nonortho(param, la_min, la_max, lb_min, lb_max, lc_min, lc_max, zeta, zetb, zetc, ra, rb, rc, &
290 habc, o1, o2, o3, gg_count, gr_count, rr_count)
316 SUBROUTINE eri_mme_3c_integrate_ortho(param, la_min, la_max, lb_min, lb_max, lc_min, lc_max, zeta, zetb, zetc, RA, RB, RC, &
317 habc, o1, o2, o3, RR_count)
318 TYPE(eri_mme_param),
INTENT(IN) :: param
319 INTEGER,
INTENT(IN) :: la_min, la_max, lb_min, lb_max, lc_min, &
321 REAL(kind=
dp),
INTENT(IN) :: zeta, zetb, zetc
322 REAL(kind=
dp),
DIMENSION(3),
INTENT(IN) :: ra, rb, rc
323 REAL(kind=
dp),
DIMENSION(:, :, :),
INTENT(INOUT) :: habc
324 INTEGER,
INTENT(IN) :: o1, o2, o3
325 INTEGER,
INTENT(INOUT),
OPTIONAL :: rr_count
327 INTEGER :: grid, i_aw, lmax_0, n_aw
328 INTEGER(KIND=int_8),
DIMENSION(3) :: n_sum_3d
329 INTEGER(KIND=int_8),
DIMENSION(3, 3) :: n_sum_1d
330 REAL(kind=
dp) :: alpha_r_0, cutoff, g_res, lgth, prefac, &
332 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:, :) :: s_g_0
333 REAL(kind=
dp),
ALLOCATABLE, &
334 DIMENSION(:, :, :, :, :) :: s_g
335 REAL(kind=
dp),
DIMENSION(2) :: r_rads_3
336 REAL(kind=
dp),
DIMENSION(2, 3) :: r_bounds_3
337 REAL(kind=
dp),
DIMENSION(3) :: g_rads_1, r_rads_2
338 REAL(kind=
dp),
DIMENSION(3, 3) :: g_bounds_1, h_inv, hmat, r_bounds_2
339 REAL(kind=
dp),
DIMENSION(:),
POINTER :: aw
343 CALL eri_mme_3c_get_rads(la_max, lb_max, lc_max, zeta, zetb, zetc, 0.0_dp, param%G_min, param%R_min, &
344 param%sum_precision, g_rads_1=g_rads_1)
346 cutoff = (min(g_rads_1(1), g_rads_1(2) + g_rads_1(3)))**2/2
350 cpassert(grid .GT. 0)
353 n_aw = param%minimax_grid(grid)%n_minimax
354 aw => param%minimax_grid(grid)%minimax_aw
362 prefac = (zeta*zetb*zetc)**(-1.5_dp)*
pi**(11.0_dp/2.0_dp)*4.0_dp
365 g_res = 0.5_dp*param%G_min
366 r_res = 0.5_dp*param%R_min
368 ALLOCATE (s_g(n_aw, 3, 0:la_max, 0:lb_max, 0:lc_max))
371 IF (lc_min == 0)
THEN
372 ALLOCATE (s_g_0(0:la_max + lb_max, 3))
374 alpha_r_0 = zeta*zetb/(zeta + zetb)
375 lmax_0 = la_max + lb_max
376 r_rad_0 =
exp_radius(lmax_0, alpha_r_0, param%sum_precision, 1.0_dp, epsabs=r_res)
378 lgth = abs(hmat(1, 1))
380 lgth = abs(hmat(2, 2))
382 lgth = abs(hmat(3, 3))
387 CALL eri_mme_3c_get_bounds(hmat, h_inv, vol, .true., param%G_min, param%R_min, la_max, lb_max, lc_max, &
388 zeta, zetb, zetc, aw(i_aw), param%sum_precision, n_sum_1d, n_sum_3d, &
389 g_bounds_1, g_rads_1, r_bounds_2, r_rads_2, r_bounds_3, r_rads_3)
390 CALL pgf_sum_3c_1d(s_g(i_aw, 1, :, :, :), ra(1), rb(1), rc(1), &
391 zeta, zetb, zetc, aw(i_aw), abs(hmat(1, 1)), &
394 CALL pgf_sum_3c_1d(s_g(i_aw, 2, :, :, :), ra(2), rb(2), rc(2), &
395 zeta, zetb, zetc, aw(i_aw), abs(hmat(2, 2)), &
398 CALL pgf_sum_3c_1d(s_g(i_aw, 3, :, :, :), ra(3), rb(3), rc(3), &
399 zeta, zetb, zetc, aw(i_aw), abs(hmat(3, 3)), &
402 IF (
PRESENT(rr_count)) rr_count = rr_count + 3
405 CALL eri_mme_3c_collect_ortho(vol, la_min, la_max, lb_min, lb_max, lc_min, lc_max, &
406 zeta, zetb, zetc, n_aw, aw, s_g, s_g_0, prefac, habc, o1, o2, o3)
433 SUBROUTINE eri_mme_3c_integrate_nonortho(param, la_min, la_max, lb_min, lb_max, lc_min, lc_max, zeta, zetb, zetc, RA, RB, RC, &
434 habc, o1, o2, o3, GG_count, GR_count, RR_count)
436 TYPE(eri_mme_param),
INTENT(IN) :: param
437 INTEGER,
INTENT(IN) :: la_min, la_max, lb_min, lb_max, lc_min, &
439 REAL(kind=
dp),
INTENT(IN) :: zeta, zetb, zetc
440 REAL(kind=
dp),
DIMENSION(3),
INTENT(IN) :: ra, rb, rc
441 REAL(kind=
dp),
DIMENSION(:, :, :),
INTENT(INOUT) :: habc
442 INTEGER,
INTENT(IN) :: o1, o2, o3
443 INTEGER,
INTENT(INOUT),
OPTIONAL :: gg_count, gr_count, rr_count
445 INTEGER :: ax, ay, az, bx, by, bz, cx, cy, cz, &
446 grid, i_aw, ico, ir, jco, kco, la, lb, &
447 lc, lmax_0, method, n_aw, nresults, &
449 INTEGER(KIND=int_8),
DIMENSION(3) :: n_sum_3d
450 INTEGER(KIND=int_8),
DIMENSION(3, 3) :: n_sum_1d
451 LOGICAL :: db_sum1, db_sum2, db_sum3, do_g_sum_0
452 REAL(kind=
dp) :: alpha_g_0, alpha_r_0, cutoff, g_rad_0, &
453 g_res, max_error, max_result, &
454 min_result, prefac, r_rad_0, r_res, vol
455 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:) :: results_no, s_g_0_no
456 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:, :, :) :: s_g_no, s_g_no_1, s_g_no_2, s_g_no_3, &
458 REAL(kind=
dp),
DIMENSION(2) :: r_rads_3
459 REAL(kind=
dp),
DIMENSION(2, 3) :: r_bounds_3
460 REAL(kind=
dp),
DIMENSION(3) :: g_bound_0, g_rads_1, r_0, r_bound_0, &
462 REAL(kind=
dp),
DIMENSION(3, 3) :: g_bounds_1, h_inv, hmat, r_bounds_2
463 REAL(kind=
dp),
DIMENSION(:),
POINTER :: aw
465 cpassert(param%is_valid)
469 CALL eri_mme_3c_get_rads(la_max, lb_max, lc_max, zeta, zetb, zetc, 0.0_dp, param%G_min, param%R_min, &
470 param%sum_precision, g_rads_1=g_rads_1)
472 cutoff = (min(g_rads_1(1), g_rads_1(2) + g_rads_1(3)))**2/2
476 cpassert(grid .GT. 0)
479 n_aw = param%minimax_grid(grid)%n_minimax
480 aw => param%minimax_grid(grid)%minimax_aw
488 prefac = (zeta*zetb*zetc)**(-1.5_dp)*
pi**(11.0_dp/2.0_dp)*4.0_dp
490 IF (param%debug)
THEN
497 g_res = 0.5_dp*param%G_min
498 r_res = 0.5_dp*param%R_min
502 s_g_no(:, :, :) = 0.0_dp
503 IF (param%debug)
THEN
504 s_g_no_1(:, :, :) = -1.0_dp
505 s_g_no_2(:, :, :) = -1.0_dp
506 s_g_no_3(:, :, :) = -1.0_dp
511 IF (lc_min == 0)
THEN
512 ALLOCATE (s_g_0_no(
ncoset(la_max + lb_max)))
513 alpha_g_0 = 0.25_dp/zetb + 0.25_dp/zeta
514 alpha_r_0 = 0.25_dp/alpha_g_0
515 lmax_0 = la_max + lb_max
517 g_rad_0 =
exp_radius(lmax_0, alpha_g_0, param%sum_precision, 1.0_dp, epsabs=g_res)
518 r_rad_0 =
exp_radius(lmax_0, alpha_r_0, param%sum_precision, 1.0_dp, epsabs=r_res)
521 do_g_sum_0 = product(2*r_bound_0 + 1) .GT. product(2*g_bound_0 + 1)
530 CALL eri_mme_3c_get_bounds(hmat, h_inv, vol, .false., param%G_min, param%R_min, la_max, lb_max, lc_max, &
531 zeta, zetb, zetc, aw(i_aw), param%sum_precision, n_sum_1d, n_sum_3d, &
532 g_bounds_1, g_rads_1, r_bounds_2, r_rads_2, r_bounds_3, r_rads_3)
533 sum_method = minloc(n_sum_3d, dim=1)
535 CALL pgf_sum_3c_3d(s_g_no_h, la_max, lb_max, lc_max, ra, rb, rc, &
536 zeta, zetb, zetc, aw(i_aw), hmat, h_inv, vol, &
537 g_bounds_1, r_bounds_2, r_bounds_3, &
538 g_rads_1, r_rads_2, r_rads_3, &
539 method=sum_method, method_out=method)
540 s_g_no(:, :, :) = s_g_no(:, :, :) + aw(n_aw + i_aw)*s_g_no_h(:, :, :)
544 IF (
PRESENT(gg_count)) gg_count = gg_count + 1
546 IF (
PRESENT(gr_count)) gr_count = gr_count + 1
548 IF (
PRESENT(rr_count)) rr_count = rr_count + 1
553 IF (param%debug)
THEN
557 db_sum1 = (n_sum_3d(1)) .LT. int(param%debug_nsum, kind=
int_8)
558 db_sum2 = (n_sum_3d(2)) .LT. int(param%debug_nsum, kind=
int_8)
559 db_sum3 = (n_sum_3d(3)) .LT. int(param%debug_nsum, kind=
int_8)
561 IF (param%unit_nr > 0)
THEN
562 WRITE (param%unit_nr, *)
"ERI_MME DEBUG | number of summands (GG / GR / RR)", n_sum_3d
563 WRITE (param%unit_nr, *)
"ERI_MME DEBUG | sum methods to be compared (GG / GR / RR)", db_sum1, db_sum2, db_sum3
566 s_g_no_1(:, :, :) = 0.0_dp
567 s_g_no_2(:, :, :) = 0.0_dp
568 s_g_no_3(:, :, :) = 0.0_dp
571 CALL pgf_sum_3c_3d(s_g_no_1, la_max, lb_max, lc_max, ra, rb, rc, &
572 zeta, zetb, zetc, aw(i_aw), hmat, h_inv, vol, &
573 g_bounds_1, r_bounds_2, r_bounds_3, &
574 g_rads_1, r_rads_2, r_rads_3, &
576 nresults = nresults + 1
580 CALL pgf_sum_3c_3d(s_g_no_2, la_max, lb_max, lc_max, ra, rb, rc, &
581 zeta, zetb, zetc, aw(i_aw), hmat, h_inv, vol, &
582 g_bounds_1, r_bounds_2, r_bounds_3, &
583 g_rads_1, r_rads_2, r_rads_3, &
585 nresults = nresults + 1
589 CALL pgf_sum_3c_3d(s_g_no_3, la_max, lb_max, lc_max, ra, rb, rc, &
590 zeta, zetb, zetc, aw(i_aw), hmat, h_inv, vol, &
591 g_bounds_1, r_bounds_2, r_bounds_3, &
592 g_rads_1, r_rads_2, r_rads_3, &
594 nresults = nresults + 1
598 ALLOCATE (results_no(nresults))
601 CALL get_l(kco, lc, cx, cy, cz)
603 CALL get_l(jco, lb, bx, by, bz)
605 CALL get_l(ico, la, ax, ay, az)
611 results_no(ir) = s_g_no_1(ico, jco, kco)
616 results_no(ir) = s_g_no_2(ico, jco, kco)
621 results_no(ir) = s_g_no_3(ico, jco, kco)
624 max_result = maxval(results_no)
625 min_result = minval(results_no)
626 IF (nresults > 0) max_error = max(max_error, &
627 (max_result - min_result)/(0.5_dp*(abs(max_result) + abs(min_result)) + 1.0_dp))
632 cpassert(max_error .LE. param%debug_delta)
633 DEALLOCATE (results_no)
639 CALL eri_mme_3c_collect_nonortho(vol, la_min, la_max, lb_min, lb_max, lc_min, lc_max, &
640 zeta, zetb, zetc, n_aw, aw, s_g_no, s_g_0_no, prefac, habc, o1, o2, o3)
666 SUBROUTINE eri_mme_3c_collect_ortho(vol, la_min, la_max, lb_min, lb_max, lc_min, lc_max, &
667 zeta, zetb, zetc, n_aw, aw, S_G, S_G_0, prefac, habc, o1, o2, o3)
668 REAL(kind=
dp),
INTENT(IN) :: vol
669 INTEGER,
INTENT(IN) :: la_min, la_max, lb_min, lb_max, lc_min, &
671 REAL(kind=
dp),
INTENT(IN) :: zeta, zetb, zetc
672 INTEGER,
INTENT(IN) :: n_aw
673 REAL(kind=
dp),
DIMENSION(2*n_aw),
INTENT(IN) :: aw
674 REAL(kind=
dp),
DIMENSION(:, :, 0:, 0:, 0:), &
676 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:, :), &
678 REAL(kind=
dp),
INTENT(IN) :: prefac
679 REAL(kind=
dp),
DIMENSION(:, :, :),
INTENT(INOUT) :: habc
680 INTEGER,
INTENT(IN) :: o1, o2, o3
682 INTEGER :: ax, ay, az, bx, by, bz, cx, cy, cz, ico, &
683 jco, kco, la, la_prev, lb, lb_prev, &
685 REAL(kind=
dp) :: imm, ixyz_0, mone_lb, resc_a, &
686 resc_a_init, resc_b, resc_b_init, &
690 resc_a_init = (2.0_dp*zeta)**la_min
691 resc_b_init = (2.0_dp*zetb)**lb_min
692 resc_c_init = (2.0_dp*zetc)**lc_min
697 CALL get_l(kco, lc, cx, cy, cz)
698 IF (lc_prev < lc) resc_c = resc_c*(2.0_dp*zetc)
703 CALL get_l(jco, lb, bx, by, bz)
704 mone_lb = (-1.0_dp)**lb
705 IF (lb_prev < lb) resc_b = resc_b*(2.0_dp*zetb)
710 CALL get_l(ico, la, ax, ay, az)
712 IF (la_prev < la) resc_a = resc_a*(2.0_dp*zeta)
715 ixyz_0 = s_g_0(ax + bx, 1)* &
720 imm = sum(aw(n_aw + 1:2*n_aw)*( &
721 s_g(1:n_aw, 1, ax, bx, cx)* &
722 s_g(1:n_aw, 2, ay, by, cy)* &
723 s_g(1:n_aw, 3, az, bz, cz)) - ixyz_0)
726 habc(o1 + ico, o2 + jco, o3 + kco) = imm*prefac/(resc_a*resc_b*resc_c)
758 PURE SUBROUTINE eri_mme_3c_collect_nonortho(vol, la_min, la_max, lb_min, lb_max, lc_min, lc_max, &
759 zeta, zetb, zetc, n_aw, aw, S_G, S_G_0, prefac, habc, o1, o2, o3)
760 REAL(kind=
dp),
INTENT(IN) :: vol
761 INTEGER,
INTENT(IN) :: la_min, la_max, lb_min, lb_max, lc_min, &
763 REAL(kind=
dp),
INTENT(IN) :: zeta, zetb, zetc
764 INTEGER,
INTENT(IN) :: n_aw
765 REAL(kind=
dp),
DIMENSION(2*n_aw),
INTENT(IN) :: aw
766 REAL(kind=
dp),
DIMENSION(:, :, :),
INTENT(IN) :: s_g
767 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:), &
769 REAL(kind=
dp),
INTENT(IN) :: prefac
770 REAL(kind=
dp),
DIMENSION(:, :, :),
INTENT(INOUT) :: habc
771 INTEGER,
INTENT(IN) :: o1, o2, o3
773 INTEGER :: ax, ay, az, bx, by, bz, cx, cy, cz, ico, &
774 ijco, jco, kco, la, la_prev, lb, &
776 REAL(kind=
dp) :: imm, mone_lb, resc_a, resc_a_init, &
777 resc_b, resc_b_init, resc_c, &
781 resc_a_init = (2.0_dp*zeta)**la_min
782 resc_b_init = (2.0_dp*zetb)**lb_min
783 resc_c_init = (2.0_dp*zetc)**lc_min
788 CALL get_l(kco, lc, cx, cy, cz)
789 IF (lc_prev < lc) resc_c = resc_c*(2.0_dp*zetc)
794 CALL get_l(jco, lb, bx, by, bz)
795 mone_lb = (-1.0_dp)**lb
796 IF (lb_prev < lb) resc_b = resc_b*(2.0_dp*zetb)
801 CALL get_l(ico, la, ax, ay, az)
803 IF (la_prev < la) resc_a = resc_a*(2.0_dp*zeta)
805 imm = s_g(ico, jco, kco)
807 ijco =
coset(ax + bx, ay + by, az + bz)
808 imm = s_g(ico, jco, kco) - sum(aw(n_aw + 1:2*n_aw))*s_g_0(ijco)/vol*mone_lb
812 habc(o1 + ico, o2 + jco, o3 + kco) = imm*prefac/(resc_a*resc_b*resc_c)
All kind of helpful little routines.
real(kind=dp) function, public exp_radius(l, alpha, threshold, prefactor, epsabs, epsrel, rlow)
The radius of a primitive Gaussian function for a given threshold is calculated. g(r) = prefactor*r**...
Methods related to properties of Hermite and Cartesian Gaussian functions.
pure real(kind=dp) function, public hermite_gauss_norm(zet, l)
Norm of 1d Hermite-Gauss functions.
Minimax-Ewald (MME) method for calculating 2-center and 3-center electron repulsion integrals (ERI) o...
subroutine, public eri_mme_2c_integrate(param, la_min, la_max, lb_min, lb_max, zeta, zetb, rab, hab, o1, o2, G_count, R_count, normalize, potential, pot_par)
Low-level integration routine for 2-center ERIs.
subroutine, public eri_mme_3c_integrate(param, la_min, la_max, lb_min, lb_max, lc_min, lc_max, zeta, zetb, zetc, RA, RB, RC, habc, o1, o2, o3, GG_count, GR_count, RR_count)
Low-level integration routine for 3-center ERIs.
Ewald sums to represent integrals in direct and reciprocal lattice.
subroutine, public pgf_sum_3c_1d(S_G, RA, RB, RC, zeta, zetb, zetc, a_mm, lgth, R_bounds_3)
Compute Ewald-like sum for 3-center integrals in 1 dimension S_G(l, m, n, alpha, beta,...
pure subroutine, public pgf_sum_2c_rspace_1d(S_R, R, alpha, lgth, R_c)
Compute Ewald-like sum for 2-center ERIs in R space in 1 dimension S_R(l, alpha) = SQRT(alpha/pi) sum...
subroutine, public pgf_sum_3c_3d(S_G, la_max, lb_max, lc_max, RA, RB, RC, zeta, zetb, zetc, a_mm, hmat, h_inv, vol, G_bounds_1, R_bounds_2, R_bounds_3, G_rads_1, R_rads_2, R_rads_3, method, method_out, order)
As pgf_sum_3c_1d but 3d sum required for non-orthorhombic cells.
pure elemental subroutine, public get_l(lco, l, lx, ly, lz)
...
subroutine, public eri_mme_3c_get_bounds(hmat, h_inv, vol, is_ortho, G_min, R_min, la_max, lb_max, lc_max, zeta, zetb, zetc, a_mm, sum_precision, n_sum_1d, n_sum_3d, G_bounds_1, G_rads_1, R_bounds_2, R_rads_2, R_bounds_3, R_rads_3)
Get summation bounds for 3c integrals.
subroutine, public eri_mme_2c_get_bounds(hmat, h_inv, vol, is_ortho, G_min, R_min, la_max, lb_max, zeta, zetb, a_mm, sum_precision, n_sum_1d, n_sum_3d, G_bounds, G_rad, R_bounds, R_rad)
Get summation bounds for 2c integrals.
pure subroutine, public pgf_sum_2c_gspace_1d(S_G, R, alpha, inv_lgth, G_c)
Compute Ewald-like sum for 2-center ERIs in G space in 1 dimension S_G(l, alpha) = (-i)^l*inv_lgth*su...
subroutine, public eri_mme_3c_get_rads(la_max, lb_max, lc_max, zeta, zetb, zetc, a_mm, G_min, R_min, sum_precision, G_rads_1, R_rads_2, R_rads_3)
Get summation radii for 3c integrals.
subroutine, public eri_mme_2c_get_rads(la_max, lb_max, zeta, zetb, a_mm, G_min, R_min, sum_precision, G_rad, R_rad)
Get summation radii for 2c integrals.
pure real(kind=dp) function, dimension(3), public ellipsoid_bounds(s_rad, s_to_e)
Compute bounding box for ellipsoid. This is needed in order to find summation bounds for sphere for s...
pure subroutine, public pgf_sum_2c_gspace_3d(S_G, l_max, R, alpha, h_inv, G_c, G_rad, vol, potential, pot_par)
As pgf_sum_2c_gspace_1d but 3d sum required for non-orthorhombic cells.
pure subroutine, public pgf_sum_2c_rspace_3d(S_R, l_max, R, alpha, hmat, h_inv, R_c, R_rad)
As pgf_sum_2c_rspace_1d but 3d sum required for non-orthorhombic cells.
Types and initialization / release routines for Minimax-Ewald method for electron repulsion integrals...
subroutine, public get_minimax_from_cutoff(grids, cutoff, n_minimax, minimax_aw, grid_no)
...
Defines the basic variable types.
integer, parameter, public int_8
integer, parameter, public dp
Definition of mathematical constants and functions.
real(kind=dp), parameter, public pi
Provides Cartesian and spherical orbital pointers and indices.
integer, dimension(:), allocatable, public ncoset
integer, dimension(:, :, :), allocatable, public coset