87 SUBROUTINE build_core_ppnl(matrix_h, matrix_p, force, virial, calculate_forces, use_virial, nder, &
88 qs_kind_set, atomic_kind_set, particle_set, sab_orb, sap_ppnl, eps_ppnl, &
89 nimages, cell_to_index, basis_type, deltaR, matrix_l, atcore)
91 TYPE(
dbcsr_p_type),
DIMENSION(:, :),
POINTER :: matrix_h, matrix_p
94 LOGICAL,
INTENT(IN) :: calculate_forces
101 POINTER :: sab_orb, sap_ppnl
102 REAL(kind=
dp),
INTENT(IN) :: eps_ppnl
103 INTEGER,
INTENT(IN) :: nimages
104 INTEGER,
DIMENSION(:, :, :),
OPTIONAL,
POINTER :: cell_to_index
105 CHARACTER(LEN=*),
INTENT(IN) :: basis_type
106 REAL(kind=
dp),
DIMENSION(:, :),
INTENT(IN), &
110 REAL(kind=
dp),
DIMENSION(:),
INTENT(INOUT), &
113 CHARACTER(LEN=*),
PARAMETER :: routinen =
'build_core_ppnl'
115 INTEGER :: atom_a, first_col, handle, i, i_dim, iab, iac, iatom, ib, ibc, icol, ikind, &
116 ilist, img, irow, iset, j, jatom, jb, jkind, jneighbor, kac, katom, kbc, kkind, l, &
117 lc_max, lc_min, ldai, ldsab, lppnl, maxco, maxder, maxl, maxlgto, maxlppnl, maxppnl, &
118 maxsgf, na, natom, nb, ncoa, ncoc, nkind, nlist, nneighbor, nnl, np, nppnl, nprjc, nseta, &
119 nsgfa, prjc, sgfa, slot
120 INTEGER,
ALLOCATABLE,
DIMENSION(:) :: atom_of_kind, kind_of
121 INTEGER,
DIMENSION(3) :: cell_b, cell_c
122 INTEGER,
DIMENSION(:),
POINTER :: la_max, la_min, npgfa, nprj_ppnl, &
124 INTEGER,
DIMENSION(:, :),
POINTER :: first_sgfa
125 LOGICAL :: do_dr, do_gth, do_kp, do_soc, doat, &
127 REAL(kind=
dp) :: atk, dac, f0, ppnl_radius
128 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:) :: radp
129 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:, :) :: sab, work
130 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:, :, :) :: ai_work, lab, work_l
131 REAL(kind=
dp),
DIMENSION(1) :: rprjc, zetc
132 REAL(kind=
dp),
DIMENSION(3) :: fa, fb, rab, rac, rbc
133 REAL(kind=
dp),
DIMENSION(3, 3) :: pv_thread
139 TYPE(
alist_type),
POINTER :: alist_ac, alist_bc
140 REAL(kind=
dp),
DIMENSION(SIZE(particle_set)) :: at_thread
141 REAL(kind=
dp),
DIMENSION(:, :, :),
POINTER :: achint, acint, alkint, bchint, bcint, &
143 REAL(kind=
dp),
DIMENSION(:, :),
POINTER :: cprj, h_block, l_block_x, l_block_y, &
144 l_block_z, p_block, r_2block, &
145 r_3block, rpgfa, sphi_a, vprj_ppnl, &
147 REAL(kind=
dp),
DIMENSION(:),
POINTER :: a_nl, alpha_ppnl, hprj, set_radius_a
148 REAL(kind=
dp),
DIMENSION(3, SIZE(particle_set)) :: force_thread
162 IF (
PRESENT(deltar)) do_dr = .true.
164 IF (
PRESENT(atcore)) doat = .true.
166 IF (calculate_forces)
THEN
167 CALL timeset(routinen//
"_forces", handle)
169 CALL timeset(routinen, handle)
172 do_soc =
PRESENT(matrix_l)
174 ppnl_present =
ASSOCIATED(sap_ppnl)
176 IF (ppnl_present)
THEN
178 nkind =
SIZE(atomic_kind_set)
179 natom =
SIZE(particle_set)
181 do_kp = (nimages > 1)
184 cpassert(
PRESENT(cell_to_index) .AND.
ASSOCIATED(cell_to_index))
187 IF (calculate_forces .OR. doat)
THEN
188 IF (
SIZE(matrix_p, 1) == 2)
THEN
190 CALL dbcsr_add(matrix_p(1, img)%matrix, matrix_p(2, img)%matrix, &
191 alpha_scalar=1.0_dp, beta_scalar=1.0_dp)
192 CALL dbcsr_add(matrix_p(2, img)%matrix, matrix_p(1, img)%matrix, &
193 alpha_scalar=-2.0_dp, beta_scalar=1.0_dp)
206 basis_type=basis_type)
208 maxl = max(maxlgto, maxlppnl)
211 ldsab = max(maxco,
ncoset(maxlppnl), maxsgf, maxppnl)
212 ldai =
ncoset(maxl + nder + 1)
215 ALLOCATE (sap_int(nkind*nkind))
216 DO i = 1, nkind*nkind
217 NULLIFY (sap_int(i)%alist, sap_int(i)%asort, sap_int(i)%aindex)
218 sap_int(i)%nalist = 0
222 ALLOCATE (basis_set(nkind), gpotential(nkind), spotential(nkind))
224 CALL get_qs_kind(qs_kind_set(ikind), basis_set=orb_basis_set, basis_type=basis_type)
225 IF (
ASSOCIATED(orb_basis_set))
THEN
226 basis_set(ikind)%gto_basis_set => orb_basis_set
228 NULLIFY (basis_set(ikind)%gto_basis_set)
230 CALL get_qs_kind(qs_kind_set(ikind), gth_potential=gth_potential, sgp_potential=sgp_potential)
231 NULLIFY (gpotential(ikind)%gth_potential)
232 NULLIFY (spotential(ikind)%sgp_potential)
233 IF (
ASSOCIATED(gth_potential))
THEN
234 gpotential(ikind)%gth_potential => gth_potential
235 IF (do_soc .AND. (.NOT. gth_potential%soc))
THEN
236 cpabort(
"Spin-orbit coupling selected, but GTH potential without SOC parameters provided")
238 ELSE IF (
ASSOCIATED(sgp_potential))
THEN
239 spotential(ikind)%sgp_potential => sgp_potential
244 DO slot = 1, sap_ppnl(1)%nl_size
246 ikind = sap_ppnl(1)%nlist_task(slot)%ikind
247 kkind = sap_ppnl(1)%nlist_task(slot)%jkind
248 iatom = sap_ppnl(1)%nlist_task(slot)%iatom
249 katom = sap_ppnl(1)%nlist_task(slot)%jatom
250 nlist = sap_ppnl(1)%nlist_task(slot)%nlist
251 ilist = sap_ppnl(1)%nlist_task(slot)%ilist
252 nneighbor = sap_ppnl(1)%nlist_task(slot)%nnode
254 iac = ikind + nkind*(kkind - 1)
255 IF (.NOT.
ASSOCIATED(basis_set(ikind)%gto_basis_set)) cycle
256 IF (.NOT.
ASSOCIATED(gpotential(kkind)%gth_potential) .AND. &
257 .NOT.
ASSOCIATED(spotential(kkind)%sgp_potential)) cycle
258 IF (.NOT.
ASSOCIATED(sap_int(iac)%alist))
THEN
259 sap_int(iac)%a_kind = ikind
260 sap_int(iac)%p_kind = kkind
261 sap_int(iac)%nalist = nlist
262 ALLOCATE (sap_int(iac)%alist(nlist))
264 NULLIFY (sap_int(iac)%alist(i)%clist)
265 sap_int(iac)%alist(i)%aatom = 0
266 sap_int(iac)%alist(i)%nclist = 0
269 IF (.NOT.
ASSOCIATED(sap_int(iac)%alist(ilist)%clist))
THEN
270 sap_int(iac)%alist(ilist)%aatom = iatom
271 sap_int(iac)%alist(ilist)%nclist = nneighbor
272 ALLOCATE (sap_int(iac)%alist(ilist)%clist(nneighbor))
274 sap_int(iac)%alist(ilist)%clist(i)%catom = 0
292 ALLOCATE (sab(ldsab, ldsab*maxder), work(ldsab, ldsab*maxder))
294 ALLOCATE (ai_work(ldai, ldai,
ncoset(nder + 1)))
297 ALLOCATE (lab(ldsab, ldsab, 3), work_l(ldsab, ldsab, 3))
302 DO slot = 1, sap_ppnl(1)%nl_size
304 ikind = sap_ppnl(1)%nlist_task(slot)%ikind
305 kkind = sap_ppnl(1)%nlist_task(slot)%jkind
306 iatom = sap_ppnl(1)%nlist_task(slot)%iatom
307 katom = sap_ppnl(1)%nlist_task(slot)%jatom
308 nlist = sap_ppnl(1)%nlist_task(slot)%nlist
309 ilist = sap_ppnl(1)%nlist_task(slot)%ilist
310 nneighbor = sap_ppnl(1)%nlist_task(slot)%nnode
311 jneighbor = sap_ppnl(1)%nlist_task(slot)%inode
312 cell_c(:) = sap_ppnl(1)%nlist_task(slot)%cell(:)
313 rac(1:3) = sap_ppnl(1)%nlist_task(slot)%r(1:3)
315 iac = ikind + nkind*(kkind - 1)
316 IF (.NOT.
ASSOCIATED(basis_set(ikind)%gto_basis_set)) cycle
318 first_sgfa => basis_set(ikind)%gto_basis_set%first_sgf
319 la_max => basis_set(ikind)%gto_basis_set%lmax
320 la_min => basis_set(ikind)%gto_basis_set%lmin
321 npgfa => basis_set(ikind)%gto_basis_set%npgf
322 nseta = basis_set(ikind)%gto_basis_set%nset
323 nsgfa = basis_set(ikind)%gto_basis_set%nsgf
324 nsgf_seta => basis_set(ikind)%gto_basis_set%nsgf_set
325 rpgfa => basis_set(ikind)%gto_basis_set%pgf_radius
326 set_radius_a => basis_set(ikind)%gto_basis_set%set_radius
327 sphi_a => basis_set(ikind)%gto_basis_set%sphi
328 zeta => basis_set(ikind)%gto_basis_set%zet
330 IF (
ASSOCIATED(gpotential(kkind)%gth_potential))
THEN
333 alpha_ppnl => gpotential(kkind)%gth_potential%alpha_ppnl
334 cprj => gpotential(kkind)%gth_potential%cprj
335 lppnl = gpotential(kkind)%gth_potential%lppnl
336 nppnl = gpotential(kkind)%gth_potential%nppnl
337 nprj_ppnl => gpotential(kkind)%gth_potential%nprj_ppnl
338 ppnl_radius = gpotential(kkind)%gth_potential%ppnl_radius
339 vprj_ppnl => gpotential(kkind)%gth_potential%vprj_ppnl
340 wprj_ppnl => gpotential(kkind)%gth_potential%wprj_ppnl
341 ELSE IF (
ASSOCIATED(spotential(kkind)%sgp_potential))
THEN
344 nprjc = spotential(kkind)%sgp_potential%nppnl
345 IF (nprjc == 0) cycle
346 nnl = spotential(kkind)%sgp_potential%n_nonlocal
347 lppnl = spotential(kkind)%sgp_potential%lmax
348 a_nl => spotential(kkind)%sgp_potential%a_nonlocal
349 ppnl_radius = spotential(kkind)%sgp_potential%ppnl_radius
351 radp(:) = ppnl_radius
352 cprj => spotential(kkind)%sgp_potential%cprj_ppnl
353 hprj => spotential(kkind)%sgp_potential%vprj_ppnl
354 nppnl =
SIZE(cprj, 2)
359 dac = sqrt(sum(rac*rac))
360 clist => sap_int(iac)%alist(ilist)%clist(jneighbor)
364 ALLOCATE (clist%acint(nsgfa, nppnl, maxder), &
365 clist%achint(nsgfa, nppnl, maxder), &
366 clist%alint(nsgfa, nppnl, 3), &
367 clist%alkint(nsgfa, nppnl, 3))
369 clist%achint = 0.0_dp
371 clist%alkint = 0.0_dp
374 NULLIFY (clist%sgf_list)
376 ncoa = npgfa(iset)*
ncoset(la_max(iset))
377 sgfa = first_sgfa(1, iset)
383 nprjc = nprj_ppnl(l)*
nco(l)
384 IF (nprjc == 0) cycle
385 rprjc(1) = ppnl_radius
386 IF (set_radius_a(iset) + rprjc(1) < dac) cycle
387 lc_max = l + 2*(nprj_ppnl(l) - 1)
389 zetc(1) = alpha_ppnl(l)
393 CALL overlap(la_max(iset), la_min(iset), npgfa(iset), rpgfa(:, iset), zeta(:, iset), &
394 lc_max, lc_min, 1, rprjc, zetc, rac, dac, sab, nder, .true., ai_work, ldai)
400 first_col = (i - 1)*ldsab
403 work(1:na, first_col + prjc:first_col + prjc + nb - 1) = &
404 matmul(sab(1:na, first_col + 1:first_col + np), cprj(1:np, prjc:prjc + nb - 1))
410 CALL angmom(la_max(iset), npgfa(iset), zeta(:, iset), rpgfa(:, iset), la_min(iset), &
411 lc_max, 1, zetc, rprjc, -rac, (/0._dp, 0._dp, 0._dp/), lab)
413 work_l(1:na, prjc:prjc + nb - 1, i_dim) = &
414 matmul(lab(1:na, 1:np, i_dim), cprj(1:np, prjc:prjc + nb - 1))
425 first_col = (i - 1)*ldsab + 1
429 clist%acint(sgfa:sgfa + na - 1, 1:nb, i) = &
430 matmul(transpose(sphi_a(1:np, sgfa:sgfa + na - 1)), work(1:np, first_col:first_col + nb - 1))
434 clist%achint(sgfa:sgfa + na - 1, 1:nb, i) = &
435 matmul(clist%acint(sgfa:sgfa + na - 1, 1:nb, i), vprj_ppnl(1:nb, 1:nb))
439 clist%alint(sgfa:sgfa + na - 1, 1:nb, i_dim) = &
440 matmul(transpose(sphi_a(1:np, sgfa:sgfa + na - 1)), work_l(1:np, 1:nb, i_dim))
441 clist%alkint(sgfa:sgfa + na - 1, 1:nb, i_dim) = &
442 matmul(clist%alint(sgfa:sgfa + na - 1, 1:nb, i_dim), wprj_ppnl(1:nb, 1:nb))
448 CALL overlap(la_max(iset), la_min(iset), npgfa(iset), rpgfa(:, iset), zeta(:, iset), &
449 lppnl, 0, nnl, radp, a_nl, rac, dac, sab, nder, .true., ai_work, ldai)
454 first_col = (i - 1)*ldsab + 1
458 work(1:np, 1:nb) = matmul(sab(1:np, first_col:first_col + nprjc - 1), cprj(1:nprjc, 1:nb))
462 clist%acint(sgfa:sgfa + na - 1, 1:nb, i) = &
463 matmul(transpose(sphi_a(1:np, sgfa:sgfa + na - 1)), work(1:np, 1:nb))
465 ncoc = sgfa + nsgf_seta(iset) - 1
467 clist%achint(sgfa:ncoc, j, i) = clist%acint(sgfa:ncoc, j, i)*hprj(j)
472 clist%maxac = maxval(abs(clist%acint(:, :, 1)))
473 clist%maxach = maxval(abs(clist%achint(:, :, 1)))
474 IF (.NOT. do_gth)
DEALLOCATE (radp)
477 DEALLOCATE (sab, ai_work, work)
478 IF (do_soc)
DEALLOCATE (lab, work_l)
486 force_thread = 0.0_dp
517 DO slot = 1, sab_orb(1)%nl_size
519 ikind = sab_orb(1)%nlist_task(slot)%ikind
520 jkind = sab_orb(1)%nlist_task(slot)%jkind
521 iatom = sab_orb(1)%nlist_task(slot)%iatom
522 jatom = sab_orb(1)%nlist_task(slot)%jatom
523 cell_b(:) = sab_orb(1)%nlist_task(slot)%cell(:)
524 rab(1:3) = sab_orb(1)%nlist_task(slot)%r(1:3)
526 IF (.NOT.
ASSOCIATED(basis_set(ikind)%gto_basis_set)) cycle
527 IF (.NOT.
ASSOCIATED(basis_set(jkind)%gto_basis_set)) cycle
529 iab = ikind + nkind*(jkind - 1)
532 IF (iatom == jatom)
THEN
539 img = cell_to_index(cell_b(1), cell_b(2), cell_b(3))
545 IF (iatom <= jatom)
THEN
555 NULLIFY (l_block_x, l_block_y, l_block_z)
562 NULLIFY (r_2block, r_3block)
567 IF (calculate_forces .OR. doat)
THEN
573 IF (
ASSOCIATED(h_block))
THEN
578 iac = ikind + nkind*(kkind - 1)
579 ibc = jkind + nkind*(kkind - 1)
580 IF (.NOT.
ASSOCIATED(sap_int(iac)%alist)) cycle
581 IF (.NOT.
ASSOCIATED(sap_int(ibc)%alist)) cycle
582 CALL get_alist(sap_int(iac), alist_ac, iatom)
583 CALL get_alist(sap_int(ibc), alist_bc, jatom)
584 IF (.NOT.
ASSOCIATED(alist_ac)) cycle
585 IF (.NOT.
ASSOCIATED(alist_bc)) cycle
586 DO kac = 1, alist_ac%nclist
587 DO kbc = 1, alist_bc%nclist
588 IF (alist_ac%clist(kac)%catom /= alist_bc%clist(kbc)%catom) cycle
589 IF (all(cell_b + alist_bc%clist(kbc)%cell - alist_ac%clist(kac)%cell == 0))
THEN
590 IF (alist_ac%clist(kac)%maxac*alist_bc%clist(kbc)%maxach < eps_ppnl) cycle
591 acint => alist_ac%clist(kac)%acint
592 bcint => alist_bc%clist(kbc)%acint
593 achint => alist_ac%clist(kac)%achint
594 bchint => alist_bc%clist(kbc)%achint
596 alkint => alist_ac%clist(kac)%alkint
597 blkint => alist_bc%clist(kbc)%alkint
603 IF (.NOT. do_dr)
THEN
604 IF (iatom <= jatom)
THEN
605 h_block(1:na, 1:nb) = h_block(1:na, 1:nb) + &
606 matmul(achint(1:na, 1:np, 1), transpose(bcint(1:nb, 1:np, 1)))
608 h_block(1:nb, 1:na) = h_block(1:nb, 1:na) + &
609 matmul(bchint(1:nb, 1:np, 1), transpose(acint(1:na, 1:np, 1)))
613 IF (iatom <= jatom)
THEN
614 l_block_x(1:na, 1:nb) = l_block_x(1:na, 1:nb) + &
615 matmul(alkint(1:na, 1:np, 1), transpose(bcint(1:nb, 1:np, 1)))
616 l_block_y(1:na, 1:nb) = l_block_y(1:na, 1:nb) + &
617 matmul(alkint(1:na, 1:np, 2), transpose(bcint(1:nb, 1:np, 1)))
618 l_block_z(1:na, 1:nb) = l_block_z(1:na, 1:nb) + &
619 matmul(alkint(1:na, 1:np, 3), transpose(bcint(1:nb, 1:np, 1)))
622 l_block_x(1:nb, 1:na) = l_block_x(1:nb, 1:na) - &
623 matmul(blkint(1:nb, 1:np, 1), transpose(acint(1:na, 1:np, 1)))
624 l_block_y(1:nb, 1:na) = l_block_y(1:nb, 1:na) - &
625 matmul(blkint(1:nb, 1:np, 2), transpose(acint(1:na, 1:np, 1)))
626 l_block_z(1:nb, 1:na) = l_block_z(1:nb, 1:na) - &
627 matmul(blkint(1:nb, 1:np, 3), transpose(acint(1:na, 1:np, 1)))
631 IF (calculate_forces)
THEN
632 IF (
ASSOCIATED(p_block))
THEN
633 katom = alist_ac%clist(kac)%catom
636 IF (iatom <= jatom)
THEN
637 fa(i) = sum(p_block(1:na, 1:nb)* &
638 matmul(acint(1:na, 1:np, j), transpose(bchint(1:nb, 1:np, 1))))
639 fb(i) = sum(p_block(1:na, 1:nb)* &
640 matmul(achint(1:na, 1:np, 1), transpose(bcint(1:nb, 1:np, j))))
642 fa(i) = sum(p_block(1:nb, 1:na)* &
643 matmul(bchint(1:nb, 1:np, 1), transpose(acint(1:na, 1:np, j))))
644 fb(i) = sum(p_block(1:nb, 1:na)* &
645 matmul(bcint(1:nb, 1:np, j), transpose(achint(1:na, 1:np, 1))))
647 force_thread(i, iatom) = force_thread(i, iatom) + f0*fa(i)
648 force_thread(i, katom) = force_thread(i, katom) - f0*fa(i)
649 force_thread(i, jatom) = force_thread(i, jatom) + f0*fb(i)
650 force_thread(i, katom) = force_thread(i, katom) - f0*fb(i)
654 rac = alist_ac%clist(kac)%rac
655 rbc = alist_bc%clist(kbc)%rac
664 katom = alist_ac%clist(kac)%catom
665 IF (iatom <= jatom)
THEN
666 h_block(1:na, 1:nb) = h_block(1:na, 1:nb) + &
667 (deltar(i, iatom) - deltar(i, katom))* &
668 matmul(acint(1:na, 1:np, j), transpose(bchint(1:nb, 1:np, 1)))
670 h_block(1:na, 1:nb) = h_block(1:na, 1:nb) + &
671 (deltar(i, jatom) - deltar(i, katom))* &
672 matmul(achint(1:na, 1:np, 1), transpose(bcint(1:nb, 1:np, j)))
674 h_block(1:nb, 1:na) = h_block(1:nb, 1:na) + &
675 (deltar(i, iatom) - deltar(i, katom))* &
676 matmul(bchint(1:nb, 1:np, 1), transpose(acint(1:na, 1:np, j)))
677 h_block(1:nb, 1:na) = h_block(1:nb, 1:na) + &
678 (deltar(i, jatom) - deltar(i, katom))* &
679 matmul(bcint(1:nb, 1:np, j), transpose(achint(1:na, 1:np, 1)))
683 katom = alist_ac%clist(kac)%catom
684 IF (iatom <= jatom)
THEN
685 r_2block(1:na, 1:nb) = r_2block(1:na, 1:nb) + &
686 (deltar(i, iatom) - deltar(i, katom))* &
687 matmul(acint(1:na, 1:np, j), transpose(bchint(1:nb, 1:np, 1)))
689 r_2block(1:na, 1:nb) = r_2block(1:na, 1:nb) + &
690 (deltar(i, jatom) - deltar(i, katom))* &
691 matmul(achint(1:na, 1:np, 1), transpose(bcint(1:nb, 1:np, j)))
693 r_2block(1:nb, 1:na) = r_2block(1:nb, 1:na) + &
694 (deltar(i, iatom) - deltar(i, katom))* &
695 matmul(bchint(1:nb, 1:np, 1), transpose(acint(1:na, 1:np, j)))
696 r_2block(1:nb, 1:na) = r_2block(1:nb, 1:na) + &
697 (deltar(i, jatom) - deltar(i, katom))* &
698 matmul(bcint(1:nb, 1:np, j), transpose(achint(1:na, 1:np, 1)))
702 katom = alist_ac%clist(kac)%catom
703 IF (iatom <= jatom)
THEN
704 r_3block(1:na, 1:nb) = r_3block(1:na, 1:nb) + &
705 (deltar(i, iatom) - deltar(i, katom))* &
706 matmul(acint(1:na, 1:np, j), transpose(bchint(1:nb, 1:np, 1)))
708 r_3block(1:na, 1:nb) = r_3block(1:na, 1:nb) + &
709 (deltar(i, jatom) - deltar(i, katom))* &
710 matmul(achint(1:na, 1:np, 1), transpose(bcint(1:nb, 1:np, j)))
712 r_3block(1:nb, 1:na) = r_3block(1:nb, 1:na) + &
713 (deltar(i, iatom) - deltar(i, katom))* &
714 matmul(bchint(1:nb, 1:np, 1), transpose(acint(1:na, 1:np, j)))
715 r_3block(1:nb, 1:na) = r_3block(1:nb, 1:na) + &
716 (deltar(i, jatom) - deltar(i, katom))* &
717 matmul(bcint(1:nb, 1:np, j), transpose(achint(1:na, 1:np, 1)))
722 IF (
ASSOCIATED(p_block))
THEN
723 katom = alist_ac%clist(kac)%catom
724 IF (iatom <= jatom)
THEN
725 atk = sum(p_block(1:na, 1:nb)* &
726 matmul(achint(1:na, 1:np, 1), transpose(bcint(1:nb, 1:np, 1))))
728 atk = sum(p_block(1:nb, 1:na)* &
729 matmul(bchint(1:nb, 1:np, 1), transpose(acint(1:na, 1:np, 1))))
731 at_thread(katom) = at_thread(katom) + f0*atk
756 DEALLOCATE (basis_set, gpotential, spotential)
757 IF (calculate_forces)
THEN
761 atom_a = atom_of_kind(iatom)
762 ikind = kind_of(iatom)
763 force(ikind)%gth_ppnl(:, atom_a) = force(ikind)%gth_ppnl(:, atom_a) + force_thread(:, iatom)
766 DEALLOCATE (atom_of_kind, kind_of)
769 IF (calculate_forces .AND. use_virial)
THEN
770 virial%pv_ppnl = virial%pv_ppnl + pv_thread
771 virial%pv_virial = virial%pv_virial + pv_thread
775 atcore(1:natom) = atcore(1:natom) + at_thread
778 IF (calculate_forces .OR. doat)
THEN
781 IF (
SIZE(matrix_p, 1) == 2)
THEN
783 CALL dbcsr_add(matrix_p(1, img)%matrix, matrix_p(2, img)%matrix, &
784 alpha_scalar=0.5_dp, beta_scalar=0.5_dp)
785 CALL dbcsr_add(matrix_p(2, img)%matrix, matrix_p(1, img)%matrix, &
786 alpha_scalar=-1.0_dp, beta_scalar=1.0_dp)
793 CALL timestop(handle)