132#include "./base/base_uses.f90"
141 CHARACTER(len=*),
PARAMETER,
PRIVATE :: moduleN =
'qs_linres_current'
145 REAL(dp),
POINTER,
DIMENSION(:, :) :: r => null()
148 0.0_dp, 0.0_dp, 0.0_dp, 0.0_dp, 0.0_dp, -1.0_dp, 0.0_dp, 1.0_dp, 0.0_dp, &
149 0.0_dp, 0.0_dp, 1.0_dp, 0.0_dp, 0.0_dp, 0.0_dp, -1.0_dp, 0.0_dp, 0.0_dp, &
150 0.0_dp, -1.0_dp, 0.0_dp, 1.0_dp, 0.0_dp, 0.0_dp, 0.0_dp, 0.0_dp, 0.0_dp/), (/3, 3, 3/))
183 INTEGER,
INTENT(IN) :: ib
185 CHARACTER(LEN=*),
PARAMETER :: routinen =
'current_build_current'
187 CHARACTER(LEN=default_path_length) :: ext, filename, my_pos
188 INTEGER :: handle, idir, iib, iiib, ispin, istate, &
189 j, jstate, nao, natom, nmo, nspins, &
190 nstates(2), output_unit, unit_nr
191 INTEGER,
ALLOCATABLE,
DIMENSION(:) :: first_sgf, last_sgf
192 INTEGER,
DIMENSION(:),
POINTER :: row_blk_sizes
193 LOGICAL :: append_cube, gapw, mpi_io
194 REAL(
dp) :: dk(3), jrho_tot_g(3, 3), &
195 jrho_tot_r(3, 3), maxocc, scale_fac
196 REAL(
dp),
ALLOCATABLE,
DIMENSION(:, :) :: ddk
197 REAL(
dp),
EXTERNAL :: ddot
200 TYPE(
cp_fm_type),
ALLOCATABLE,
DIMENSION(:) :: p_psi1, psi1
201 TYPE(
cp_fm_type),
DIMENSION(:),
POINTER :: psi0_order
202 TYPE(
cp_fm_type),
DIMENSION(:, :),
POINTER :: psi1_d, psi1_p, psi1_rxp
206 TYPE(
dbcsr_p_type),
DIMENSION(:),
POINTER :: density_matrix0, density_matrix_a, &
207 density_matrix_ii, density_matrix_iii
220 TYPE(
qs_kind_type),
DIMENSION(:),
POINTER :: qs_kind_set
226 CALL timeset(routinen, handle)
228 NULLIFY (logger, current_section, density_matrix0, density_matrix_a, &
229 density_matrix_ii, density_matrix_iii, cell, dft_control, mos, &
230 particle_set, pw_env, auxbas_rs_desc, auxbas_pw_pool, &
231 para_env, center_list, mo_coeff, jrho1_r, jrho1_g, &
232 psi1_p, psi1_d, psi1_rxp, sab_all, qs_kind_set)
239 center_list=center_list, &
243 psi0_order=psi0_order, &
250 dft_control=dft_control, &
257 particle_set=particle_set, &
258 qs_kind_set=qs_kind_set, &
259 dbcsr_dist=dbcsr_dist)
263 gapw = dft_control%qs_control%gapw
264 nspins = dft_control%nspins
265 natom =
SIZE(particle_set, 1)
268 ALLOCATE (psi1(nspins), p_psi1(nspins))
270 CALL cp_fm_create(psi1(ispin), psi0_order(ispin)%matrix_struct)
271 CALL cp_fm_create(p_psi1(ispin), psi0_order(ispin)%matrix_struct)
283 ALLOCATE (first_sgf(natom))
284 ALLOCATE (last_sgf(natom))
286 first_sgf=first_sgf, &
288 ALLOCATE (row_blk_sizes(natom))
289 CALL dbcsr_convert_offsets_to_sizes(first_sgf, row_blk_sizes, last_sgf)
290 DEALLOCATE (first_sgf)
291 DEALLOCATE (last_sgf)
297 ALLOCATE (density_matrix0(ispin)%matrix)
298 CALL dbcsr_create(matrix=density_matrix0(ispin)%matrix, &
299 name=
"density_matrix0", &
300 dist=dbcsr_dist, matrix_type=dbcsr_type_no_symmetry, &
301 row_blk_size=row_blk_sizes, col_blk_size=row_blk_sizes, &
306 ALLOCATE (density_matrix_a(ispin)%matrix)
307 CALL dbcsr_copy(density_matrix_a(ispin)%matrix, density_matrix0(ispin)%matrix, &
308 name=
"density_matrix_a")
311 ALLOCATE (density_matrix_ii(ispin)%matrix)
312 CALL dbcsr_copy(density_matrix_ii(ispin)%matrix, density_matrix0(ispin)%matrix, &
313 name=
"density_matrix_ii")
316 ALLOCATE (density_matrix_iii(ispin)%matrix)
317 CALL dbcsr_copy(density_matrix_iii(ispin)%matrix, density_matrix0(ispin)%matrix, &
318 name=
"density_matrix_iii")
321 DEALLOCATE (row_blk_sizes)
334 mo_coeff => psi0_order(ispin)
337 CALL get_mo_set(mo_set=mos(ispin), maxocc=maxocc)
341 CALL dbcsr_set(density_matrix0(ispin)%matrix, 0.0_dp)
343 matrix_v=mo_coeff, matrix_g=mo_coeff, &
344 ncol=nmo, alpha=maxocc)
347 ALLOCATE (ddk(3, nmo))
352 associate(psi_a_ib => psi1(ispin), psi_buf => p_psi1(ispin))
358 DO istate = 1, current_env%nbr_center(ispin)
359 dk(1:3) = current_env%centers_set(ispin)%array(1:3, istate)
363 DO j = center_list(ispin)%array(1, istate), center_list(ispin)%array(1, istate + 1) - 1
364 jstate = center_list(ispin)%array(2, j)
365 CALL cp_fm_to_fm(psi1_p(ispin, iib), psi_a_ib, 1, jstate, jstate)
366 CALL cp_fm_to_fm(psi1_p(ispin, iiib), psi_buf, 1, jstate, jstate)
367 ddk(:, jstate) = dk(1:3)
380 IF (current_env%full)
THEN
389 CALL dbcsr_set(density_matrix_a(ispin)%matrix, 0.0_dp)
391 matrix_v=mo_coeff, matrix_g=psi_a_ib, &
392 ncol=nmo, alpha=maxocc)
396 CALL dbcsr_set(density_matrix_iii(ispin)%matrix, 0.0_dp)
398 matrix_v=mo_coeff, matrix_g=psi1_p(ispin, iiib), &
399 ncol=nmo, alpha=maxocc)
402 CALL dbcsr_set(density_matrix_ii(ispin)%matrix, 0.0_dp)
404 matrix_v=mo_coeff, matrix_g=psi1_p(ispin, iib), &
405 ncol=nmo, alpha=maxocc)
412 CALL qs_rho_get(current_env%jrho1_set(idir)%rho, rho_r=jrho1_r)
413 CALL qs_rho_get(current_env%jrho1_set(idir)%rho, rho_g=jrho1_g)
414 associate(jrho_rspace => jrho1_r(ispin), jrho_gspace => jrho1_g(ispin))
418 density_matrix_a(ispin)%matrix, &
419 density_matrix_ii(ispin)%matrix, &
420 density_matrix_iii(ispin)%matrix, &
421 ib, idir, jrho_rspace, jrho_gspace, qs_env, &
424 scale_fac = cell%deth/
twopi
425 CALL pw_scale(jrho_rspace, scale_fac)
426 CALL pw_scale(jrho_gspace, scale_fac)
432 IF (output_unit > 0)
THEN
433 WRITE (output_unit,
'(T2,2(A,E24.16))')
'Integrated j_'&
434 &//achar(idir + 119)//achar(ib + 119)//
'(r): G-space=', &
435 jrho_tot_g(idir, ib),
' R-space=', jrho_tot_r(idir, ib)
451 CALL calculate_jrho_atom_coeff(qs_env, current_env, &
455 density_matrix_iii, &
462 CALL calculate_jrho_atom_rad(qs_env, current_env, idir)
465 CALL calculate_jrho_atom(current_env, qs_env, ib, idir)
470 IF (btest(cp_print_key_should_output(logger%iter_info, current_section,&
471 &
"PRINT%CURRENT_CUBES"), cp_p_file))
THEN
472 append_cube = section_get_lval(current_section,
"PRINT%CURRENT_CUBES%APPEND")
474 IF (append_cube)
THEN
478 CALL pw_env_get(pw_env, auxbas_rs_desc=auxbas_rs_desc, &
479 auxbas_pw_pool=auxbas_pw_pool)
481 CALL auxbas_pw_pool%create_pw(wf_r)
485 CALL qs_rho_get(current_env%jrho1_set(idir)%rho, rho_r=jrho1_r)
487 CALL pw_axpy(jrho1_r(ispin), wf_r, 1.0_dp)
494 cpabort(
"GAPW needs to be finalized")
498 WRITE (ext,
'(a2,I1,a2,I1,a5)')
"iB", ib,
"_d", idir,
".cube"
499 WRITE (ext,
'(a2,a1,a2,a1,a5)')
"iB", achar(ib + 119),
"_d", achar(idir + 119),
".cube"
500 unit_nr = cp_print_key_unit_nr(logger, current_section,
"PRINT%CURRENT_CUBES", &
501 extension=trim(ext), middle_name=trim(filename), &
502 log_filename=.false., file_position=my_pos, &
505 CALL cp_pw_to_cube(wf_r, unit_nr,
"RESPONSE CURRENT DENSITY ", &
506 particles=particles, &
507 stride=section_get_ivals(current_section,
"PRINT%CURRENT_CUBES%STRIDE"), &
509 CALL cp_print_key_finished_output(unit_nr, logger, current_section,&
510 &
"PRINT%CURRENT_CUBES", mpi_io=mpi_io)
513 CALL auxbas_pw_pool%give_back_pw(wf_r)
517 IF (output_unit > 0)
THEN
518 WRITE (output_unit,
'(T2,A,E24.16)')
'CheckSum R-integrated j=', &
519 sqrt(ddot(9, jrho_tot_r(1, 1), 1, jrho_tot_r(1, 1), 1))
524 CALL cp_fm_release(psi1)
525 CALL cp_fm_release(p_psi1)
527 CALL dbcsr_deallocate_matrix_set(density_matrix0)
528 CALL dbcsr_deallocate_matrix_set(density_matrix_a)
529 CALL dbcsr_deallocate_matrix_set(density_matrix_ii)
530 CALL dbcsr_deallocate_matrix_set(density_matrix_iii)
533 CALL timestop(handle)
577 current_rs, current_gs, qs_env, current_env, soft_valid, retain_rsgrid)
579 TYPE(dbcsr_type),
POINTER :: mat_d0, mat_jp, mat_jp_rii, mat_jp_riii
580 INTEGER,
INTENT(IN) :: ib, idir
581 TYPE(pw_r3d_rs_type),
INTENT(INOUT) :: current_rs
582 TYPE(pw_c1d_gs_type),
INTENT(INOUT) :: current_gs
583 TYPE(qs_environment_type),
POINTER :: qs_env
584 TYPE(current_env_type) :: current_env
585 LOGICAL,
INTENT(IN),
OPTIONAL :: soft_valid, retain_rsgrid
587 CHARACTER(LEN=*),
PARAMETER :: routinen =
'calculate_jrho_resp'
588 INTEGER,
PARAMETER :: max_tasks = 2000
590 CHARACTER(LEN=default_string_length) :: basis_type
591 INTEGER :: adbmdab_func, bcol, brow, cindex, curr_tasks, handle, i, iatom, iatom_old, idir2, &
592 igrid_level, iib, iiib, ikind, ikind_old, ipgf, iset, iset_old, itask, ithread, jatom, &
593 jatom_old, jkind, jkind_old, jpgf, jset, jset_old, maxco, maxpgf, maxset, maxsgf, &
594 maxsgf_set, na1, na2, natom, nb1, nb2, ncoa, ncob, nimages, nkind, nseta, nsetb, ntasks, &
596 INTEGER,
DIMENSION(:),
POINTER :: la_max, la_min, lb_max, lb_min, npgfa, &
598 INTEGER,
DIMENSION(:, :),
POINTER :: first_sgfa, first_sgfb
599 LOGICAL :: atom_pair_changed, den_found, &
600 den_found_a, distributed_rs_grids, &
601 do_igaim, my_retain_rsgrid, my_soft
602 REAL(dp),
DIMENSION(:, :, :),
POINTER :: my_current, my_gauge, my_rho
603 REAL(kind=dp) :: eps_rho_rspace, f, kind_radius_a, &
604 kind_radius_b, lxo2, lyo2, lzo2, &
605 prefactor, radius, scale, scale2, zetp
606 REAL(kind=dp),
DIMENSION(3) :: ra, rab, rb, rp
607 REAL(kind=dp),
DIMENSION(:),
POINTER :: set_radius_a, set_radius_b
608 REAL(kind=dp),
DIMENSION(:, :),
POINTER :: jp_block_a, jp_block_b, jp_block_c, jp_block_d, &
609 jpab_a, jpab_b, jpab_c, jpab_d, rpgfa, rpgfb, sphi_a, sphi_b, work, zeta, zetb
610 REAL(kind=dp),
DIMENSION(:, :, :),
POINTER :: jpabt_a, jpabt_b, jpabt_c, jpabt_d, workt
611 TYPE(atom_pair_type),
DIMENSION(:),
POINTER :: atom_pair_recv, atom_pair_send
612 TYPE(cell_type),
POINTER :: cell
613 TYPE(cube_info_type),
DIMENSION(:),
POINTER :: cube_info
614 TYPE(dbcsr_p_type),
DIMENSION(:),
POINTER :: deltajp_a, deltajp_b, deltajp_c, &
616 TYPE(dbcsr_type),
POINTER :: mat_a, mat_b, mat_c, mat_d
617 TYPE(dft_control_type),
POINTER :: dft_control
618 TYPE(gridlevel_info_type),
POINTER :: gridlevel_info
619 TYPE(gto_basis_set_p_type),
DIMENSION(:),
POINTER :: basis_set_list
620 TYPE(gto_basis_set_type),
POINTER :: basis_set_a, basis_set_b, orb_basis_set
621 TYPE(mp_para_env_type),
POINTER :: para_env
622 TYPE(neighbor_list_iterator_p_type), &
623 DIMENSION(:),
POINTER :: nl_iterator
624 TYPE(neighbor_list_set_p_type),
DIMENSION(:), &
626 TYPE(particle_type),
DIMENSION(:),
POINTER :: particle_set
627 TYPE(pw_env_type),
POINTER :: pw_env
628 TYPE(qs_kind_type),
DIMENSION(:),
POINTER :: qs_kind_set
629 TYPE(qs_kind_type),
POINTER :: qs_kind
630 TYPE(realspace_grid_desc_p_type),
DIMENSION(:), &
632 TYPE(realspace_grid_type),
DIMENSION(:),
POINTER :: rs_current, rs_rho
633 TYPE(realspace_grid_type),
DIMENSION(:, :), &
635 TYPE(task_type),
DIMENSION(:),
POINTER :: tasks
637 NULLIFY (qs_kind, cell, dft_control, orb_basis_set, rs_rho, &
638 qs_kind_set, sab_orb, particle_set, rs_current, pw_env, &
639 rs_descs, para_env, set_radius_a, set_radius_b, la_max, la_min, &
640 lb_max, lb_min, npgfa, npgfb, nsgfa, nsgfb, rpgfa, rpgfb, &
641 sphi_a, sphi_b, zeta, zetb, first_sgfa, first_sgfb, tasks, &
642 workt, mat_a, mat_b, mat_c, mat_d, rs_gauge)
643 NULLIFY (deltajp_a, deltajp_b, deltajp_c, deltajp_d)
644 NULLIFY (jp_block_a, jp_block_b, jp_block_c, jp_block_d)
645 NULLIFY (jpabt_a, jpabt_b, jpabt_c, jpabt_d)
646 NULLIFY (atom_pair_send, atom_pair_recv)
648 CALL timeset(routinen, handle)
653 do_igaim = current_env%gauge .EQ. current_gauge_atom
658 IF (do_igaim) mat_d => mat_d0
660 my_retain_rsgrid = .false.
661 IF (
PRESENT(retain_rsgrid)) my_retain_rsgrid = retain_rsgrid
663 CALL get_qs_env(qs_env=qs_env, &
664 qs_kind_set=qs_kind_set, &
666 dft_control=dft_control, &
667 particle_set=particle_set, &
672 IF (do_igaim)
CALL get_current_env(current_env=current_env, rs_gauge=rs_gauge)
675 CALL set_vecp(ib, iib, iiib)
680 IF (idir .NE. ib)
THEN
681 CALL set_vecp_rev(idir, ib, idir2)
682 scale2 = fac_vecp(idir, ib, idir2)
686 gridlevel_info => pw_env%gridlevel_info
687 cube_info => pw_env%cube_info
690 cpassert(
ASSOCIATED(sab_orb))
692 cpassert(
ASSOCIATED(pw_env))
693 CALL pw_env_get(pw_env, rs_descs=rs_descs, rs_grids=rs_rho)
695 distributed_rs_grids = .false.
696 DO igrid_level = 1, gridlevel_info%ngrid_levels
697 IF (.NOT. all(rs_descs(igrid_level)%rs_desc%perd == 1))
THEN
698 distributed_rs_grids = .true.
701 eps_rho_rspace = dft_control%qs_control%eps_rho_rspace
705 CALL get_qs_kind_set(qs_kind_set=qs_kind_set, &
708 maxsgf_set=maxsgf_set)
710 lxo2 = sqrt(sum(cell%hmat(:, 1)**2))/2.0_dp
711 lyo2 = sqrt(sum(cell%hmat(:, 2)**2))/2.0_dp
712 lzo2 = sqrt(sum(cell%hmat(:, 3)**2))/2.0_dp
715 IF (
PRESENT(soft_valid)) my_soft = soft_valid
717 basis_type =
"ORB_SOFT"
722 nkind =
SIZE(qs_kind_set)
724 CALL reallocate(jpabt_a, 1, maxco, 1, maxco, 0, nthread - 1)
725 CALL reallocate(jpabt_b, 1, maxco, 1, maxco, 0, nthread - 1)
726 CALL reallocate(jpabt_c, 1, maxco, 1, maxco, 0, nthread - 1)
727 CALL reallocate(jpabt_d, 1, maxco, 1, maxco, 0, nthread - 1)
728 CALL reallocate(workt, 1, maxco, 1, maxsgf_set, 0, nthread - 1)
729 CALL reallocate_tasks(tasks, max_tasks)
732 curr_tasks =
SIZE(tasks)
735 natom =
SIZE(particle_set)
740 nimages = dft_control%nimages
741 cpassert(nimages == 1)
745 qs_kind => qs_kind_set(ikind)
747 CALL get_qs_kind(qs_kind=qs_kind, basis_set=orb_basis_set)
749 IF (.NOT.
ASSOCIATED(orb_basis_set)) cycle
751 CALL get_gto_basis_set(gto_basis_set=orb_basis_set, npgf=npgfa, nset=nseta)
752 maxset = max(nseta, maxset)
753 maxpgf = max(maxval(npgfa), maxpgf)
760 ALLOCATE (deltajp_a(1), deltajp_b(1), deltajp_c(1), deltajp_d(1))
761 IF (distributed_rs_grids)
THEN
762 ALLOCATE (deltajp_a(1)%matrix, deltajp_b(1)%matrix, deltajp_c(1)%matrix)
764 ALLOCATE (deltajp_d(1)%matrix)
767 CALL dbcsr_create(deltajp_a(1)%matrix, template=mat_a, name=
'deltajp_a')
768 CALL dbcsr_create(deltajp_b(1)%matrix, template=mat_a, name=
'deltajp_b')
769 CALL dbcsr_create(deltajp_c(1)%matrix, template=mat_a, name=
'deltajp_c')
770 IF (do_igaim)
CALL dbcsr_create(deltajp_d(1)%matrix, template=mat_a, name=
'deltajp_d')
772 deltajp_a(1)%matrix => mat_a
773 deltajp_b(1)%matrix => mat_b
774 deltajp_c(1)%matrix => mat_c
775 IF (do_igaim) deltajp_d(1)%matrix => mat_d
778 ALLOCATE (basis_set_list(nkind))
780 qs_kind => qs_kind_set(ikind)
781 CALL get_qs_kind(qs_kind=qs_kind, basis_set=basis_set_a, basis_type=basis_type)
782 IF (
ASSOCIATED(basis_set_a))
THEN
783 basis_set_list(ikind)%gto_basis_set => basis_set_a
785 NULLIFY (basis_set_list(ikind)%gto_basis_set)
788 CALL neighbor_list_iterator_create(nl_iterator, sab_orb)
789 DO WHILE (neighbor_list_iterate(nl_iterator) == 0)
790 CALL get_iterator_info(nl_iterator, ikind=ikind, jkind=jkind, iatom=iatom, jatom=jatom, r=rab)
791 basis_set_a => basis_set_list(ikind)%gto_basis_set
792 IF (.NOT.
ASSOCIATED(basis_set_a)) cycle
793 basis_set_b => basis_set_list(jkind)%gto_basis_set
794 IF (.NOT.
ASSOCIATED(basis_set_b)) cycle
795 ra(:) = pbc(particle_set(iatom)%r, cell)
797 first_sgfa => basis_set_a%first_sgf
798 la_max => basis_set_a%lmax
799 la_min => basis_set_a%lmin
800 npgfa => basis_set_a%npgf
801 nseta = basis_set_a%nset
802 nsgfa => basis_set_a%nsgf_set
803 rpgfa => basis_set_a%pgf_radius
804 set_radius_a => basis_set_a%set_radius
805 kind_radius_a = basis_set_a%kind_radius
806 sphi_a => basis_set_a%sphi
807 zeta => basis_set_a%zet
809 first_sgfb => basis_set_b%first_sgf
810 lb_max => basis_set_b%lmax
811 lb_min => basis_set_b%lmin
812 npgfb => basis_set_b%npgf
813 nsetb = basis_set_b%nset
814 nsgfb => basis_set_b%nsgf_set
815 rpgfb => basis_set_b%pgf_radius
816 set_radius_b => basis_set_b%set_radius
817 kind_radius_b = basis_set_b%kind_radius
818 sphi_b => basis_set_b%sphi
819 zetb => basis_set_b%zet
821 IF (abs(rab(1)) > lxo2 .OR. abs(rab(2)) > lyo2 .OR. abs(rab(3)) > lzo2)
THEN
828 CALL dbcsr_get_block_p(matrix=mat_a, row=brow, col=bcol, &
829 block=jp_block_a, found=den_found_a)
830 CALL dbcsr_get_block_p(matrix=mat_b, row=brow, col=bcol, &
831 block=jp_block_b, found=den_found)
832 CALL dbcsr_get_block_p(matrix=mat_c, row=brow, col=bcol, &
833 block=jp_block_c, found=den_found)
834 IF (do_igaim)
CALL dbcsr_get_block_p(matrix=mat_d, row=brow, col=bcol, &
835 block=jp_block_d, found=den_found)
837 IF (.NOT.
ASSOCIATED(jp_block_a)) cycle
839 IF (distributed_rs_grids)
THEN
840 CALL dbcsr_put_block(deltajp_a(1)%matrix, brow, bcol, jp_block_a)
841 CALL dbcsr_put_block(deltajp_b(1)%matrix, brow, bcol, jp_block_b)
842 CALL dbcsr_put_block(deltajp_c(1)%matrix, brow, bcol, jp_block_c)
844 CALL dbcsr_put_block(deltajp_d(1)%matrix, brow, bcol, jp_block_d)
848 CALL task_list_inner_loop(tasks, ntasks, curr_tasks, rs_descs, &
849 dft_control, cube_info, gridlevel_info, cindex, &
850 iatom, jatom, rpgfa, rpgfb, zeta, zetb, kind_radius_b, &
851 set_radius_a, set_radius_b, ra, rab, &
852 la_max, la_min, lb_max, lb_min, npgfa, npgfb, nseta, nsetb)
855 CALL neighbor_list_iterator_release(nl_iterator)
857 DEALLOCATE (basis_set_list)
859 IF (distributed_rs_grids)
THEN
860 CALL dbcsr_finalize(deltajp_a(1)%matrix)
861 CALL dbcsr_finalize(deltajp_b(1)%matrix)
862 CALL dbcsr_finalize(deltajp_c(1)%matrix)
863 IF (do_igaim)
CALL dbcsr_finalize(deltajp_d(1)%matrix)
867 CALL distribute_tasks(rs_descs=rs_descs, ntasks=ntasks, natoms=natom, tasks=tasks, &
868 atom_pair_send=atom_pair_send, atom_pair_recv=atom_pair_recv, &
869 symmetric=.false., reorder_rs_grid_ranks=.true., &
870 skip_load_balance_distributed=.false.)
872 ALLOCATE (rs_current(gridlevel_info%ngrid_levels))
874 DO igrid_level = 1, gridlevel_info%ngrid_levels
877 IF (rs_descs(igrid_level)%rs_desc%distributed .AND. .NOT. my_retain_rsgrid)
THEN
878 CALL rs_grid_release(rs_rho(igrid_level))
879 CALL rs_grid_create(rs_rho(igrid_level), rs_descs(igrid_level)%rs_desc)
881 CALL rs_grid_zero(rs_rho(igrid_level))
882 CALL rs_grid_create(rs_current(igrid_level), rs_descs(igrid_level)%rs_desc)
883 CALL rs_grid_zero(rs_current(igrid_level))
888 IF (.NOT. current_env%gauge_init .AND. do_igaim)
THEN
889 CALL current_set_gauge(current_env, qs_env)
890 current_env%gauge_init = .true.
895 DO igrid_level = 1, gridlevel_info%ngrid_levels
896 my_rho => rs_rho(igrid_level)%r
897 my_current => rs_current(igrid_level)%r
898 IF (lbound(my_rho, 3) .NE. lbound(my_current, 3) .OR. &
899 lbound(my_rho, 2) .NE. lbound(my_current, 2) .OR. &
900 lbound(my_rho, 1) .NE. lbound(my_current, 1) .OR. &
901 ubound(my_rho, 3) .NE. ubound(my_current, 3) .OR. &
902 ubound(my_rho, 2) .NE. ubound(my_current, 2) .OR. &
903 ubound(my_rho, 1) .NE. ubound(my_current, 1))
THEN
904 WRITE (*, *)
'LBOUND(my_rho,3),LBOUND(my_current,3)', lbound(my_rho, 3), lbound(my_current, 3)
905 WRITE (*, *)
'LBOUND(my_rho,2),LBOUND(my_current,2)', lbound(my_rho, 2), lbound(my_current, 2)
906 WRITE (*, *)
'LBOUND(my_rho,1),LBOUND(my_current,1)', lbound(my_rho, 1), lbound(my_current, 1)
907 WRITE (*, *)
'UBOUND(my_rho,3),UBOUND(my_current,3)', ubound(my_rho, 3), ubound(my_current, 3)
908 WRITE (*, *)
'UBOUND(my_rho,2),UBOUND(my_current,2)', ubound(my_rho, 2), ubound(my_current, 2)
909 WRITE (*, *)
'UBOUND(my_rho,1),UBOUND(my_current,1)', ubound(my_rho, 1), ubound(my_current, 1)
913 my_gauge => rs_gauge(1, igrid_level)%r
914 IF (lbound(my_rho, 3) .NE. lbound(my_gauge, 3) .OR. &
915 lbound(my_rho, 2) .NE. lbound(my_gauge, 2) .OR. &
916 lbound(my_rho, 1) .NE. lbound(my_gauge, 1) .OR. &
917 ubound(my_rho, 3) .NE. ubound(my_gauge, 3) .OR. &
918 ubound(my_rho, 2) .NE. ubound(my_gauge, 2) .OR. &
919 ubound(my_rho, 1) .NE. ubound(my_gauge, 1))
THEN
920 WRITE (*, *)
'LBOUND(my_rho,3),LBOUND(my_gauge,3)', lbound(my_rho, 3), lbound(my_gauge, 3)
921 WRITE (*, *)
'LBOUND(my_rho,2),LBOUND(my_gauge,2)', lbound(my_rho, 2), lbound(my_gauge, 2)
922 WRITE (*, *)
'LBOUND(my_rho,1),LBOUND(my_gauge,1)', lbound(my_rho, 1), lbound(my_gauge, 1)
923 WRITE (*, *)
'UBOUND(my_rho,3),UbOUND(my_gauge,3)', ubound(my_rho, 3), ubound(my_gauge, 3)
924 WRITE (*, *)
'UBOUND(my_rho,2),UBOUND(my_gauge,2)', ubound(my_rho, 2), ubound(my_gauge, 2)
925 WRITE (*, *)
'UBOUND(my_rho,1),UBOUND(my_gauge,1)', ubound(my_rho, 1), ubound(my_gauge, 1)
933 IF (distributed_rs_grids)
THEN
934 CALL rs_distribute_matrix(rs_descs=rs_descs, pmats=deltajp_a, &
935 atom_pair_send=atom_pair_send, atom_pair_recv=atom_pair_recv, &
936 nimages=nimages, scatter=.true.)
937 CALL rs_distribute_matrix(rs_descs=rs_descs, pmats=deltajp_b, &
938 atom_pair_send=atom_pair_send, atom_pair_recv=atom_pair_recv, &
939 nimages=nimages, scatter=.true.)
940 CALL rs_distribute_matrix(rs_descs=rs_descs, pmats=deltajp_c, &
941 atom_pair_send=atom_pair_send, atom_pair_recv=atom_pair_recv, &
942 nimages=nimages, scatter=.true.)
943 IF (do_igaim)
CALL rs_distribute_matrix(rs_descs=rs_descs, pmats=deltajp_d, &
944 atom_pair_send=atom_pair_send, atom_pair_recv=atom_pair_recv, &
945 nimages=nimages, scatter=.true.)
949 jpab_a => jpabt_a(:, :, ithread)
950 jpab_b => jpabt_b(:, :, ithread)
951 jpab_c => jpabt_c(:, :, ithread)
952 IF (do_igaim) jpab_d => jpabt_d(:, :, ithread)
953 work => workt(:, :, ithread)
955 iatom_old = -1; jatom_old = -1; iset_old = -1; jset_old = -1
956 ikind_old = -1; jkind_old = -1
958 loop_tasks:
DO itask = 1, ntasks
959 igrid_level = tasks(itask)%grid_level
960 cindex = tasks(itask)%image
961 iatom = tasks(itask)%iatom
962 jatom = tasks(itask)%jatom
963 iset = tasks(itask)%iset
964 jset = tasks(itask)%jset
965 ipgf = tasks(itask)%ipgf
966 jpgf = tasks(itask)%jpgf
969 cpassert(tasks(itask)%dist_type .NE. 2)
971 IF (iatom .NE. iatom_old .OR. jatom .NE. jatom_old)
THEN
973 ikind = particle_set(iatom)%atomic_kind%kind_number
974 jkind = particle_set(jatom)%atomic_kind%kind_number
976 IF (iatom .NE. iatom_old) ra(:) = pbc(particle_set(iatom)%r, cell)
981 IF (ikind .NE. ikind_old)
THEN
982 CALL get_qs_kind(qs_kind_set(ikind), basis_set=orb_basis_set, &
983 basis_type=basis_type)
985 CALL get_gto_basis_set(gto_basis_set=orb_basis_set, &
986 first_sgf=first_sgfa, &
993 set_radius=set_radius_a, &
998 IF (jkind .NE. jkind_old)
THEN
1000 CALL get_qs_kind(qs_kind_set(jkind), &
1001 basis_set=orb_basis_set, basis_type=basis_type)
1003 CALL get_gto_basis_set(gto_basis_set=orb_basis_set, &
1004 first_sgf=first_sgfb, &
1005 kind_radius=kind_radius_b, &
1012 set_radius=set_radius_b, &
1018 CALL dbcsr_get_block_p(matrix=deltajp_a(1)%matrix, row=brow, col=bcol, &
1019 block=jp_block_a, found=den_found)
1020 CALL dbcsr_get_block_p(matrix=deltajp_b(1)%matrix, row=brow, col=bcol, &
1021 block=jp_block_b, found=den_found)
1022 CALL dbcsr_get_block_p(matrix=deltajp_c(1)%matrix, row=brow, col=bcol, &
1023 block=jp_block_c, found=den_found)
1024 IF (do_igaim)
CALL dbcsr_get_block_p(matrix=deltajp_d(1)%matrix, row=brow, col=bcol, &
1025 block=jp_block_d, found=den_found)
1027 IF (.NOT.
ASSOCIATED(jp_block_a)) &
1028 cpabort(
"p_block not associated in deltap")
1035 atom_pair_changed = .true.
1039 atom_pair_changed = .false.
1043 IF (atom_pair_changed .OR. iset_old .NE. iset .OR. jset_old .NE. jset)
THEN
1045 ncoa = npgfa(iset)*
ncoset(la_max(iset))
1046 sgfa = first_sgfa(1, iset)
1047 ncob = npgfb(jset)*
ncoset(lb_max(jset))
1048 sgfb = first_sgfb(1, jset)
1051 CALL dgemm(
"N",
"N", ncoa, nsgfb(jset), nsgfa(iset), &
1052 1.0_dp, sphi_a(1, sgfa),
SIZE(sphi_a, 1), &
1053 jp_block_a(sgfa, sgfb),
SIZE(jp_block_a, 1), &
1054 0.0_dp, work(1, 1), maxco)
1055 CALL dgemm(
"N",
"T", ncoa, ncob, nsgfb(jset), &
1056 1.0_dp, work(1, 1), maxco, &
1057 sphi_b(1, sgfb),
SIZE(sphi_b, 1), &
1058 0.0_dp, jpab_a(1, 1), maxco)
1060 CALL dgemm(
"N",
"N", ncoa, nsgfb(jset), nsgfa(iset), &
1061 1.0_dp, sphi_a(1, sgfa),
SIZE(sphi_a, 1), &
1062 jp_block_b(sgfa, sgfb),
SIZE(jp_block_b, 1), &
1063 0.0_dp, work(1, 1), maxco)
1064 CALL dgemm(
"N",
"T", ncoa, ncob, nsgfb(jset), &
1065 1.0_dp, work(1, 1), maxco, &
1066 sphi_b(1, sgfb),
SIZE(sphi_b, 1), &
1067 0.0_dp, jpab_b(1, 1), maxco)
1069 CALL dgemm(
"N",
"N", ncoa, nsgfb(jset), nsgfa(iset), &
1070 1.0_dp, sphi_a(1, sgfa),
SIZE(sphi_a, 1), &
1071 jp_block_c(sgfa, sgfb),
SIZE(jp_block_c, 1), &
1072 0.0_dp, work(1, 1), maxco)
1073 CALL dgemm(
"N",
"T", ncoa, ncob, nsgfb(jset), &
1074 1.0_dp, work(1, 1), maxco, &
1075 sphi_b(1, sgfb),
SIZE(sphi_b, 1), &
1076 0.0_dp, jpab_c(1, 1), maxco)
1079 CALL dgemm(
"N",
"N", ncoa, nsgfb(jset), nsgfa(iset), &
1080 1.0_dp, sphi_a(1, sgfa),
SIZE(sphi_a, 1), &
1081 jp_block_d(sgfa, sgfb),
SIZE(jp_block_d, 1), &
1082 0.0_dp, work(1, 1), maxco)
1083 CALL dgemm(
"N",
"T", ncoa, ncob, nsgfb(jset), &
1084 1.0_dp, work(1, 1), maxco, &
1085 sphi_b(1, sgfb),
SIZE(sphi_b, 1), &
1086 0.0_dp, jpab_d(1, 1), maxco)
1096 adbmdab_func = grid_func_adbmdab_x
1098 adbmdab_func = grid_func_adbmdab_y
1100 adbmdab_func = grid_func_adbmdab_z
1102 cpabort(
"invalid idir")
1105 rab(:) = tasks(itask)%rab
1106 rb(:) = ra(:) + rab(:)
1107 zetp = zeta(ipgf, iset) + zetb(jpgf, jset)
1108 f = zetb(jpgf, jset)/zetp
1109 prefactor = exp(-zeta(ipgf, iset)*f*dot_product(rab, rab))
1110 rp(:) = ra(:) + f*rab(:)
1112 na1 = (ipgf - 1)*
ncoset(la_max(iset)) + 1
1113 na2 = ipgf*
ncoset(la_max(iset))
1114 nb1 = (jpgf - 1)*
ncoset(lb_max(jset)) + 1
1115 nb2 = jpgf*
ncoset(lb_max(jset))
1124 radius = exp_radius_very_extended(la_min=la_min(iset), la_max=la_max(iset), &
1125 lb_min=lb_min(jset), lb_max=lb_max(jset), &
1126 ra=ra, rb=rb, rp=rp, zetp=zetp, eps=eps_rho_rspace, &
1127 prefactor=prefactor, cutoff=1.0_dp)
1129 CALL collocate_pgf_product(la_max(iset), zeta(ipgf, iset), &
1130 la_min(iset), lb_max(jset), zetb(jpgf, jset), lb_min(jset), &
1131 ra, rab, scale, jpab_a, na1 - 1, nb1 - 1, &
1132 rs_current(igrid_level), &
1133 radius=radius, ga_gb_function=adbmdab_func)
1137 IF (scale2 .NE. 0.0_dp)
THEN
1138 CALL collocate_pgf_product(la_max(iset), zeta(ipgf, iset), &
1139 la_min(iset), lb_max(jset), zetb(jpgf, jset), lb_min(jset), &
1140 ra, rab, scale2, jpab_d, na1 - 1, nb1 - 1, &
1141 rs_rho(igrid_level), &
1142 radius=radius, ga_gb_function=grid_func_ab)
1148 current_env%rs_buf(igrid_level)%r(:, :, :) = 0.0_dp
1149 CALL collocate_pgf_product(la_max(iset), zeta(ipgf, iset), &
1150 la_min(iset), lb_max(jset), zetb(jpgf, jset), lb_min(jset), &
1151 ra, rab, scale, jpab_b, na1 - 1, nb1 - 1, &
1153 ga_gb_function=adbmdab_func, &
1154 rsgrid=current_env%rs_buf(igrid_level))
1155 CALL collocate_gauge_ortho(rsgrid=current_env%rs_buf(igrid_level), &
1156 rsbuf=rs_current(igrid_level), &
1157 rsgauge=rs_gauge(iiib, igrid_level), &
1158 cube_info=cube_info(igrid_level), radius=radius, &
1159 zeta=zeta(ipgf, iset), zetb=zetb(jpgf, jset), &
1160 ra=ra, rab=rab, ir=iiib)
1166 current_env%rs_buf(igrid_level)%r(:, :, :) = 0.0_dp
1167 CALL collocate_pgf_product(la_max(iset), zeta(ipgf, iset), &
1168 la_min(iset), lb_max(jset), zetb(jpgf, jset), lb_min(jset), &
1169 ra, rab, scale, jpab_c, na1 - 1, nb1 - 1, &
1171 ga_gb_function=adbmdab_func, &
1172 rsgrid=current_env%rs_buf(igrid_level))
1173 CALL collocate_gauge_ortho(rsgrid=current_env%rs_buf(igrid_level), &
1174 rsbuf=rs_current(igrid_level), &
1175 rsgauge=rs_gauge(iib, igrid_level), &
1176 cube_info=cube_info(igrid_level), radius=radius, &
1177 zeta=zeta(ipgf, iset), zetb=zetb(jpgf, jset), &
1178 ra=ra, rab=rab, ir=iib)
1184 CALL collocate_pgf_product(la_max(iset), zeta(ipgf, iset), &
1185 la_min(iset), lb_max(jset), zetb(jpgf, jset), lb_min(jset), &
1186 ra, rab, scale, jpab_b, na1 - 1, nb1 - 1, &
1187 rs_current(igrid_level), &
1189 ga_gb_function=encode_ardbmdarb_func(idir=idir, ir=iiib))
1194 CALL collocate_pgf_product(la_max(iset), zeta(ipgf, iset), &
1195 la_min(iset), lb_max(jset), zetb(jpgf, jset), lb_min(jset), &
1196 ra, rab, scale, jpab_c, na1 - 1, nb1 - 1, &
1197 rs_current(igrid_level), &
1199 ga_gb_function=encode_ardbmdarb_func(idir=idir, ir=iib))
1206 DO igrid_level = 1, gridlevel_info%ngrid_levels
1207 CALL rs_grid_mult_and_add(rs_current(igrid_level), rs_rho(igrid_level), &
1208 rs_gauge(idir2, igrid_level), 1.0_dp)
1213 IF (distributed_rs_grids)
THEN
1214 CALL dbcsr_deallocate_matrix(deltajp_a(1)%matrix)
1215 CALL dbcsr_deallocate_matrix(deltajp_b(1)%matrix)
1216 CALL dbcsr_deallocate_matrix(deltajp_c(1)%matrix)
1217 IF (do_igaim)
CALL dbcsr_deallocate_matrix(deltajp_d(1)%matrix)
1219 DEALLOCATE (deltajp_a, deltajp_b, deltajp_c, deltajp_d)
1221 DEALLOCATE (jpabt_a, jpabt_b, jpabt_c, jpabt_d, workt, tasks)
1223 IF (
ASSOCIATED(atom_pair_send))
DEALLOCATE (atom_pair_send)
1224 IF (
ASSOCIATED(atom_pair_recv))
DEALLOCATE (atom_pair_recv)
1226 CALL density_rs2pw(pw_env, rs_current, current_rs, current_gs)
1227 DO i = 1,
SIZE(rs_current)
1228 CALL rs_grid_release(rs_current(i))
1231 DO i = 1,
SIZE(rs_rho)
1232 IF (rs_descs(i)%rs_desc%distributed .AND. .NOT. my_retain_rsgrid)
THEN
1233 CALL rs_grid_release(rs_rho(i))
1238 DEALLOCATE (rs_current)
1240 CALL timestop(handle)
1250 FUNCTION encode_ardbmdarb_func(idir, ir)
RESULT(func)
1251 INTEGER,
INTENT(IN) :: idir, ir
1254 cpassert(1 <= idir .AND. idir <= 3 .AND. 1 <= ir .AND. ir <= 3)
1255 SELECT CASE (10*idir + ir)
1257 func = grid_func_ardbmdarb_xx
1259 func = grid_func_ardbmdarb_xy
1261 func = grid_func_ardbmdarb_xz
1263 func = grid_func_ardbmdarb_yx
1265 func = grid_func_ardbmdarb_yy
1267 func = grid_func_ardbmdarb_yz
1269 func = grid_func_ardbmdarb_zx
1271 func = grid_func_ardbmdarb_zy
1273 func = grid_func_ardbmdarb_zz
1275 cpabort(
"invalid idir or iiiB")
1277 END FUNCTION encode_ardbmdarb_func
1292 SUBROUTINE collocate_gauge_ortho(rsgrid, rsbuf, rsgauge, cube_info, radius, ra, rab, zeta, zetb, ir)
1293 TYPE(realspace_grid_type) :: rsgrid, rsbuf, rsgauge
1294 TYPE(cube_info_type),
INTENT(IN) :: cube_info
1295 REAL(kind=dp),
INTENT(IN) :: radius
1296 REAL(kind=dp),
DIMENSION(3),
INTENT(IN) :: ra, rab
1297 REAL(kind=dp),
INTENT(IN) :: zeta, zetb
1298 INTEGER,
INTENT(IN) :: ir
1300 INTEGER :: cmax, i, ig, igmax, igmin, j, j2, jg, &
1301 jg2, jgmin, k, k2, kg, kg2, kgmin, &
1302 length, offset, sci, start
1303 INTEGER,
ALLOCATABLE,
DIMENSION(:, :) :: map
1304 INTEGER,
DIMENSION(3) :: cubecenter, lb_cube, ng, ub_cube
1305 INTEGER,
DIMENSION(:),
POINTER :: sphere_bounds
1306 REAL(kind=dp) :: f, point(3, 4), res(4), x, y, y2, z, z2, &
1308 REAL(kind=dp),
DIMENSION(3) :: dr, rap, rb, rbp, roffset, rp
1309 REAL(kind=dp),
DIMENSION(:, :, :),
POINTER :: gauge, grid, grid_buf
1311 cpassert(rsgrid%desc%orthorhombic)
1312 NULLIFY (sphere_bounds)
1314 grid => rsgrid%r(:, :, :)
1315 grid_buf => rsbuf%r(:, :, :)
1316 gauge => rsgauge%r(:, :, :)
1322 rbp(:) = rap(:) - rab(:)
1323 rp(:) = ra(:) + rap(:)
1324 rb(:) = ra(:) + rab(:)
1327 ng(:) = rsgrid%desc%npts(:)
1328 dr(1) = rsgrid%desc%dh(1, 1)
1329 dr(2) = rsgrid%desc%dh(2, 2)
1330 dr(3) = rsgrid%desc%dh(3, 3)
1333 CALL return_cube(cube_info, radius, lb_cube, ub_cube, sphere_bounds)
1334 cmax = maxval(ub_cube)
1343 ALLOCATE (map(-cmax:cmax, 3))
1345 CALL compute_cube_center(cubecenter, rsgrid%desc, zeta, zetb, ra, rab)
1346 roffset(:) = rp(:) - real(cubecenter(:), dp)*dr(:)
1350 IF (rsgrid%desc%perd(i) == 1)
THEN
1353 offset =
modulo(cubecenter(i) + start, ng(i)) + 1 - start
1354 length = min(ub_cube(i), ng(i) - offset) - start
1355 DO ig = start, start + length
1356 map(ig, i) = ig + offset
1358 IF (start + length .GE. ub_cube(i))
EXIT
1359 start = start + length + 1
1363 offset =
modulo(cubecenter(i) + lb_cube(i) + rsgrid%desc%lb(i) - rsgrid%lb_local(i), ng(i)) + 1 - lb_cube(i)
1365 IF (ub_cube(i) + offset > ubound(grid, i) .OR. lb_cube(i) + offset < lbound(grid, i))
THEN
1368 DO ig = lb_cube(i), ub_cube(i)
1369 map(ig, i) = ig + offset
1376 kgmin = sphere_bounds(sci)
1382 jgmin = sphere_bounds(sci)
1384 z = (real(kg, dp) + real(cubecenter(3), dp))*dr(3)
1385 z2 = (real(kg2, dp) + real(cubecenter(3), dp))*dr(3)
1390 igmin = sphere_bounds(sci)
1393 y = (real(jg, dp) + real(cubecenter(2), dp))*dr(2)
1394 y2 = (real(jg2, dp) + real(cubecenter(2), dp))*dr(2)
1395 DO ig = igmin, igmax
1397 x = (real(ig, dp) + real(cubecenter(1), dp))*dr(1)
1398 point(1, 1) = x; point(2, 1) = y; point(3, 1) = z
1399 point(1, 2) = x; point(2, 2) = y2; point(3, 2) = z
1400 point(1, 3) = x; point(2, 3) = y; point(3, 3) = z2
1401 point(1, 4) = x; point(2, 4) = y2; point(3, 4) = z2
1403 res(1) = (point(ir, 1) - rb(ir)) - gauge(i, j, k)
1404 res(2) = (point(ir, 2) - rb(ir)) - gauge(i, j2, k)
1405 res(3) = (point(ir, 3) - rb(ir)) - gauge(i, j, k2)
1406 res(4) = (point(ir, 4) - rb(ir)) - gauge(i, j2, k2)
1408 grid_buf(i, j, k) = grid_buf(i, j, k) + grid(i, j, k)*res(1)
1409 grid_buf(i, j2, k) = grid_buf(i, j2, k) + grid(i, j2, k)*res(2)
1410 grid_buf(i, j, k2) = grid_buf(i, j, k2) + grid(i, j, k2)*res(3)
1411 grid_buf(i, j2, k2) = grid_buf(i, j2, k2) + grid(i, j2, k2)*res(4)
1415 END SUBROUTINE collocate_gauge_ortho
1422 SUBROUTINE current_set_gauge(current_env, qs_env)
1424 TYPE(current_env_type) :: current_env
1425 TYPE(qs_environment_type),
POINTER :: qs_env
1427 CHARACTER(LEN=*),
PARAMETER :: routinen =
'current_set_gauge'
1431 REAL(dp),
ALLOCATABLE,
DIMENSION(:, :) :: box_data
1432 INTEGER :: handle, igrid_level, nbox(3), gauge
1433 INTEGER,
ALLOCATABLE,
DIMENSION(:, :, :) :: box_ptr
1434 TYPE(realspace_grid_desc_p_type),
DIMENSION(:), &
1436 TYPE(pw_env_type),
POINTER :: pw_env
1437 TYPE(realspace_grid_type),
DIMENSION(:, :),
POINTER :: rs_gauge
1439 TYPE(box_type),
DIMENSION(:, :, :),
POINTER :: box
1440 LOGICAL :: use_old_gauge_atom
1442 NULLIFY (rs_gauge, box)
1444 CALL timeset(routinen, handle)
1446 CALL get_current_env(current_env=current_env, &
1447 use_old_gauge_atom=use_old_gauge_atom, &
1448 rs_gauge=rs_gauge, &
1451 IF (gauge .EQ. current_gauge_atom)
THEN
1452 CALL get_qs_env(qs_env=qs_env, &
1454 CALL pw_env_get(pw_env=pw_env, &
1458 IF (use_old_gauge_atom)
THEN
1459 CALL box_atoms(qs_env)
1461 CALL box_atoms_new(current_env, qs_env, box)
1465 DO igrid_level = pw_env%gridlevel_info%ngrid_levels, 1, -1
1468 CALL rs_grid_create(rs_gauge(idir, igrid_level), rs_descs(igrid_level)%rs_desc)
1471 IF (use_old_gauge_atom)
THEN
1472 CALL collocate_gauge(current_env, qs_env, &
1473 rs_gauge(1, igrid_level), &
1474 rs_gauge(2, igrid_level), &
1475 rs_gauge(3, igrid_level))
1477 CALL collocate_gauge_new(current_env, qs_env, &
1478 rs_gauge(1, igrid_level), &
1479 rs_gauge(2, igrid_level), &
1480 rs_gauge(3, igrid_level), &
1486 ALLOCATE (current_env%rs_buf(pw_env%gridlevel_info%ngrid_levels))
1487 DO igrid_level = 1, pw_env%gridlevel_info%ngrid_levels
1488 CALL rs_grid_create(current_env%rs_buf(igrid_level), rs_descs(igrid_level)%rs_desc)
1491 DEALLOCATE (box_ptr, box_data)
1492 CALL deallocate_box(box)
1495 CALL timestop(handle)
1503 SUBROUTINE box_atoms(qs_env)
1504 TYPE(qs_environment_type),
POINTER :: qs_env
1506 REAL(kind=dp),
PARAMETER :: box_size_guess = 5.0_dp
1508 INTEGER :: i, iatom, ibox, ii, jbox, kbox, natms
1509 REAL(dp) :: offset(3)
1510 REAL(dp),
ALLOCATABLE,
DIMENSION(:, :) :: ratom
1511 TYPE(cell_type),
POINTER :: cell
1512 TYPE(particle_type),
DIMENSION(:),
POINTER :: particle_set
1513 TYPE(qs_kind_type),
DIMENSION(:),
POINTER :: qs_kind_set
1515 CALL get_qs_env(qs_env=qs_env, &
1516 qs_kind_set=qs_kind_set, &
1518 particle_set=particle_set)
1520 natms =
SIZE(particle_set, 1)
1521 ALLOCATE (ratom(3, natms))
1524 nbox(1) = ceiling(cell%hmat(1, 1)/box_size_guess)
1525 nbox(2) = ceiling(cell%hmat(2, 2)/box_size_guess)
1526 nbox(3) = ceiling(cell%hmat(3, 3)/box_size_guess)
1528 dbox(1) = cell%hmat(1, 1)/real(nbox(1), dp)
1529 dbox(2) = cell%hmat(2, 2)/real(nbox(2), dp)
1530 dbox(3) = cell%hmat(3, 3)/real(nbox(3), dp)
1532 ALLOCATE (box_ptr(0:nbox(1), 0:nbox(2) - 1, 0:nbox(3) - 1), box_data(3, natms))
1533 box_data(:, :) = huge(0.0_dp)
1534 box_ptr(:, :, :) = huge(0)
1536 offset(1) = cell%hmat(1, 1)*0.5_dp
1537 offset(2) = cell%hmat(2, 2)*0.5_dp
1538 offset(3) = cell%hmat(3, 3)*0.5_dp
1540 ratom(:, iatom) = pbc(particle_set(iatom)%r(:), cell) + offset(:)
1544 DO kbox = 0, nbox(3) - 1
1545 DO jbox = 0, nbox(2) - 1
1546 box_ptr(0, jbox, kbox) = i
1547 DO ibox = 0, nbox(1) - 1
1550 IF (int(ratom(1, iatom)/dbox(1)) .EQ. ibox .AND. &
1551 int(ratom(2, iatom)/dbox(2)) .EQ. jbox .AND. &
1552 int(ratom(3, iatom)/dbox(3)) .EQ. kbox)
THEN
1553 box_data(:, i) = ratom(:, iatom) - offset(:)
1558 box_ptr(ibox + 1, jbox, kbox) = box_ptr(ibox, jbox, kbox) + ii
1564 DO kbox = 0, nbox(3) - 1
1565 DO jbox = 0, nbox(2) - 1
1566 DO ibox = 0, nbox(1) - 1
1567 WRITE (*, *)
'box=', ibox, jbox, kbox
1568 WRITE (*, *)
'nbr atom=', box_ptr(ibox + 1, jbox, kbox) - box_ptr(ibox, jbox, kbox)
1569 DO iatom = box_ptr(ibox, jbox, kbox), box_ptr(ibox + 1, jbox, kbox) - 1
1570 WRITE (*, *)
'iatom=', iatom
1571 WRITE (*,
'(A,3E14.6)')
'coor=', box_data(:, iatom)
1578 END SUBROUTINE box_atoms
1588 SUBROUTINE collocate_gauge(current_env, qs_env, rs_grid_x, rs_grid_y, rs_grid_z)
1590 TYPE(current_env_type) :: current_env
1591 TYPE(qs_environment_type),
POINTER :: qs_env
1592 TYPE(realspace_grid_type),
INTENT(IN) :: rs_grid_x, rs_grid_y, rs_grid_z
1594 INTEGER :: i, iatom, ibeg, ibox, iend,
imax,
imin, &
1595 j, jatom, jbox, jmax, jmin, k, kbox, &
1596 kmax, kmin, lb(3), lb_local(3), natms, &
1598 REAL(kind=dp) :: ab, buf_tmp, dist, dr(3), &
1599 gauge_atom_radius, offset(3), pa, pb, &
1600 point(3), pra(3), r(3), res(3), summe, &
1602 REAL(kind=dp),
ALLOCATABLE,
DIMENSION(:) :: buf, nrm_atms_pnt
1603 REAL(kind=dp),
ALLOCATABLE,
DIMENSION(:, :) :: atms_pnt, ratom
1604 REAL(kind=dp),
DIMENSION(:, :, :),
POINTER :: grid_x, grid_y, grid_z
1605 TYPE(cell_type),
POINTER :: cell
1606 TYPE(particle_type),
DIMENSION(:),
POINTER :: particle_set
1607 TYPE(qs_kind_type),
DIMENSION(:),
POINTER :: qs_kind_set
1611 CALL get_current_env(current_env=current_env, &
1612 gauge_atom_radius=gauge_atom_radius)
1614 CALL get_qs_env(qs_env=qs_env, &
1615 qs_kind_set=qs_kind_set, &
1617 particle_set=particle_set)
1619 natms =
SIZE(particle_set, 1)
1620 dr(1) = rs_grid_x%desc%dh(1, 1)
1621 dr(2) = rs_grid_x%desc%dh(2, 2)
1622 dr(3) = rs_grid_x%desc%dh(3, 3)
1623 lb(:) = rs_grid_x%desc%lb(:)
1624 lb_local(:) = rs_grid_x%lb_local(:)
1625 grid_x => rs_grid_x%r(:, :, :)
1626 grid_y => rs_grid_y%r(:, :, :)
1627 grid_z => rs_grid_z%r(:, :, :)
1628 ng(:) = ubound(grid_x)
1629 offset(1) = cell%hmat(1, 1)*0.5_dp
1630 offset(2) = cell%hmat(2, 2)*0.5_dp
1631 offset(3) = cell%hmat(3, 3)*0.5_dp
1632 ALLOCATE (buf(natms), ratom(3, natms), atms_pnt(3, natms), nrm_atms_pnt(natms))
1639 point(3) = real(k - 1 + lb_local(3) - lb(3), dp)*dr(3)
1640 point(2) = real(j - 1 + lb_local(2) - lb(2), dp)*dr(2)
1641 point(1) = real(i - 1 + lb_local(1) - lb(1), dp)*dr(1)
1642 point = pbc(point, cell)
1646 kmin = int((point(3) + offset(3) - gauge_atom_radius)/dbox(3))
1647 kmax = int((point(3) + offset(3) + gauge_atom_radius)/dbox(3))
1648 IF (kmax - kmin + 1 .GT. nbox(3))
THEN
1652 DO kbox = kmin, kmax
1653 jmin = int((point(2) + offset(2) - gauge_atom_radius)/dbox(2))
1654 jmax = int((point(2) + offset(2) + gauge_atom_radius)/dbox(2))
1655 IF (jmax - jmin + 1 .GT. nbox(2))
THEN
1659 DO jbox = jmin, jmax
1660 imin = int((point(1) + offset(1) - gauge_atom_radius)/dbox(1))
1661 imax = int((point(1) + offset(1) + gauge_atom_radius)/dbox(1))
1662 IF (
imax -
imin + 1 .GT. nbox(1))
THEN
1668 iend = box_ptr(
modulo(ibox, nbox(1)) + 1,
modulo(jbox, nbox(2)),
modulo(kbox, nbox(3))) - 1
1669 DO iatom = ibeg, iend
1670 r(:) = pbc(box_data(:, iatom) - point(:), cell) + point(:)
1671 dist = (r(1) - point(1))**2 + (r(2) - point(2))**2 + (r(3) - point(3))**2
1672 IF (dist .LT. gauge_atom_radius**2)
THEN
1673 natms_local = natms_local + 1
1674 ratom(:, natms_local) = r(:)
1680 atms_pnt(1, natms_local) = x
1681 atms_pnt(2, natms_local) = y
1682 atms_pnt(3, natms_local) = z
1683 nrm_atms_pnt(natms_local) = sqrt(x*x + y*y + z*z)
1690 IF (natms_local .GT. 0)
THEN
1693 DO iatom = 1, natms_local
1695 pra(1) = atms_pnt(1, iatom)
1696 pra(2) = atms_pnt(2, iatom)
1697 pra(3) = atms_pnt(3, iatom)
1698 pa = nrm_atms_pnt(iatom)
1699 DO jatom = 1, natms_local
1700 IF (iatom .EQ. jatom) cycle
1701 pb = nrm_atms_pnt(jatom)
1702 x = pra(1) - atms_pnt(1, jatom)
1703 y = pra(2) - atms_pnt(2, jatom)
1704 z = pra(3) - atms_pnt(3, jatom)
1705 ab = sqrt(x*x + y*y + z*z)
1708 tmp = 0.5_dp*(3.0_dp - tmp*tmp)*tmp
1709 tmp = 0.5_dp*(3.0_dp - tmp*tmp)*tmp
1710 tmp = 0.5_dp*(3.0_dp - tmp*tmp)*tmp
1711 buf_tmp = buf_tmp*0.5_dp*(1.0_dp - tmp)
1713 buf(iatom) = buf_tmp
1719 DO iatom = 1, natms_local
1720 res(1) = res(1) + ratom(1, iatom)*buf(iatom)
1721 res(2) = res(2) + ratom(2, iatom)*buf(iatom)
1722 res(3) = res(3) + ratom(3, iatom)*buf(iatom)
1723 summe = summe + buf(iatom)
1725 res(1) = res(1)/summe
1726 res(2) = res(2)/summe
1727 res(3) = res(3)/summe
1728 grid_x(i, j, k) = point(1) - res(1)
1729 grid_y(i, j, k) = point(2) - res(2)
1730 grid_z(i, j, k) = point(3) - res(3)
1732 grid_x(i, j, k) = 0.0_dp
1733 grid_y(i, j, k) = 0.0_dp
1734 grid_z(i, j, k) = 0.0_dp
1740 DEALLOCATE (buf, ratom, atms_pnt, nrm_atms_pnt)
1742 END SUBROUTINE collocate_gauge
1750 SUBROUTINE box_atoms_new(current_env, qs_env, box)
1751 TYPE(current_env_type) :: current_env
1752 TYPE(qs_environment_type),
POINTER :: qs_env
1753 TYPE(box_type),
DIMENSION(:, :, :),
POINTER :: box
1755 CHARACTER(LEN=*),
PARAMETER :: routinen =
'box_atoms_new'
1757 INTEGER :: handle, i, iatom, ibeg, ibox, iend, &
1758 ifind, ii,
imax,
imin, j, jatom, jbox, &
1759 jmax, jmin, k, kbox, kmax, kmin, &
1761 REAL(dp) :: gauge_atom_radius, offset(3), scale
1762 REAL(dp),
ALLOCATABLE,
DIMENSION(:, :) :: ratom
1763 REAL(dp),
DIMENSION(:, :),
POINTER :: r_ptr
1764 REAL(kind=dp) :: box_center(3), box_center_wrap(3), &
1765 box_size_guess, r(3)
1766 TYPE(cell_type),
POINTER :: cell
1767 TYPE(particle_type),
DIMENSION(:),
POINTER :: particle_set
1768 TYPE(qs_kind_type),
DIMENSION(:),
POINTER :: qs_kind_set
1770 CALL timeset(routinen, handle)
1772 CALL get_qs_env(qs_env=qs_env, &
1773 qs_kind_set=qs_kind_set, &
1775 particle_set=particle_set)
1777 CALL get_current_env(current_env=current_env, &
1778 gauge_atom_radius=gauge_atom_radius)
1782 box_size_guess = gauge_atom_radius/scale
1784 natms =
SIZE(particle_set, 1)
1785 ALLOCATE (ratom(3, natms))
1789 nbox(1) = ceiling(cell%hmat(1, 1)/box_size_guess)
1790 nbox(2) = ceiling(cell%hmat(2, 2)/box_size_guess)
1791 nbox(3) = ceiling(cell%hmat(3, 3)/box_size_guess)
1792 dbox(1) = cell%hmat(1, 1)/real(nbox(1), dp)
1793 dbox(2) = cell%hmat(2, 2)/real(nbox(2), dp)
1794 dbox(3) = cell%hmat(3, 3)/real(nbox(3), dp)
1795 ALLOCATE (box_ptr(0:nbox(1), 0:nbox(2) - 1, 0:nbox(3) - 1), box_data(3, natms))
1796 box_data(:, :) = huge(0.0_dp)
1797 box_ptr(:, :, :) = huge(0)
1799 offset(1) = cell%hmat(1, 1)*0.5_dp
1800 offset(2) = cell%hmat(2, 2)*0.5_dp
1801 offset(3) = cell%hmat(3, 3)*0.5_dp
1803 ratom(:, iatom) = pbc(particle_set(iatom)%r(:), cell)
1807 DO kbox = 0, nbox(3) - 1
1808 DO jbox = 0, nbox(2) - 1
1809 box_ptr(0, jbox, kbox) = i
1810 DO ibox = 0, nbox(1) - 1
1813 IF (
modulo(floor(ratom(1, iatom)/dbox(1)), nbox(1)) .EQ. ibox .AND. &
1814 modulo(floor(ratom(2, iatom)/dbox(2)), nbox(2)) .EQ. jbox .AND. &
1815 modulo(floor(ratom(3, iatom)/dbox(3)), nbox(3)) .EQ. kbox)
THEN
1816 box_data(:, i) = ratom(:, iatom)
1821 box_ptr(ibox + 1, jbox, kbox) = box_ptr(ibox, jbox, kbox) + ii
1827 DO kbox = 0, nbox(3) - 1
1828 DO jbox = 0, nbox(2) - 1
1829 DO ibox = 0, nbox(1) - 1
1830 IF (box_ptr(ibox + 1, jbox, kbox) - box_ptr(ibox, jbox, kbox) .GT. 0)
THEN
1831 WRITE (*, *)
'box=', ibox, jbox, kbox
1832 WRITE (*, *)
'nbr atom=', box_ptr(ibox + 1, jbox, kbox) - box_ptr(ibox, jbox, kbox)
1833 DO iatom = box_ptr(ibox, jbox, kbox), box_ptr(ibox + 1, jbox, kbox) - 1
1834 WRITE (*,
'(A,I3,3E14.6)')
'coor=', iatom, box_data(:, iatom)
1843 ALLOCATE (box(0:nbox(1) - 1, 0:nbox(2) - 1, 0:nbox(3) - 1))
1846 DO k = 0, nbox(3) - 1
1847 DO j = 0, nbox(2) - 1
1848 DO i = 0, nbox(1) - 1
1850 box_center(1) = (real(i, dp) + 0.5_dp)*dbox(1)
1851 box_center(2) = (real(j, dp) + 0.5_dp)*dbox(2)
1852 box_center(3) = (real(k, dp) + 0.5_dp)*dbox(3)
1853 box_center_wrap = pbc(box_center, cell)
1857 kmin = floor((box_center(3) - gauge_atom_radius)/dbox(3))
1858 kmax = floor((box_center(3) + gauge_atom_radius)/dbox(3))
1859 IF (kmax - kmin + 1 .GT. nbox(3))
THEN
1863 DO kbox = kmin, kmax
1864 jmin = floor((box_center(2) - gauge_atom_radius)/dbox(2))
1865 jmax = floor((box_center(2) + gauge_atom_radius)/dbox(2))
1866 IF (jmax - jmin + 1 .GT. nbox(2))
THEN
1870 DO jbox = jmin, jmax
1871 imin = floor((box_center(1) - gauge_atom_radius)/dbox(1))
1872 imax = floor((box_center(1) + gauge_atom_radius)/dbox(1))
1873 IF (
imax -
imin + 1 .GT. nbox(1))
THEN
1879 iend = box_ptr(
modulo(ibox, nbox(1)) + 1,
modulo(jbox, nbox(2)),
modulo(kbox, nbox(3))) - 1
1880 DO iatom = ibeg, iend
1881 r = pbc(box_center_wrap(:) - box_data(:, iatom), cell)
1882 IF (abs(r(1)) .LE. (scale + 0.5_dp)*dbox(1) .AND. &
1883 abs(r(2)) .LE. (scale + 0.5_dp)*dbox(2) .AND. &
1884 abs(r(3)) .LE. (scale + 0.5_dp)*dbox(3))
THEN
1885 natms_local = natms_local + 1
1886 ratom(:, natms_local) = box_data(:, iatom)
1894 box(i, j, k)%n = natms_local
1895 NULLIFY (box(i, j, k)%r)
1896 IF (natms_local .GT. 0)
THEN
1897 ALLOCATE (box(i, j, k)%r(3, natms_local))
1898 r_ptr => box(i, j, k)%r
1899 CALL dcopy(3*natms_local, ratom(1, 1), 1, r_ptr(1, 1), 1)
1906 DO k = 0, nbox(3) - 1
1907 DO j = 0, nbox(2) - 1
1908 DO i = 0, nbox(1) - 1
1909 IF (box(i, j, k)%n .GT. 0)
THEN
1911 WRITE (*, *)
'box=', i, j, k
1912 box_center(1) = (real(i, dp) + 0.5_dp)*dbox(1)
1913 box_center(2) = (real(j, dp) + 0.5_dp)*dbox(2)
1914 box_center(3) = (real(k, dp) + 0.5_dp)*dbox(3)
1915 box_center = pbc(box_center, cell)
1916 WRITE (*,
'(A,3E14.6)')
'box_center=', box_center
1917 WRITE (*, *)
'nbr atom=', box(i, j, k)%n
1918 r_ptr => box(i, j, k)%r
1919 DO iatom = 1, box(i, j, k)%n
1920 WRITE (*,
'(A,I3,3E14.6)')
'coor=', iatom, r_ptr(:, iatom)
1921 r(:) = pbc(box_center(:) - r_ptr(:, iatom), cell)
1922 IF (abs(r(1)) .GT. (scale + 0.5_dp)*dbox(1) .OR. &
1923 abs(r(2)) .GT. (scale + 0.5_dp)*dbox(2) .OR. &
1924 abs(r(3)) .GT. (scale + 0.5_dp)*dbox(3))
THEN
1925 WRITE (*, *)
'error too many atoms'
1926 WRITE (*, *)
'dist=', abs(r(:))
1927 WRITE (*, *)
'large_dist=', (scale + 0.5_dp)*dbox
1938 DO k = 0, nbox(3) - 1
1939 DO j = 0, nbox(2) - 1
1940 DO i = 0, nbox(1) - 1
1941 box_center(1) = (real(i, dp) + 0.5_dp)*dbox(1)
1942 box_center(2) = (real(j, dp) + 0.5_dp)*dbox(2)
1943 box_center(3) = (real(k, dp) + 0.5_dp)*dbox(3)
1944 box_center = pbc(box_center, cell)
1945 r_ptr => box(i, j, k)%r
1947 r(:) = pbc(box_center(:) - ratom(:, iatom), cell)
1949 DO jatom = 1, box(i, j, k)%n
1950 IF (sum(abs(ratom(:, iatom) - r_ptr(:, jatom))) .LT. 1e-10_dp) ifind = 1
1953 IF (ifind .EQ. 0)
THEN
1955 IF (dot_product(r, r) .LT. (gauge_atom_radius*gauge_atom_radius))
THEN
1956 WRITE (*, *)
'error atom too close'
1957 WRITE (*, *)
'iatom', iatom
1958 WRITE (*, *)
'box_center', box_center
1959 WRITE (*, *)
'ratom', ratom(:, iatom)
1960 WRITE (*, *)
'gauge_atom_radius', gauge_atom_radius
1972 CALL timestop(handle)
1974 END SUBROUTINE box_atoms_new
1985 SUBROUTINE collocate_gauge_new(current_env, qs_env, rs_grid_x, rs_grid_y, rs_grid_z, box)
1987 TYPE(current_env_type) :: current_env
1988 TYPE(qs_environment_type),
POINTER :: qs_env
1989 TYPE(realspace_grid_type),
INTENT(IN) :: rs_grid_x, rs_grid_y, rs_grid_z
1990 TYPE(box_type),
DIMENSION(:, :, :),
POINTER :: box
1992 CHARACTER(LEN=*),
PARAMETER :: routinen =
'collocate_gauge_new'
1994 INTEGER :: delta_lb(3), handle, i, iatom, ib, ibe, ibox, ibs, ie, is, j, jatom, jb, jbe, &
1995 jbox, jbs, je, js, k, kb, kbe, kbox, kbs, ke, ks, lb(3), lb_local(3), natms, &
1996 natms_local0, natms_local1, ng(3)
1997 REAL(dp),
DIMENSION(:, :),
POINTER :: r_ptr
1998 REAL(kind=dp) :: ab, box_center(3), buf_tmp, dist, dr(3), &
1999 gauge_atom_radius, offset(3), pa, pb, &
2000 point(3), pra(3), r(3), res(3), summe, &
2002 REAL(kind=dp),
ALLOCATABLE,
DIMENSION(:) :: buf, nrm_atms_pnt
2003 REAL(kind=dp),
ALLOCATABLE,
DIMENSION(:, :) :: atms_pnt, ratom
2004 REAL(kind=dp),
DIMENSION(:, :, :),
POINTER :: grid_x, grid_y, grid_z
2005 TYPE(cell_type),
POINTER :: cell
2006 TYPE(particle_type),
DIMENSION(:),
POINTER :: particle_set
2007 TYPE(qs_kind_type),
DIMENSION(:),
POINTER :: qs_kind_set
2009 CALL timeset(routinen, handle)
2012 CALL get_current_env(current_env=current_env, &
2013 gauge_atom_radius=gauge_atom_radius)
2015 CALL get_qs_env(qs_env=qs_env, &
2016 qs_kind_set=qs_kind_set, &
2018 particle_set=particle_set)
2020 natms =
SIZE(particle_set, 1)
2021 dr(1) = rs_grid_x%desc%dh(1, 1)
2022 dr(2) = rs_grid_x%desc%dh(2, 2)
2023 dr(3) = rs_grid_x%desc%dh(3, 3)
2024 lb(:) = rs_grid_x%desc%lb(:)
2025 lb_local(:) = rs_grid_x%lb_local(:)
2026 grid_x => rs_grid_x%r(:, :, :)
2027 grid_y => rs_grid_y%r(:, :, :)
2028 grid_z => rs_grid_z%r(:, :, :)
2029 ng(:) = ubound(grid_x)
2030 delta_lb(:) = lb_local(:) - lb(:)
2031 offset(1) = cell%hmat(1, 1)*0.5_dp
2032 offset(2) = cell%hmat(2, 2)*0.5_dp
2033 offset(3) = cell%hmat(3, 3)*0.5_dp
2034 ALLOCATE (buf(natms), ratom(3, natms), atms_pnt(3, natms), nrm_atms_pnt(natms))
2037 ibs = floor(real(delta_lb(1), dp)*dr(1)/dbox(1))
2038 ibe = floor(real(ng(1) - 1 + delta_lb(1), dp)*dr(1)/dbox(1))
2039 jbs = floor(real(delta_lb(2), dp)*dr(2)/dbox(2))
2040 jbe = floor(real(ng(2) - 1 + delta_lb(2), dp)*dr(2)/dbox(2))
2041 kbs = floor(real(delta_lb(3), dp)*dr(3)/dbox(3))
2042 kbe = floor(real(ng(3) - 1 + delta_lb(3), dp)*dr(3)/dbox(3))
2048 ibox =
modulo(ib, nbox(1))
2049 jbox =
modulo(jb, nbox(2))
2050 kbox =
modulo(kb, nbox(3))
2052 is = max(ceiling(real(ib, dp)*dbox(1)/dr(1)), delta_lb(1)) - delta_lb(1) + 1
2053 ie = min(floor(real(ib + 1, dp)*dbox(1)/dr(1)), ng(1) - 1 + delta_lb(1)) - delta_lb(1) + 1
2054 js = max(ceiling(real(jb, dp)*dbox(2)/dr(2)), delta_lb(2)) - delta_lb(2) + 1
2055 je = min(floor(real(jb + 1, dp)*dbox(2)/dr(2)), ng(2) - 1 + delta_lb(2)) - delta_lb(2) + 1
2056 ks = max(ceiling(real(kb, dp)*dbox(3)/dr(3)), delta_lb(3)) - delta_lb(3) + 1
2057 ke = min(floor(real(kb + 1, dp)*dbox(3)/dr(3)), ng(3) - 1 + delta_lb(3)) - delta_lb(3) + 1
2061 IF (real(ks - 1 + delta_lb(3), dp)*dr(3) .LT. real(kb, dp)*dbox(3) .OR. &
2062 REAL(ke - 1 + delta_lb(3), dp)*dr(3) .GT.
REAL(kb + 1, dp)*dbox(3)) then
2063 WRITE (*, *)
'box_k', real(kb, dp)*dbox(3), real(kb + 1, dp)*dbox(3)
2064 WRITE (*, *)
'point_k', real(ks - 1 + delta_lb(3), dp)*dr(3), real(ke - 1 + delta_lb(3), dp)*dr(3)
2065 WRITE (*, *)
'ibox', ibox,
'jbox', jbox,
'kbox', kbox
2066 WRITE (*, *)
'is,ie', is, ie,
' js,je', js, je,
' ks,ke', ks, ke
2067 WRITE (*, *)
'ibs,ibe', ibs, ibe,
' jbs,jbe', jbs, jbe,
' kbs,kbe', kbs, kbe
2068 cpabort(
"we stop_k")
2070 IF (real(js - 1 + delta_lb(2), dp)*dr(2) .LT. real(jb, dp)*dbox(2) .OR. &
2071 REAL(je - 1 + delta_lb(2), dp)*dr(2) .GT.
REAL(jb + 1, dp)*dbox(2)) then
2072 WRITE (*, *)
'box_j', real(jb, dp)*dbox(2), real(jb + 1, dp)*dbox(2)
2073 WRITE (*, *)
'point_j', real(js - 1 + delta_lb(2), dp)*dr(2), real(je - 1 + delta_lb(2), dp)*dr(2)
2074 WRITE (*, *)
'is,ie', is, ie,
' js,je', js, je,
' ks,ke', ks, ke
2075 WRITE (*, *)
'ibs,ibe', ibs, ibe,
' jbs,jbe', jbs, jbe,
' kbs,kbe', kbs, kbe
2076 cpabort(
"we stop_j")
2078 IF (real(is - 1 + delta_lb(1), dp)*dr(1) .LT. real(ib, dp)*dbox(1) .OR. &
2079 REAL(ie - 1 + delta_lb(1), dp)*dr(1) .GT.
REAL(ib + 1, dp)*dbox(1)) then
2080 WRITE (*, *)
'box_i', real(ib, dp)*dbox(1), real(ib + 1, dp)*dbox(1)
2081 WRITE (*, *)
'point_i', real(is - 1 + delta_lb(1), dp)*dr(1), real(ie - 1 + delta_lb(1), dp)*dr(1)
2082 WRITE (*, *)
'is,ie', is, ie,
' js,je', js, je,
' ks,ke', ks, ke
2083 WRITE (*, *)
'ibs,ibe', ibs, ibe,
' jbs,jbe', jbs, jbe,
' kbs,kbe', kbs, kbe
2084 cpabort(
"we stop_i")
2089 box_center(1) = (real(ibox, dp) + 0.5_dp)*dbox(1)
2090 box_center(2) = (real(jbox, dp) + 0.5_dp)*dbox(2)
2091 box_center(3) = (real(kbox, dp) + 0.5_dp)*dbox(3)
2094 natms_local0 = box(ibox, jbox, kbox)%n
2095 r_ptr => box(ibox, jbox, kbox)%r
2098 IF (natms_local0 .GT. 0)
THEN
2104 point(1) = real(i - 1 + delta_lb(1), dp)*dr(1)
2105 point(2) = real(j - 1 + delta_lb(2), dp)*dr(2)
2106 point(3) = real(k - 1 + delta_lb(3), dp)*dr(3)
2107 point = pbc(point, cell)
2111 DO iatom = 1, natms_local0
2112 r(:) = pbc(r_ptr(:, iatom) - point(:), cell) + point(:)
2113 dist = (r(1) - point(1))**2 + (r(2) - point(2))**2 + (r(3) - point(3))**2
2114 IF (dist .LT. gauge_atom_radius**2)
THEN
2115 natms_local1 = natms_local1 + 1
2116 ratom(:, natms_local1) = r(:)
2122 atms_pnt(1, natms_local1) = x
2123 atms_pnt(2, natms_local1) = y
2124 atms_pnt(3, natms_local1) = z
2125 nrm_atms_pnt(natms_local1) = sqrt(x*x + y*y + z*z)
2130 IF (natms_local1 .GT. 0)
THEN
2133 DO iatom = 1, natms_local1
2135 pra(1) = atms_pnt(1, iatom)
2136 pra(2) = atms_pnt(2, iatom)
2137 pra(3) = atms_pnt(3, iatom)
2138 pa = nrm_atms_pnt(iatom)
2139 DO jatom = 1, natms_local1
2140 IF (iatom .EQ. jatom) cycle
2141 pb = nrm_atms_pnt(jatom)
2142 x = pra(1) - atms_pnt(1, jatom)
2143 y = pra(2) - atms_pnt(2, jatom)
2144 z = pra(3) - atms_pnt(3, jatom)
2145 ab = sqrt(x*x + y*y + z*z)
2148 tmp = 0.5_dp*(3.0_dp - tmp*tmp)*tmp
2149 tmp = 0.5_dp*(3.0_dp - tmp*tmp)*tmp
2150 tmp = 0.5_dp*(3.0_dp - tmp*tmp)*tmp
2151 buf_tmp = buf_tmp*0.5_dp*(1.0_dp - tmp)
2153 buf(iatom) = buf_tmp
2159 DO iatom = 1, natms_local1
2160 res(1) = res(1) + ratom(1, iatom)*buf(iatom)
2161 res(2) = res(2) + ratom(2, iatom)*buf(iatom)
2162 res(3) = res(3) + ratom(3, iatom)*buf(iatom)
2163 summe = summe + buf(iatom)
2165 res(1) = res(1)/summe
2166 res(2) = res(2)/summe
2167 res(3) = res(3)/summe
2168 grid_x(i, j, k) = point(1) - res(1)
2169 grid_y(i, j, k) = point(2) - res(2)
2170 grid_z(i, j, k) = point(3) - res(3)
2172 grid_x(i, j, k) = 0.0_dp
2173 grid_y(i, j, k) = 0.0_dp
2174 grid_z(i, j, k) = 0.0_dp
2186 grid_x(i, j, k) = 0.0_dp
2187 grid_y(i, j, k) = 0.0_dp
2188 grid_z(i, j, k) = 0.0_dp
2199 DEALLOCATE (buf, ratom, atms_pnt, nrm_atms_pnt)
2201 CALL timestop(handle)
2203 END SUBROUTINE collocate_gauge_new
2209 SUBROUTINE deallocate_box(box)
2210 TYPE(box_type),
DIMENSION(:, :, :),
POINTER :: box
2214 IF (
ASSOCIATED(box))
THEN
2215 DO k = lbound(box, 3), ubound(box, 3)
2216 DO j = lbound(box, 2), ubound(box, 2)
2217 DO i = lbound(box, 1), ubound(box, 1)
2218 IF (
ASSOCIATED(box(i, j, k)%r))
THEN
2219 DEALLOCATE (box(i, j, k)%r)
2226 END SUBROUTINE deallocate_box
2227 END SUBROUTINE current_set_gauge
2237 TYPE(current_env_type) :: current_env
2238 TYPE(qs_environment_type),
POINTER :: qs_env
2239 INTEGER,
INTENT(IN) :: ib
2241 IF (current_env%full)
THEN
2242 CALL current_build_chi_many_centers(current_env, qs_env, ib)
2243 ELSE IF (current_env%nbr_center(1) > 1)
THEN
2244 CALL current_build_chi_many_centers(current_env, qs_env, ib)
2246 CALL current_build_chi_one_center(current_env, qs_env, ib)
2257 SUBROUTINE current_build_chi_many_centers(current_env, qs_env, iB)
2259 TYPE(current_env_type) :: current_env
2260 TYPE(qs_environment_type),
POINTER :: qs_env
2261 INTEGER,
INTENT(IN) :: ib
2263 CHARACTER(LEN=*),
PARAMETER :: routinen =
'current_build_chi_many_centers'
2265 INTEGER :: handle, icenter, idir, idir2, ii, iib, iii, iiib, ispin, istate, j, jstate, &
2266 max_states, nao, natom, nbr_center(2), nmo, nspins, nstate_loc, nstates(2), output_unit
2267 INTEGER,
ALLOCATABLE,
DIMENSION(:) :: first_sgf, last_sgf
2268 INTEGER,
DIMENSION(:),
POINTER :: row_blk_sizes
2269 LOGICAL :: chi_pbc, gapw
2270 REAL(dp) :: chi(3), chi_tmp, contrib, contrib2, &
2271 dk(3), int_current(3), &
2272 int_current_tmp, maxocc
2273 TYPE(cell_type),
POINTER :: cell
2274 TYPE(cp_2d_i_p_type),
DIMENSION(:),
POINTER :: center_list
2275 TYPE(cp_2d_r_p_type),
DIMENSION(:),
POINTER :: centers_set
2276 TYPE(cp_fm_struct_type),
POINTER :: tmp_fm_struct
2277 TYPE(cp_fm_type) :: psi0, psi_d, psi_p1, psi_p2, psi_rxp
2278 TYPE(cp_fm_type),
DIMENSION(3) :: p_rxp, r_p1, r_p2
2279 TYPE(cp_fm_type),
DIMENSION(9, 3) :: rr_p1, rr_p2, rr_rxp
2280 TYPE(cp_fm_type),
DIMENSION(:),
POINTER :: psi0_order
2281 TYPE(cp_fm_type),
DIMENSION(:, :),
POINTER :: psi1_d, psi1_p, psi1_rxp
2282 TYPE(cp_fm_type),
POINTER :: mo_coeff
2283 TYPE(cp_logger_type),
POINTER :: logger
2284 TYPE(dbcsr_distribution_type),
POINTER :: dbcsr_dist
2285 TYPE(dbcsr_p_type),
DIMENSION(:),
POINTER :: op_mom_ao, op_p_ao
2286 TYPE(dbcsr_p_type),
DIMENSION(:, :),
POINTER :: op_mom_der_ao
2287 TYPE(dft_control_type),
POINTER :: dft_control
2288 TYPE(mo_set_type),
DIMENSION(:),
POINTER :: mos
2289 TYPE(mp_para_env_type),
POINTER :: para_env
2290 TYPE(neighbor_list_set_p_type),
DIMENSION(:), &
2291 POINTER :: sab_all, sab_orb
2292 TYPE(particle_type),
DIMENSION(:),
POINTER :: particle_set
2293 TYPE(qs_kind_type),
DIMENSION(:),
POINTER :: qs_kind_set
2297 CALL timeset(routinen, handle)
2299 NULLIFY (dft_control, mos, para_env, mo_coeff, op_mom_ao, &
2300 op_mom_der_ao, center_list, centers_set, &
2301 op_p_ao, psi1_p, psi1_rxp, psi1_d, &
2302 cell, particle_set, qs_kind_set)
2304 logger => cp_get_default_logger()
2305 output_unit = cp_logger_get_default_io_unit(logger)
2307 CALL get_qs_env(qs_env=qs_env, &
2308 dft_control=dft_control, &
2310 para_env=para_env, &
2312 dbcsr_dist=dbcsr_dist, &
2313 particle_set=particle_set, &
2314 qs_kind_set=qs_kind_set, &
2318 nspins = dft_control%nspins
2319 gapw = dft_control%qs_control%gapw
2321 CALL get_current_env(current_env=current_env, &
2324 nbr_center=nbr_center, &
2325 center_list=center_list, &
2326 centers_set=centers_set, &
2328 psi1_rxp=psi1_rxp, &
2331 psi0_order=psi0_order)
2335 DO ispin = 1, nspins
2336 DO icenter = 1, nbr_center(ispin)
2337 max_states = max(max_states, center_list(ispin)%array(1, icenter + 1)&
2338 & - center_list(ispin)%array(1, icenter))
2344 CALL dbcsr_allocate_matrix_set(op_mom_ao, 9)
2345 CALL dbcsr_allocate_matrix_set(op_mom_der_ao, 9, 3)
2348 natom =
SIZE(particle_set, 1)
2349 ALLOCATE (first_sgf(natom))
2350 ALLOCATE (last_sgf(natom))
2351 CALL get_particle_set(particle_set, qs_kind_set, &
2352 first_sgf=first_sgf, &
2354 ALLOCATE (row_blk_sizes(natom))
2355 CALL dbcsr_convert_offsets_to_sizes(first_sgf, row_blk_sizes, last_sgf)
2356 DEALLOCATE (first_sgf)
2357 DEALLOCATE (last_sgf)
2360 ALLOCATE (op_mom_ao(1)%matrix)
2361 CALL dbcsr_create(matrix=op_mom_ao(1)%matrix, &
2363 dist=dbcsr_dist, matrix_type=dbcsr_type_no_symmetry, &
2364 row_blk_size=row_blk_sizes, col_blk_size=row_blk_sizes, &
2365 mutable_work=.true.)
2366 CALL cp_dbcsr_alloc_block_from_nbl(op_mom_ao(1)%matrix, sab_all)
2369 ALLOCATE (op_mom_der_ao(1, idir2)%matrix)
2370 CALL dbcsr_copy(op_mom_der_ao(1, idir2)%matrix, op_mom_ao(1)%matrix, &
2371 "op_mom_der_ao"//
"-"//trim(adjustl(cp_to_string(idir2))))
2374 DO idir = 2,
SIZE(op_mom_ao, 1)
2375 ALLOCATE (op_mom_ao(idir)%matrix)
2376 CALL dbcsr_copy(op_mom_ao(idir)%matrix, op_mom_ao(1)%matrix, &
2377 "op_mom_ao"//
"-"//trim(adjustl(cp_to_string(idir))))
2379 ALLOCATE (op_mom_der_ao(idir, idir2)%matrix)
2380 CALL dbcsr_copy(op_mom_der_ao(idir, idir2)%matrix, op_mom_ao(1)%matrix, &
2381 "op_mom_der_ao"//
"-"//trim(adjustl(cp_to_string(idir*idir2))))
2385 CALL dbcsr_allocate_matrix_set(op_p_ao, 3)
2386 ALLOCATE (op_p_ao(1)%matrix)
2387 CALL dbcsr_create(matrix=op_p_ao(1)%matrix, &
2389 dist=dbcsr_dist, matrix_type=dbcsr_type_antisymmetric, &
2390 row_blk_size=row_blk_sizes, col_blk_size=row_blk_sizes, &
2391 mutable_work=.true.)
2392 CALL cp_dbcsr_alloc_block_from_nbl(op_p_ao(1)%matrix, sab_orb)
2395 ALLOCATE (op_p_ao(idir)%matrix)
2396 CALL dbcsr_copy(op_p_ao(idir)%matrix, op_p_ao(1)%matrix, &
2397 "op_p_ao"//
"-"//trim(adjustl(cp_to_string(idir))))
2401 DEALLOCATE (row_blk_sizes)
2405 mo_coeff => psi0_order(1)
2406 NULLIFY (tmp_fm_struct)
2407 CALL cp_fm_struct_create(tmp_fm_struct, nrow_global=nao, &
2408 ncol_global=max_states, para_env=para_env, &
2409 context=mo_coeff%matrix_struct%context)
2410 CALL cp_fm_create(psi0, tmp_fm_struct)
2411 CALL cp_fm_create(psi_d, tmp_fm_struct)
2412 CALL cp_fm_create(psi_rxp, tmp_fm_struct)
2413 CALL cp_fm_create(psi_p1, tmp_fm_struct)
2414 CALL cp_fm_create(psi_p2, tmp_fm_struct)
2415 CALL cp_fm_struct_release(tmp_fm_struct)
2417 CALL cp_fm_struct_create(tmp_fm_struct, nrow_global=nao, &
2418 ncol_global=max_states, para_env=para_env, &
2419 context=mo_coeff%matrix_struct%context)
2421 CALL cp_fm_create(p_rxp(idir), tmp_fm_struct)
2422 CALL cp_fm_create(r_p1(idir), tmp_fm_struct)
2423 CALL cp_fm_create(r_p2(idir), tmp_fm_struct)
2425 CALL cp_fm_create(rr_rxp(idir2, idir), tmp_fm_struct)
2426 CALL cp_fm_create(rr_p1(idir2, idir), tmp_fm_struct)
2427 CALL cp_fm_create(rr_p2(idir2, idir), tmp_fm_struct)
2430 CALL cp_fm_struct_release(tmp_fm_struct)
2435 CALL build_lin_mom_matrix(qs_env, op_p_ao)
2440 CALL set_vecp(ib, iib, iiib)
2441 DO ispin = 1, nspins
2444 nmo = nstates(ispin)
2445 mo_coeff => psi0_order(ispin)
2446 CALL get_mo_set(mo_set=mos(ispin), maxocc=maxocc)
2450 int_current = 0.0_dp
2453 DO icenter = 1, nbr_center(ispin)
2456 dk(1:3) = centers_set(ispin)%array(1:3, icenter)
2461 CALL dbcsr_set(op_mom_ao(idir)%matrix, 0.0_dp)
2463 CALL dbcsr_set(op_mom_der_ao(idir, idir2)%matrix, 0.0_dp)
2466 CALL rrc_xyz_der_ao(op_mom_ao, op_mom_der_ao, qs_env, dk, order=2, &
2467 minimum_image=.false., soft=gapw)
2470 CALL cp_fm_set_all(psi0, 0.0_dp)
2471 CALL cp_fm_set_all(psi_rxp, 0.0_dp)
2472 CALL cp_fm_set_all(psi_d, 0.0_dp)
2473 CALL cp_fm_set_all(psi_p1, 0.0_dp)
2474 CALL cp_fm_set_all(psi_p2, 0.0_dp)
2475 nstate_loc = center_list(ispin)%array(1, icenter + 1) - center_list(ispin)%array(1, icenter)
2477 DO j = center_list(ispin)%array(1, icenter), center_list(ispin)%array(1, icenter + 1) - 1
2478 istate = center_list(ispin)%array(2, j)
2481 CALL cp_fm_to_fm(mo_coeff, psi0, 1, istate, jstate)
2483 CALL cp_fm_to_fm(psi1_rxp(ispin, ib), psi_rxp, 1, istate, jstate)
2484 IF (current_env%full)
CALL cp_fm_to_fm(psi1_d(ispin, ib), psi_d, 1, istate, jstate)
2487 CALL cp_fm_to_fm(psi1_p(ispin, iib), psi_p1, 1, istate, jstate)
2488 CALL cp_fm_to_fm(psi1_p(ispin, iiib), psi_p2, 1, istate, jstate)
2494 IF (current_env%full)
CALL cp_fm_scale_and_add(1.0_dp, psi_rxp, -1.0_dp, psi_d)
2497 CALL set_vecp(idir, ii, iii)
2498 CALL cp_dbcsr_sm_fm_multiply(op_p_ao(idir)%matrix, psi_rxp, &
2499 p_rxp(idir), ncol=nstate_loc, alpha=1.e0_dp)
2500 IF (iiib .EQ. iii .OR. iiib .EQ. ii)
THEN
2501 CALL cp_dbcsr_sm_fm_multiply(op_mom_ao(idir)%matrix, psi_p1, &
2502 r_p1(idir), ncol=nstate_loc, alpha=1.e0_dp)
2504 IF (iib .EQ. iii .OR. iib .EQ. ii)
THEN
2505 CALL cp_dbcsr_sm_fm_multiply(op_mom_ao(idir)%matrix, psi_p2, &
2506 r_p2(idir), ncol=nstate_loc, alpha=1.e0_dp)
2509 IF (idir2 .EQ. ii .OR. idir2 .EQ. iii)
THEN
2510 CALL cp_dbcsr_sm_fm_multiply(op_mom_der_ao(idir2, idir)%matrix, psi_rxp, &
2511 rr_rxp(idir2, idir), ncol=nstate_loc, alpha=1.e0_dp)
2514 IF (idir2 .EQ. ind_m2(ii, iiib) .OR. idir2 .EQ. ind_m2(iii, iiib) .OR. idir2 .EQ. iiib)
THEN
2515 CALL cp_dbcsr_sm_fm_multiply(op_mom_der_ao(idir2, idir)%matrix, psi_p1, &
2516 rr_p1(idir2, idir), ncol=nstate_loc, alpha=1.e0_dp)
2519 IF (idir2 .EQ. ind_m2(ii, iib) .OR. idir2 .EQ. ind_m2(iii, iib) .OR. idir2 .EQ. iib)
THEN
2520 CALL cp_dbcsr_sm_fm_multiply(op_mom_der_ao(idir2, idir)%matrix, psi_p2, &
2521 rr_p2(idir2, idir), ncol=nstate_loc, alpha=1.e0_dp)
2534 int_current_tmp = 0.0_dp
2537 CALL set_vecp(idir, ii, iii)
2542 CALL cp_fm_trace(psi0, rr_rxp(ii, iii), contrib)
2543 chi_tmp = chi_tmp + 2.0_dp*contrib
2546 CALL cp_fm_trace(psi0, rr_rxp(iii, ii), contrib)
2547 chi_tmp = chi_tmp - 2.0_dp*contrib
2552 CALL cp_fm_trace(psi0, p_rxp(iii), contrib)
2553 IF (.NOT. chi_pbc) chi_tmp = chi_tmp + 2.0_dp*dk(ii)*contrib
2554 int_current_tmp = int_current_tmp + 2.0_dp*contrib
2557 CALL cp_fm_trace(psi0, p_rxp(ii), contrib2)
2558 IF (.NOT. chi_pbc) chi_tmp = chi_tmp - 2.0_dp*dk(iii)*contrib2
2564 idir2 = ind_m2(ii, iib)
2565 CALL cp_fm_trace(psi0, rr_p2(idir2, iii), contrib)
2566 chi_tmp = chi_tmp - 2.0_dp*contrib
2568 IF (iib == iii)
THEN
2569 CALL cp_fm_trace(psi0, r_p2(ii), contrib2)
2570 chi_tmp = chi_tmp - contrib2
2574 idir2 = ind_m2(iii, iib)
2575 CALL cp_fm_trace(psi0, rr_p2(idir2, ii), contrib)
2576 chi_tmp = chi_tmp + 2.0_dp*contrib
2579 CALL cp_fm_trace(psi0, r_p2(iii), contrib2)
2580 chi_tmp = chi_tmp + contrib2
2588 CALL cp_fm_trace(psi0, rr_p2(iib, iii), contrib)
2589 IF (.NOT. chi_pbc) chi_tmp = chi_tmp - 2.0_dp*dk(ii)*contrib
2590 int_current_tmp = int_current_tmp - 2.0_dp*contrib
2593 CALL cp_fm_trace(psi0, rr_p2(iib, ii), contrib2)
2594 IF (.NOT. chi_pbc) chi_tmp = chi_tmp + 2.0_dp*dk(iii)*contrib2
2600 idir2 = ind_m2(ii, iiib)
2601 CALL cp_fm_trace(psi0, rr_p1(idir2, iii), contrib)
2602 chi_tmp = chi_tmp + 2.0_dp*contrib
2604 IF (iiib == iii)
THEN
2605 CALL cp_fm_trace(psi0, r_p1(ii), contrib2)
2606 chi_tmp = chi_tmp + contrib2
2610 idir2 = ind_m2(iii, iiib)
2611 CALL cp_fm_trace(psi0, rr_p1(idir2, ii), contrib)
2612 chi_tmp = chi_tmp - 2.0_dp*contrib
2614 IF (iiib == ii)
THEN
2615 CALL cp_fm_trace(psi0, r_p1(iii), contrib2)
2616 chi_tmp = chi_tmp - contrib2
2623 CALL cp_fm_trace(psi0, rr_p1(iiib, iii), contrib)
2624 IF (.NOT. chi_pbc) chi_tmp = chi_tmp + 2.0_dp*dk(ii)*contrib
2625 int_current_tmp = int_current_tmp + 2.0_dp*contrib
2628 CALL cp_fm_trace(psi0, rr_p1(iiib, ii), contrib2)
2629 IF (.NOT. chi_pbc) chi_tmp = chi_tmp - 2.0_dp*dk(iii)*contrib2
2632 chi(idir) = chi(idir) + maxocc*chi_tmp
2633 int_current(iii) = int_current(iii) + int_current_tmp
2639 current_env%chi_tensor(idir, ib, ispin) = current_env%chi_tensor(idir, ib, ispin) + &
2641 IF (output_unit > 0)
THEN
2652 CALL dbcsr_deallocate_matrix_set(op_mom_ao)
2653 CALL dbcsr_deallocate_matrix_set(op_mom_der_ao)
2654 CALL dbcsr_deallocate_matrix_set(op_p_ao)
2656 CALL cp_fm_release(psi0)
2657 CALL cp_fm_release(psi_rxp)
2658 CALL cp_fm_release(psi_d)
2659 CALL cp_fm_release(psi_p1)
2660 CALL cp_fm_release(psi_p2)
2662 CALL cp_fm_release(p_rxp(idir))
2663 CALL cp_fm_release(r_p1(idir))
2664 CALL cp_fm_release(r_p2(idir))
2666 CALL cp_fm_release(rr_rxp(idir2, idir))
2667 CALL cp_fm_release(rr_p1(idir2, idir))
2668 CALL cp_fm_release(rr_p2(idir2, idir))
2672 CALL timestop(handle)
2674 END SUBROUTINE current_build_chi_many_centers
2682 SUBROUTINE current_build_chi_one_center(current_env, qs_env, iB)
2684 TYPE(current_env_type) :: current_env
2685 TYPE(qs_environment_type),
POINTER :: qs_env
2686 INTEGER,
INTENT(IN) :: ib
2688 CHARACTER(LEN=*),
PARAMETER :: routinen =
'current_build_chi_one_center'
2690 INTEGER :: handle, idir, idir2, iib, iiib, ispin, jdir, jjdir, kdir, max_states, nao, natom, &
2691 nbr_center(2), nmo, nspins, nstates(2), output_unit
2692 INTEGER,
ALLOCATABLE,
DIMENSION(:) :: first_sgf, last_sgf
2693 INTEGER,
DIMENSION(:),
POINTER :: row_blk_sizes
2694 LOGICAL :: chi_pbc, gapw
2695 REAL(dp) :: chi(3), contrib, dk(3), int_current(3), &
2697 TYPE(cell_type),
POINTER :: cell
2698 TYPE(cp_2d_i_p_type),
DIMENSION(:),
POINTER :: center_list
2699 TYPE(cp_2d_r_p_type),
DIMENSION(:),
POINTER :: centers_set
2700 TYPE(cp_fm_type) :: buf
2701 TYPE(cp_fm_type),
DIMENSION(:),
POINTER :: psi0_order
2702 TYPE(cp_fm_type),
DIMENSION(:, :),
POINTER :: psi1_p, psi1_rxp
2703 TYPE(cp_fm_type),
POINTER :: mo_coeff
2704 TYPE(cp_logger_type),
POINTER :: logger
2705 TYPE(dbcsr_distribution_type),
POINTER :: dbcsr_dist
2706 TYPE(dbcsr_p_type),
DIMENSION(:),
POINTER :: op_mom_ao, op_p_ao
2707 TYPE(dbcsr_p_type),
DIMENSION(:, :),
POINTER :: op_mom_der_ao
2708 TYPE(dft_control_type),
POINTER :: dft_control
2709 TYPE(mo_set_type),
DIMENSION(:),
POINTER :: mos
2710 TYPE(mp_para_env_type),
POINTER :: para_env
2711 TYPE(neighbor_list_set_p_type),
DIMENSION(:), &
2712 POINTER :: sab_all, sab_orb
2713 TYPE(particle_type),
DIMENSION(:),
POINTER :: particle_set
2714 TYPE(qs_kind_type),
DIMENSION(:),
POINTER :: qs_kind_set
2718 CALL timeset(routinen, handle)
2720 NULLIFY (dft_control, mos, para_env, mo_coeff, op_mom_ao, &
2721 op_mom_der_ao, center_list, centers_set, &
2722 op_p_ao, psi1_p, psi1_rxp, cell, psi0_order)
2724 logger => cp_get_default_logger()
2725 output_unit = cp_logger_get_default_io_unit(logger)
2727 CALL get_qs_env(qs_env=qs_env, &
2728 dft_control=dft_control, &
2730 para_env=para_env, &
2732 particle_set=particle_set, &
2733 qs_kind_set=qs_kind_set, &
2736 dbcsr_dist=dbcsr_dist)
2738 nspins = dft_control%nspins
2739 gapw = dft_control%qs_control%gapw
2741 CALL get_current_env(current_env=current_env, &
2744 nbr_center=nbr_center, &
2745 center_list=center_list, &
2746 centers_set=centers_set, &
2748 psi1_rxp=psi1_rxp, &
2750 psi0_order=psi0_order)
2752 max_states = maxval(nstates(1:nspins))
2756 CALL dbcsr_allocate_matrix_set(op_mom_ao, 9)
2757 CALL dbcsr_allocate_matrix_set(op_mom_der_ao, 9, 3)
2760 natom =
SIZE(particle_set, 1)
2761 ALLOCATE (first_sgf(natom))
2762 ALLOCATE (last_sgf(natom))
2763 CALL get_particle_set(particle_set, qs_kind_set, &
2764 first_sgf=first_sgf, &
2766 ALLOCATE (row_blk_sizes(natom))
2767 CALL dbcsr_convert_offsets_to_sizes(first_sgf, row_blk_sizes, last_sgf)
2768 DEALLOCATE (first_sgf)
2769 DEALLOCATE (last_sgf)
2772 ALLOCATE (op_mom_ao(1)%matrix)
2773 CALL dbcsr_create(matrix=op_mom_ao(1)%matrix, &
2775 dist=dbcsr_dist, matrix_type=dbcsr_type_no_symmetry, &
2776 row_blk_size=row_blk_sizes, col_blk_size=row_blk_sizes, &
2777 mutable_work=.true.)
2778 CALL cp_dbcsr_alloc_block_from_nbl(op_mom_ao(1)%matrix, sab_all)
2781 ALLOCATE (op_mom_der_ao(1, idir2)%matrix)
2782 CALL dbcsr_copy(op_mom_der_ao(1, idir2)%matrix, op_mom_ao(1)%matrix, &
2783 "op_mom_der_ao"//
"-"//trim(adjustl(cp_to_string(idir2))))
2786 DO idir = 2,
SIZE(op_mom_ao, 1)
2787 ALLOCATE (op_mom_ao(idir)%matrix)
2788 CALL dbcsr_copy(op_mom_ao(idir)%matrix, op_mom_ao(1)%matrix, &
2789 "op_mom_ao"//
"-"//trim(adjustl(cp_to_string(idir))))
2791 ALLOCATE (op_mom_der_ao(idir, idir2)%matrix)
2792 CALL dbcsr_copy(op_mom_der_ao(idir, idir2)%matrix, op_mom_ao(1)%matrix, &
2793 "op_mom_der_ao"//
"-"//trim(adjustl(cp_to_string(idir*idir2))))
2797 CALL dbcsr_allocate_matrix_set(op_p_ao, 3)
2798 ALLOCATE (op_p_ao(1)%matrix)
2799 CALL dbcsr_create(matrix=op_p_ao(1)%matrix, &
2801 dist=dbcsr_dist, matrix_type=dbcsr_type_antisymmetric, &
2802 row_blk_size=row_blk_sizes, col_blk_size=row_blk_sizes, &
2803 mutable_work=.true.)
2804 CALL cp_dbcsr_alloc_block_from_nbl(op_p_ao(1)%matrix, sab_orb)
2807 ALLOCATE (op_p_ao(idir)%matrix)
2808 CALL dbcsr_copy(op_p_ao(idir)%matrix, op_p_ao(1)%matrix, &
2809 "op_p_ao"//
"-"//trim(adjustl(cp_to_string(idir))))
2813 DEALLOCATE (row_blk_sizes)
2816 CALL build_lin_mom_matrix(qs_env, op_p_ao)
2821 CALL set_vecp(ib, iib, iiib)
2822 DO ispin = 1, nspins
2824 cpassert(nbr_center(ispin) == 1)
2827 nmo = nstates(ispin)
2828 mo_coeff => psi0_order(ispin)
2829 CALL get_mo_set(mo_set=mos(ispin), maxocc=maxocc)
2832 CALL cp_fm_create(buf, mo_coeff%matrix_struct)
2836 int_current = 0.0_dp
2840 dk(1:3) = centers_set(ispin)%array(1:3, 1)
2845 CALL dbcsr_set(op_mom_ao(idir)%matrix, 0.0_dp)
2847 CALL dbcsr_set(op_mom_der_ao(idir, idir2)%matrix, 0.0_dp)
2850 CALL rrc_xyz_der_ao(op_mom_ao, op_mom_der_ao, qs_env, dk, order=2, &
2851 minimum_image=.false., soft=gapw)
2865 IF (.NOT. chi_pbc)
THEN
2866 CALL cp_dbcsr_sm_fm_multiply(op_p_ao(idir)%matrix, mo_coeff, &
2867 buf, ncol=nmo, alpha=1.e0_dp)
2870 IF (
levi_civita(kdir, jdir, idir) .EQ. 0.0_dp) cycle
2871 CALL cp_fm_trace(buf, psi1_rxp(ispin, ib), contrib)
2872 chi(kdir) = chi(kdir) -
levi_civita(kdir, jdir, idir)*2.0_dp*dk(jdir)*contrib
2887 CALL cp_dbcsr_sm_fm_multiply(op_mom_der_ao(jdir, idir)%matrix, mo_coeff, &
2888 buf, ncol=nmo, alpha=1.e0_dp)
2890 IF (
levi_civita(kdir, jdir, idir) .EQ. 0.0_dp) cycle
2891 CALL cp_fm_trace(buf, psi1_rxp(ispin, ib), contrib)
2892 chi(kdir) = chi(kdir) -
levi_civita(kdir, jdir, idir)*2.0_dp*contrib
2895 IF (.NOT. chi_pbc)
THEN
2896 IF (jdir .EQ. iib)
THEN
2899 IF (
levi_civita(kdir, jjdir, idir) .EQ. 0.0_dp) cycle
2900 CALL cp_fm_trace(buf, psi1_p(ispin, iiib), contrib)
2901 chi(kdir) = chi(kdir) +
levi_civita(kdir, jjdir, idir)*2.0_dp*dk(jjdir)*contrib
2906 IF (jdir .EQ. iiib)
THEN
2909 IF (
levi_civita(kdir, jjdir, idir) .EQ. 0.0_dp) cycle
2910 CALL cp_fm_trace(buf, psi1_p(ispin, iib), contrib)
2911 chi(kdir) = chi(kdir) -
levi_civita(kdir, jjdir, idir)*2.0_dp*dk(jjdir)*contrib
2927 CALL cp_dbcsr_sm_fm_multiply(op_mom_der_ao(ind_m2(jdir, iib), idir)%matrix, mo_coeff, &
2928 buf, ncol=nmo, alpha=1.e0_dp)
2930 IF (
levi_civita(kdir, jdir, idir) .EQ. 0.0_dp) cycle
2931 CALL cp_fm_trace(buf, psi1_p(ispin, iiib), contrib)
2932 chi(kdir) = chi(kdir) +
levi_civita(kdir, jdir, idir)*2.0_dp*contrib
2935 CALL cp_dbcsr_sm_fm_multiply(op_mom_der_ao(ind_m2(jdir, iiib), idir)%matrix, mo_coeff, &
2936 buf, ncol=nmo, alpha=1.e0_dp)
2938 IF (
levi_civita(kdir, jdir, idir) .EQ. 0.0_dp) cycle
2939 CALL cp_fm_trace(buf, psi1_p(ispin, iib), contrib)
2940 chi(kdir) = chi(kdir) -
levi_civita(kdir, jdir, idir)*2.0_dp*contrib
2951 CALL cp_dbcsr_sm_fm_multiply(op_mom_ao(idir)%matrix, mo_coeff, &
2952 buf, ncol=nmo, alpha=1.e0_dp)
2955 IF (
levi_civita(kdir, idir, jdir) .EQ. 0.0_dp) cycle
2956 IF (iib == jdir)
THEN
2957 CALL cp_fm_trace(buf, psi1_p(ispin, iiib), contrib)
2958 chi(kdir) = chi(kdir) +
levi_civita(kdir, idir, jdir)*contrib
2965 IF (
levi_civita(kdir, idir, jdir) .EQ. 0.0_dp) cycle
2966 IF (iiib == jdir)
THEN
2967 CALL cp_fm_trace(buf, psi1_p(ispin, iib), contrib)
2968 chi(kdir) = chi(kdir) -
levi_civita(kdir, idir, jdir)*contrib
2980 current_env%chi_tensor(idir, ib, ispin) = current_env%chi_tensor(idir, ib, ispin) + &
2982 IF (output_unit > 0)
THEN
2988 CALL cp_fm_release(buf)
2992 CALL dbcsr_deallocate_matrix_set(op_mom_ao)
2993 CALL dbcsr_deallocate_matrix_set(op_mom_der_ao)
2994 CALL dbcsr_deallocate_matrix_set(op_p_ao)
2996 CALL timestop(handle)
2998 END SUBROUTINE current_build_chi_one_center
static int imax(int x, int y)
Returns the larger of two given integers (missing from the C standard)
static int imin(int x, int y)
Returns the smaller of the two integers (missing from the C standard).
static GRID_HOST_DEVICE int ncoset(const int l)
Number of Cartesian orbitals up to given angular momentum quantum.
static GRID_HOST_DEVICE int modulo(int a, int m)
Equivalent of Fortran's MODULO, which always return a positive number. https://gcc....
static void dgemm(const char transa, const char transb, const int m, const int n, const int k, const double alpha, const double *a, const int lda, const double *b, const int ldb, const double beta, double *c, const int ldc)
Convenient wrapper to hide Fortran nature of dgemm_, swapping a and b.
All kind of helpful little routines.
real(kind=dp) function, public exp_radius_very_extended(la_min, la_max, lb_min, lb_max, pab, o1, o2, ra, rb, rp, zetp, eps, prefactor, cutoff, epsabs)
computes the radius of the Gaussian outside of which it is smaller than eps
subroutine, public get_gto_basis_set(gto_basis_set, name, aliases, norm_type, kind_radius, ncgf, nset, nsgf, cgf_symbol, sgf_symbol, norm_cgf, set_radius, lmax, lmin, lx, ly, lz, m, ncgf_set, npgf, nsgf_set, nshell, cphi, pgf_radius, sphi, scon, zet, first_cgf, first_sgf, l, last_cgf, last_sgf, n, gcc, maxco, maxl, maxpgf, maxsgf_set, maxshell, maxso, nco_sum, npgf_sum, nshell_sum, maxder, short_kind_radius, npgf_seg_sum)
...
Handles all functions related to the CELL.
various utilities that regard array of different kinds: output, allocation,... maybe it is not a good...
Defines control structures, which contain the parameters and the settings for the DFT-based calculati...
subroutine, public dbcsr_deallocate_matrix(matrix)
...
subroutine, public dbcsr_copy(matrix_b, matrix_a, name, keep_sparsity, keep_imaginary)
...
subroutine, public dbcsr_get_block_p(matrix, row, col, block, found, row_size, col_size)
...
subroutine, public dbcsr_finalize(matrix)
...
subroutine, public dbcsr_set(matrix, alpha)
...
subroutine, public dbcsr_put_block(matrix, row, col, block, summation)
...
Routines that link DBCSR and CP2K concepts together.
subroutine, public cp_dbcsr_alloc_block_from_nbl(matrix, sab_orb, desymmetrize)
allocate the blocks of a dbcsr based on the neighbor list
DBCSR operations in CP2K.
subroutine, public cp_dbcsr_sm_fm_multiply(matrix, fm_in, fm_out, ncol, alpha, beta)
multiply a dbcsr with a fm matrix
subroutine, public cp_dbcsr_plus_fm_fm_t(sparse_matrix, matrix_v, matrix_g, ncol, alpha, keep_sparsity, symmetry_mode)
performs the multiplication sparse_matrix+dense_mat*dens_mat^T if matrix_g is not explicitly given,...
basic linear algebra operations for full matrices
subroutine, public cp_fm_scale_and_add(alpha, matrix_a, beta, matrix_b)
calc A <- alpha*A + beta*B optimized for alpha == 1.0 (just add beta*B) and beta == 0....
represent the structure of a full matrix
subroutine, public cp_fm_struct_create(fmstruct, para_env, context, nrow_global, ncol_global, nrow_block, ncol_block, descriptor, first_p_pos, local_leading_dimension, template_fmstruct, square_blocks, force_block)
allocates and initializes a full matrix structure
subroutine, public cp_fm_struct_release(fmstruct)
releases a full matrix structure
represent a full matrix distributed on many processors
subroutine, public cp_fm_set_all(matrix, alpha, beta)
set all elements of a matrix to the same value, and optionally the diagonal to a different one
subroutine, public cp_fm_create(matrix, matrix_struct, name, use_sp)
creates a new full matrix with the given structure
various routines to log and control the output. The idea is that decisions about where to log should ...
integer function, public cp_logger_get_default_io_unit(logger)
returns the unit nr for the ionode (-1 on all other processors) skips as well checks if the procs cal...
type(cp_logger_type) function, pointer, public cp_get_default_logger()
returns the default logger
routines to handle the output, The idea is to remove the decision of wheter to output and what to out...
integer function, public cp_print_key_unit_nr(logger, basis_section, print_key_path, extension, middle_name, local, log_filename, ignore_should_output, file_form, file_position, file_action, file_status, do_backup, on_file, is_new_file, mpi_io, fout)
...
subroutine, public cp_print_key_finished_output(unit_nr, logger, basis_section, print_key_path, local, ignore_should_output, on_file, mpi_io)
should be called after you finish working with a unit obtained with cp_print_key_unit_nr,...
integer, parameter, public cp_p_file
integer function, public cp_print_key_should_output(iteration_info, basis_section, print_key_path, used_print_key, first_time)
returns what should be done with the given property if btest(res,cp_p_store) then the property should...
A wrapper around pw_to_cube() which accepts particle_list_type.
subroutine, public cp_pw_to_cube(pw, unit_nr, title, particles, stride, zero_tails, silent, mpi_io)
...
for a given dr()/dh(r) this will provide the bounds to be used if one wants to go over a sphere-subre...
subroutine, public compute_cube_center(cube_center, rs_desc, zeta, zetb, ra, rab)
unifies the computation of the cube center, so that differences in implementation,...
subroutine, public return_cube(info, radius, lb_cube, ub_cube, sphere_bounds)
...
Fortran API for the grid package, which is written in C.
integer, parameter, public grid_func_adbmdab_z
integer, parameter, public grid_func_adbmdab_y
integer, parameter, public grid_func_ardbmdarb_yx
integer, parameter, public grid_func_ardbmdarb_zz
integer, parameter, public grid_func_ardbmdarb_xy
integer, parameter, public grid_func_ardbmdarb_zx
integer, parameter, public grid_func_ardbmdarb_xx
integer, parameter, public grid_func_ardbmdarb_yz
integer, parameter, public grid_func_ab
integer, parameter, public grid_func_ardbmdarb_yy
integer, parameter, public grid_func_adbmdab_x
subroutine, public collocate_pgf_product(la_max, zeta, la_min, lb_max, zetb, lb_min, ra, rab, scale, pab, o1, o2, rsgrid, ga_gb_function, radius, use_subpatch, subpatch_pattern)
low level collocation of primitive gaussian functions
integer, parameter, public grid_func_ardbmdarb_zy
integer, parameter, public grid_func_ardbmdarb_xz
Defines the basic variable types.
integer, parameter, public dp
integer, parameter, public default_string_length
integer, parameter, public default_path_length
Definition of mathematical constants and functions.
real(kind=dp), parameter, public twopi
Utility routines for the memory handling.
Interface to the message passing library MPI.
Provides Cartesian and spherical orbital pointers and indices.
integer, dimension(:), allocatable, public ncoset
represent a simple array based list of the given type
Define methods related to particle_type.
subroutine, public get_particle_set(particle_set, qs_kind_set, first_sgf, last_sgf, nsgf, nmao, basis)
Get the components of a particle set.
Define the data structure for the particle information.
container for various plainwaves related things
subroutine, public pw_env_get(pw_env, pw_pools, cube_info, gridlevel_info, auxbas_pw_pool, auxbas_grid, auxbas_rs_desc, auxbas_rs_grid, rs_descs, rs_grids, xc_pw_pool, vdw_pw_pool, poisson_env, interp_section)
returns the various attributes of the pw env
Manages a pool of grids (to be used for example as tmp objects), but can also be used to instantiate ...
subroutine, public get_qs_env(qs_env, atomic_kind_set, qs_kind_set, cell, super_cell, cell_ref, use_ref_cell, kpoints, dft_control, mos, sab_orb, sab_all, qmmm, qmmm_periodic, sac_ae, sac_ppl, sac_lri, sap_ppnl, sab_vdw, sab_scp, sap_oce, sab_lrc, sab_se, sab_xtbe, sab_tbe, sab_core, sab_xb, sab_xtb_pp, sab_xtb_nonbond, sab_almo, sab_kp, sab_kp_nosym, particle_set, energy, force, matrix_h, matrix_h_im, matrix_ks, matrix_ks_im, matrix_vxc, run_rtp, rtp, matrix_h_kp, matrix_h_im_kp, matrix_ks_kp, matrix_ks_im_kp, matrix_vxc_kp, kinetic_kp, matrix_s_kp, matrix_w_kp, matrix_s_ri_aux_kp, matrix_s, matrix_s_ri_aux, matrix_w, matrix_p_mp2, matrix_p_mp2_admm, rho, rho_xc, pw_env, ewald_env, ewald_pw, active_space, mpools, input, para_env, blacs_env, scf_control, rel_control, kinetic, qs_charges, vppl, rho_core, rho_nlcc, rho_nlcc_g, ks_env, ks_qmmm_env, wf_history, scf_env, local_particles, local_molecules, distribution_2d, dbcsr_dist, molecule_kind_set, molecule_set, subsys, cp_subsys, oce, local_rho_set, rho_atom_set, task_list, task_list_soft, rho0_atom_set, rho0_mpole, rhoz_set, ecoul_1c, rho0_s_rs, rho0_s_gs, do_kpoints, has_unit_metric, requires_mo_derivs, mo_derivs, mo_loc_history, nkind, natom, nelectron_total, nelectron_spin, efield, neighbor_list_id, linres_control, xas_env, virial, cp_ddapc_env, cp_ddapc_ewald, outer_scf_history, outer_scf_ihistory, x_data, et_coupling, dftb_potential, results, se_taper, se_store_int_env, se_nddo_mpole, se_nonbond_env, admm_env, lri_env, lri_density, exstate_env, ec_env, harris_env, dispersion_env, gcp_env, vee, rho_external, external_vxc, mask, mp2_env, bs_env, kg_env, wanniercentres, atprop, ls_scf_env, do_transport, transport_env, v_hartree_rspace, s_mstruct_changed, rho_changed, potential_changed, forces_up_to_date, mscfg_env, almo_scf_env, gradient_history, variable_history, embed_pot, spin_embed_pot, polar_env, mos_last_converged, eeq, rhs)
Get the QUICKSTEP environment.
Define the quickstep kind type and their sub types.
subroutine, public get_qs_kind(qs_kind, basis_set, basis_type, ncgf, nsgf, all_potential, tnadd_potential, gth_potential, sgp_potential, upf_potential, se_parameter, dftb_parameter, xtb_parameter, dftb3_param, zatom, zeff, elec_conf, mao, lmax_dftb, alpha_core_charge, ccore_charge, core_charge, core_charge_radius, paw_proj_set, paw_atom, hard_radius, hard0_radius, max_rad_local, covalent_radius, vdw_radius, gpw_type_forced, harmonics, max_iso_not0, max_s_harm, grid_atom, ngrid_ang, ngrid_rad, lmax_rho0, dft_plus_u_atom, l_of_dft_plus_u, n_of_dft_plus_u, u_minus_j, u_of_dft_plus_u, j_of_dft_plus_u, alpha_of_dft_plus_u, beta_of_dft_plus_u, j0_of_dft_plus_u, occupation_of_dft_plus_u, dispersion, bs_occupation, magnetization, no_optimize, addel, laddel, naddel, orbitals, max_scf, eps_scf, smear, u_ramping, u_minus_j_target, eps_u_ramping, init_u_ramping_each_scf, reltmat, ghost, floating, name, element_symbol, pao_basis_size, pao_model_file, pao_potentials, pao_descriptors, nelec)
Get attributes of an atomic kind.
subroutine, public get_qs_kind_set(qs_kind_set, all_potential_present, tnadd_potential_present, gth_potential_present, sgp_potential_present, paw_atom_present, dft_plus_u_atom_present, maxcgf, maxsgf, maxco, maxco_proj, maxgtops, maxlgto, maxlprj, maxnset, maxsgf_set, ncgf, npgf, nset, nsgf, nshell, maxpol, maxlppl, maxlppnl, maxppnl, nelectron, maxder, max_ngrid_rad, max_sph_harm, maxg_iso_not0, lmax_rho0, basis_rcut, basis_type, total_zeff_corr, npgf_seg)
Get attributes of an atomic kind set.
given the response wavefunctions obtained by the application of the (rxp), p, and ((dk-dl)xp) operato...
subroutine, public calculate_jrho_atom(current_env, qs_env, ib, idir)
...
subroutine, public calculate_jrho_atom_coeff(qs_env, current_env, mat_d0, mat_jp, mat_jp_rii, mat_jp_riii, ib, idir)
Calculate the expansion coefficients for the atomic terms of the current densitiy in GAPW.
subroutine, public calculate_jrho_atom_rad(qs_env, current_env, idir)
...
given the response wavefunctions obtained by the application of the (rxp), p, and ((dk-dl)xp) operato...
subroutine, public current_build_current(current_env, qs_env, ib)
First calculate the density matrixes, for each component of the current they are 3 because of the r d...
real(dp), dimension(3, 3, 3), parameter levi_civita
subroutine, public calculate_jrho_resp(mat_d0, mat_jp, mat_jp_rii, mat_jp_riii, ib, idir, current_rs, current_gs, qs_env, current_env, soft_valid, retain_rsgrid)
Calculation of the idir component of the response current density in the presence of a constant magne...
subroutine, public current_build_chi(current_env, qs_env, ib)
...
Calculate the operators p rxp and D needed in the optimization of the different contribution of the f...
integer function, public ind_m2(ii, iii)
...
subroutine, public set_vecp(i1, i2, i3)
...
real(dp) function, public fac_vecp(a, b, c)
...
subroutine, public fm_scale_by_pbc_ac(matrix, ra, rc, cell, ixyz)
scale a matrix as a_ij = a_ij * pbc(rc(:,j),ra(:,i))(ixyz)
subroutine, public set_vecp_rev(i1, i2, i3)
...
Type definitiona for linear response calculations.
subroutine, public get_current_env(current_env, simple_done, simple_converged, full_done, nao, nstates, gauge, list_cubes, statetrueindex, gauge_name, basisfun_center, nbr_center, center_list, centers_set, psi1_p, psi1_rxp, psi1_d, p_psi0, rxp_psi0, jrho1_atom_set, jrho1_set, chi_tensor, chi_tensor_loc, gauge_atom_radius, rs_gauge, use_old_gauge_atom, chi_pbc, psi0_order)
...
wrapper for the pools of matrixes
Definition and initialisation of the mo data type.
subroutine, public get_mo_set(mo_set, maxocc, homo, lfomo, nao, nelectron, n_el_f, nmo, eigenvalues, occupation_numbers, mo_coeff, mo_coeff_b, uniform_occupation, kts, mu, flexible_electron_count)
Get the components of a MO set data structure.
Define the neighbor list data types and the corresponding functionality.
subroutine, public neighbor_list_iterator_create(iterator_set, nl, search, nthread)
Neighbor list iterator functions.
subroutine, public neighbor_list_iterator_release(iterator_set)
...
integer function, public neighbor_list_iterate(iterator_set, mepos)
...
subroutine, public get_iterator_info(iterator_set, mepos, ikind, jkind, nkind, ilist, nlist, inode, nnode, iatom, jatom, r, cell)
...
subroutine, public rrc_xyz_der_ao(op, op_der, qs_env, rc, order, minimum_image, soft)
Calculation of the multipole operators integrals and of its derivatives of the type [\mu | op | d(\nu...
subroutine, public build_lin_mom_matrix(qs_env, matrix)
Calculation of the linear momentum matrix <mu|∂|nu> over Cartesian Gaussian functions.
superstucture that hold various representations of the density and keeps track of which ones are vali...
subroutine, public qs_rho_get(rho_struct, rho_ao, rho_ao_im, rho_ao_kp, rho_ao_im_kp, rho_r, drho_r, rho_g, drho_g, tau_r, tau_g, rho_r_valid, drho_r_valid, rho_g_valid, drho_g_valid, tau_r_valid, tau_g_valid, tot_rho_r, tot_rho_g, rho_r_sccs, soft_valid, complex_rho_ao)
returns info about the density described by this object. If some representation is not available an e...
types that represent a quickstep subsys
subroutine, public qs_subsys_get(subsys, atomic_kinds, atomic_kind_set, particles, particle_set, local_particles, molecules, molecule_set, molecule_kinds, molecule_kind_set, local_molecules, para_env, colvar_p, shell_particles, core_particles, gci, multipoles, natom, nparticle, ncore, nshell, nkind, atprop, virial, results, cell, cell_ref, use_ref_cell, energy, force, qs_kind_set, cp_subsys, nelectron_total, nelectron_spin)
...
subroutine, public rs_grid_create(rs, desc)
...
subroutine, public rs_grid_mult_and_add(rs1, rs2, rs3, scalar)
rs1(i) = rs1(i) + rs2(i)*rs3(i)
subroutine, public rs_grid_release(rs_grid)
releases the given rs grid (see doc/ReferenceCounting.html)
subroutine, public rs_grid_zero(rs)
Initialize grid to zero.
Transfers densities from PW to RS grids and potentials from PW to RS.
subroutine, public density_rs2pw(pw_env, rs_rho, rho, rho_gspace)
given partial densities on the realspace multigrids, computes the full density on the plane wave grid...
generate the tasks lists used by collocate and integrate routines
subroutine, public rs_distribute_matrix(rs_descs, pmats, atom_pair_send, atom_pair_recv, nimages, scatter, hmats)
redistributes the matrix so that it can be used in realspace operations i.e. according to the task li...
subroutine, public distribute_tasks(rs_descs, ntasks, natoms, tasks, atom_pair_send, atom_pair_recv, symmetric, reorder_rs_grid_ranks, skip_load_balance_distributed)
Assembles tasks to be performed on local grid.
subroutine, public task_list_inner_loop(tasks, ntasks, curr_tasks, rs_descs, dft_control, cube_info, gridlevel_info, cindex, iatom, jatom, rpgfa, rpgfb, zeta, zetb, kind_radius_b, set_radius_a, set_radius_b, ra, rab, la_max, la_min, lb_max, lb_min, npgfa, npgfb, nseta, nsetb)
...
subroutine, public reallocate_tasks(tasks, new_size)
Grow an array of tasks while preserving the existing entries.
Type defining parameters related to the simulation cell.
represent a pointer to a 2d array
represent a pointer to a 2d array
keeps the information about the structure of a full matrix
type of a logger, at the moment it contains just a print level starting at which level it should be l...
stores all the informations relevant to an mpi environment
represent a list of objects
contained for different pw related things
Manages a pool of grids (to be used for example as tmp objects), but can also be used to instantiate ...
Provides all information about a quickstep kind.
container for the pools of matrixes used by qs