100 do_hfx, do_admm, qs_env, kernel_env, kernel_env_admm_aux, &
101 sub_env, work_matrices, admm_symm, admm_xc_correction, do_lrigpw, &
103 TYPE(
cp_fm_type),
DIMENSION(:, :),
INTENT(INOUT) :: aop_evects
104 TYPE(
cp_fm_type),
DIMENSION(:, :),
INTENT(IN) :: evects
105 LOGICAL,
INTENT(in) :: is_rks_triplets, do_hfx, do_admm
110 LOGICAL,
INTENT(in) :: admm_symm, admm_xc_correction, &
111 do_lrigpw, tddfpt_mgrid
113 CHARACTER(LEN=*),
PARAMETER :: routinen =
'fhxc_kernel'
115 CHARACTER(LEN=default_string_length) :: basis_type
116 INTEGER :: handle, ikind, ispin, ivect, nao, &
117 nao_aux, nkind, nspins, nvects, &
119 INTEGER,
DIMENSION(:),
POINTER :: blk_sizes
120 INTEGER,
DIMENSION(maxspins) :: nactive
121 LOGICAL :: do_noncol, gapw, gapw_xc
123 TYPE(
cp_fm_type) :: work_aux_orb, work_orb_orb
124 TYPE(
dbcsr_p_type),
DIMENSION(:),
POINTER :: a_xc_munu_sub, rho_ia_ao, &
130 TYPE(
pw_c1d_gs_type),
DIMENSION(:),
POINTER :: rho_ia_g, rho_ia_g_aux_fit
133 TYPE(
pw_r3d_rs_type),
DIMENSION(:),
POINTER :: rho_ia_r, rho_ia_r_aux_fit
135 TYPE(
rho_atom_type),
DIMENSION(:),
POINTER :: rho1_atom_set, rho_atom_set
138 CALL timeset(routinen, handle)
140 nspins =
SIZE(evects, 1)
141 nvects =
SIZE(evects, 2)
144 cpassert(
ASSOCIATED(sub_env%admm_A))
146 CALL get_qs_env(qs_env, dft_control=dft_control)
148 gapw = dft_control%qs_control%gapw
149 gapw_xc = dft_control%qs_control%gapw_xc
150 spinflip = dft_control%tddfpt2_control%spinflip
159 CALL qs_rho_get(work_matrices%rho_orb_struct_sub, rho_ao=rho_ia_ao, &
160 rho_g=rho_ia_g, rho_r=rho_ia_r)
161 IF (do_hfx .AND. do_admm)
THEN
163 CALL qs_rho_get(work_matrices%rho_aux_fit_struct_sub, &
164 rho_ao=rho_ia_ao_aux_fit, rho_g=rho_ia_g_aux_fit, &
165 rho_r=rho_ia_r_aux_fit)
169 CALL get_qs_env(qs_env, xcint_weights=weights)
174 IF (
ALLOCATED(work_matrices%evects_sub))
THEN
175 IF (
ASSOCIATED(work_matrices%evects_sub(1, ivect)%matrix_struct))
THEN
177 CALL dbcsr_set(rho_ia_ao(ispin)%matrix, 0.0_dp)
179 matrix_v=sub_env%mos_active(ispin), &
180 matrix_g=work_matrices%evects_sub(ispin, ivect), &
181 ncol=nactive(ispin), symmetry_mode=1)
189 CALL dbcsr_set(rho_ia_ao(ispin)%matrix, 0.0_dp)
191 matrix_v=sub_env%mos_active(ispin), &
192 matrix_g=evects(ispin, ivect), &
193 ncol=nactive(ispin), symmetry_mode=1)
199 pw_env_external=sub_env%pw_env, &
200 task_list_external=sub_env%task_list_orb, &
201 para_env_external=sub_env%para_env, &
202 tddfpt_lri_env=kernel_env%lri_env, &
203 tddfpt_lri_density=kernel_env%lri_density)
204 ELSEIF (dft_control%qs_control%lrigpw .OR. &
205 dft_control%qs_control%rigpw)
THEN
207 pw_env_external=sub_env%pw_env, &
208 task_list_external=sub_env%task_list_orb, &
209 para_env_external=sub_env%para_env)
213 local_rho_set=work_matrices%local_rho_set, &
214 pw_env_external=sub_env%pw_env, &
215 task_list_external=sub_env%task_list_orb_soft, &
216 para_env_external=sub_env%para_env)
218 do_rho0=(.NOT. is_rks_triplets), pw_env_sub=sub_env%pw_env)
219 ELSEIF (gapw_xc)
THEN
221 rho_xc_external=work_matrices%rho_xc_struct_sub, &
222 local_rho_set=work_matrices%local_rho_set, &
223 pw_env_external=sub_env%pw_env, &
224 task_list_external=sub_env%task_list_orb, &
225 task_list_external_soft=sub_env%task_list_orb_soft, &
226 para_env_external=sub_env%para_env)
227 CALL prepare_gapw_den(qs_env, work_matrices%local_rho_set, do_rho0=.false., &
228 pw_env_sub=sub_env%pw_env)
231 pw_env_external=sub_env%pw_env, &
232 task_list_external=sub_env%task_list_orb, &
233 para_env_external=sub_env%para_env)
238 CALL dbcsr_set(work_matrices%A_ia_munu_sub(ispin)%matrix, 0.0_dp)
243 CALL pw_zero(work_matrices%A_ia_rspace_sub(ispin))
249 IF (.NOT. dft_control%tddfpt2_control%do_bse)
THEN
253 IF (kernel_env%do_exck)
THEN
256 CALL tddfpt_apply_xc(a_ia_rspace=work_matrices%A_ia_rspace_sub, kernel_env=kernel_env, &
257 rho_ia_struct=work_matrices%rho_xc_struct_sub, &
258 is_rks_triplets=is_rks_triplets, pw_env=sub_env%pw_env, &
260 work_v_xc=work_matrices%wpw_rspace_sub, &
261 work_v_xc_tau=work_matrices%wpw_tau_rspace_sub, &
265 CALL pw_scale(work_matrices%A_ia_rspace_sub(ispin), &
266 work_matrices%A_ia_rspace_sub(ispin)%pw_grid%dvol)
267 CALL integrate_v_rspace(v_rspace=work_matrices%A_ia_rspace_sub(ispin), &
268 hmat=work_matrices%A_ia_munu_sub(ispin), &
269 qs_env=qs_env, calculate_forces=.false., gapw=gapw_xc, &
270 pw_env_external=sub_env%pw_env, &
271 task_list_external=sub_env%task_list_orb_soft)
272 CALL pw_zero(work_matrices%A_ia_rspace_sub(ispin))
275 IF (kernel_env%do_exck)
THEN
277 work_matrices%rho_orb_struct_sub, is_rks_triplets)
279 CALL tddfpt_apply_xc(a_ia_rspace=work_matrices%A_ia_rspace_sub, kernel_env=kernel_env, &
280 rho_ia_struct=work_matrices%rho_orb_struct_sub, &
281 is_rks_triplets=is_rks_triplets, pw_env=sub_env%pw_env, &
283 work_v_xc=work_matrices%wpw_rspace_sub, &
284 work_v_xc_tau=work_matrices%wpw_tau_rspace_sub, &
288 IF (gapw .OR. gapw_xc)
THEN
289 rho_atom_set => sub_env%local_rho_set%rho_atom_set
290 rho1_atom_set => work_matrices%local_rho_set%rho_atom_set
292 sub_env%para_env, do_tddfpt2=.true., do_triplet=is_rks_triplets, &
300 IF (do_admm .AND. admm_xc_correction)
THEN
303 rho_aux_fit_struct=work_matrices%rho_aux_fit_struct_sub, &
304 local_rho_set=work_matrices%local_rho_set_admm, &
305 qs_env=qs_env, sub_env=sub_env, &
306 wfm_rho_orb=work_matrices%rho_ao_orb_fm_sub, &
307 wfm_rho_aux_fit=work_matrices%rho_ao_aux_fit_fm_sub, &
308 wfm_aux_orb=work_matrices%wfm_aux_orb_sub)
311 CALL dbcsr_get_info(rho_ia_ao_aux_fit(1)%matrix, row_blk_size=blk_sizes)
312 ALLOCATE (a_xc_munu_sub(nspins))
314 ALLOCATE (a_xc_munu_sub(ispin)%matrix)
315 CALL dbcsr_create(matrix=a_xc_munu_sub(ispin)%matrix, name=
"ADMM_XC", &
316 dist=sub_env%dbcsr_dist, matrix_type=dbcsr_type_symmetric, &
317 row_blk_size=blk_sizes, col_blk_size=blk_sizes)
319 CALL dbcsr_set(a_xc_munu_sub(ispin)%matrix, 0.0_dp)
322 CALL pw_env_get(sub_env%pw_env, auxbas_pw_pool=auxbas_pw_pool)
323 ALLOCATE (v_rspace_sub(nspins))
325 CALL auxbas_pw_pool%create_pw(v_rspace_sub(ispin))
326 CALL pw_zero(v_rspace_sub(ispin))
329 IF (admm_env%do_gapw)
THEN
330 basis_type =
"AUX_FIT_SOFT"
331 task_list => sub_env%task_list_aux_fit_soft
333 basis_type =
"AUX_FIT"
334 task_list => sub_env%task_list_aux_fit
338 kernel_env=kernel_env_admm_aux, &
339 rho_ia_struct=work_matrices%rho_aux_fit_struct_sub, &
340 is_rks_triplets=is_rks_triplets, pw_env=sub_env%pw_env, &
342 work_v_xc=work_matrices%wpw_rspace_sub, &
343 work_v_xc_tau=work_matrices%wpw_tau_rspace_sub, &
346 CALL pw_scale(v_rspace_sub(ispin), v_rspace_sub(ispin)%pw_grid%dvol)
347 CALL integrate_v_rspace(v_rspace=v_rspace_sub(ispin), &
348 hmat=a_xc_munu_sub(ispin), &
349 qs_env=qs_env, calculate_forces=.false., &
350 pw_env_external=sub_env%pw_env, &
351 basis_type=basis_type, &
352 task_list_external=task_list)
354 IF (admm_env%do_gapw)
THEN
355 rho_atom_set => sub_env%local_rho_set_admm%rho_atom_set
356 rho1_atom_set => work_matrices%local_rho_set_admm%rho_atom_set
358 kernel_env_admm_aux%xc_section, &
359 sub_env%para_env, do_tddfpt2=.true., &
360 do_triplet=is_rks_triplets, do_sf=do_noncol, &
361 kind_set_external=admm_env%admm_gapw_env%admm_kind_set)
362 CALL update_ks_atom(qs_env, a_xc_munu_sub, rho_ia_ao_aux_fit, forces=.false., tddft=.true., &
363 rho_atom_external=rho1_atom_set, &
364 kind_set_external=admm_env%admm_gapw_env%admm_kind_set, &
365 oce_external=admm_env%admm_gapw_env%oce, &
366 sab_external=sub_env%sab_aux_fit)
369 CALL dbcsr_create(dbwork, template=work_matrices%A_ia_munu_sub(1)%matrix)
371 matrix_struct=work_matrices%wfm_aux_orb_sub%matrix_struct)
373 matrix_struct=work_matrices%rho_ao_orb_fm_sub%matrix_struct)
374 CALL cp_fm_get_info(work_aux_orb, nrow_global=nao_aux, ncol_global=nao)
378 CALL parallel_gemm(
'T',
'N', nao, nao, nao_aux, 1.0_dp, sub_env%admm_A, &
379 work_aux_orb, 0.0_dp, work_orb_orb)
380 CALL dbcsr_copy(dbwork, work_matrices%A_ia_munu_sub(1)%matrix)
383 CALL dbcsr_add(work_matrices%A_ia_munu_sub(ispin)%matrix, dbwork, 1.0_dp, 1.0_dp)
388 CALL auxbas_pw_pool%give_back_pw(v_rspace_sub(ispin))
390 DEALLOCATE (v_rspace_sub)
396 DEALLOCATE (a_xc_munu_sub)
399 kernel_env=kernel_env_admm_aux, &
400 rho_ia_struct=work_matrices%rho_aux_fit_struct_sub, &
401 is_rks_triplets=is_rks_triplets, pw_env=sub_env%pw_env, &
403 work_v_xc=work_matrices%wpw_rspace_sub, &
404 work_v_xc_tau=work_matrices%wpw_tau_rspace_sub, &
406 IF (admm_env%do_gapw)
THEN
407 cpwarn(
"GAPW/ADMM needs symmetric ADMM kernel")
408 cpabort(
"GAPW/ADMM@TDDFT")
415 IF ((.NOT. is_rks_triplets) .AND. (spinflip ==
no_sf_tddfpt))
THEN
420 CALL pw_axpy(rho_ia_g(ispin), rho_ia_g(1))
423 rho_ia_g=rho_ia_g(1), &
424 local_rho_set=work_matrices%local_rho_set, &
425 hartree_local=work_matrices%hartree_local, &
426 qs_env=qs_env, sub_env=sub_env, gapw=gapw, &
427 work_v_gspace=work_matrices%wpw_gspace_sub(1), &
428 work_v_rspace=work_matrices%wpw_rspace_sub(1), &
429 tddfpt_mgrid=tddfpt_mgrid)
434 IF (.NOT. do_lrigpw)
THEN
435 CALL pw_scale(work_matrices%A_ia_rspace_sub(ispin), &
436 work_matrices%A_ia_rspace_sub(ispin)%pw_grid%dvol)
439 CALL integrate_v_rspace(v_rspace=work_matrices%A_ia_rspace_sub(ispin), &
440 hmat=work_matrices%A_ia_munu_sub(ispin), &
441 qs_env=qs_env, calculate_forces=.false., gapw=gapw, &
442 pw_env_external=sub_env%pw_env, &
443 task_list_external=sub_env%task_list_orb_soft)
444 ELSEIF (gapw_xc)
THEN
445 IF (.NOT. is_rks_triplets)
THEN
446 CALL integrate_v_rspace(v_rspace=work_matrices%A_ia_rspace_sub(ispin), &
447 hmat=work_matrices%A_ia_munu_sub(ispin), &
448 qs_env=qs_env, calculate_forces=.false., gapw=.false., &
449 pw_env_external=sub_env%pw_env, task_list_external=sub_env%task_list_orb)
452 CALL integrate_v_rspace(v_rspace=work_matrices%A_ia_rspace_sub(ispin), &
453 hmat=work_matrices%A_ia_munu_sub(ispin), &
454 qs_env=qs_env, calculate_forces=.false., gapw=.false., &
455 pw_env_external=sub_env%pw_env, task_list_external=sub_env%task_list_orb)
458 CALL pw_scale(work_matrices%A_ia_rspace_sub(ispin), &
459 work_matrices%A_ia_rspace_sub(ispin)%pw_grid%dvol)
460 lri_v_int => kernel_env%lri_density%lri_coefs(ispin)%lri_kinds
461 CALL get_qs_env(qs_env, nkind=nkind, para_env=para_env)
463 lri_v_int(ikind)%v_int = 0.0_dp
465 CALL integrate_v_rspace_one_center(work_matrices%A_ia_rspace_sub(ispin), &
466 qs_env, lri_v_int, .false.,
"P_LRI_AUX")
468 CALL para_env%sum(lri_v_int(ikind)%v_int)
474 IF (.NOT. do_lrigpw)
THEN
475 IF (gapw .OR. gapw_xc)
THEN
477 CALL update_ks_atom(qs_env, work_matrices%A_ia_munu_sub, rho_ia_ao, forces=.false., &
478 rho_atom_external=work_matrices%local_rho_set%rho_atom_set, &
485 IF (do_lrigpw .AND. (.NOT. is_rks_triplets))
THEN
486 CALL tddfpt2_lri_amat(qs_env, sub_env, kernel_env%lri_env, lri_v_int, work_matrices%A_ia_munu_sub)
490 IF (
ALLOCATED(work_matrices%evects_sub))
THEN
492 sub_env%mos_active(ispin), &
493 work_matrices%Aop_evects_sub(ispin, ivect), &
494 ncol=nactive(ispin), alpha=1.0_dp, beta=0.0_dp)
497 sub_env%mos_active(ispin), &
498 aop_evects(ispin, ivect), &
499 ncol=nactive(ispin), alpha=1.0_dp, beta=0.0_dp)
504 CALL timestop(handle)
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, mimic, 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, sab_cneo, 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, xcint_weights, 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, rhoz_cneo_set, ecoul_1c, rho0_s_rs, rho0_s_gs, rhoz_cneo_s_rs, rhoz_cneo_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, do_rixs, tb_tblite)
Get the QUICKSTEP environment.