62      CHARACTER(len=*), 
PARAMETER :: routinen = 
'calc_dipsurf_potential' 
   64      INTEGER                                            :: handle, i, idir_surfdip, ilayer_min, &
 
   65                                                            ilow, irho, ispin, isurf, iup, jsurf, &
 
   67      INTEGER, 
DIMENSION(3)                              :: ngrid
 
   68      INTEGER, 
DIMENSION(:, :), 
POINTER                  :: bo
 
   69      REAL(
dp)                                           :: cutoff, dh(3, 3), dip_fac, dip_hh, &
 
   70                                                            dsurf, height_min, hh, pos_surf_dip, &
 
   71                                                            rhoav_min, surfarea, vdip, vdip_fac
 
   72      REAL(
dp), 
ALLOCATABLE, 
DIMENSION(:)                :: rhoavsurf
 
   75      TYPE(
pw_c1d_gs_type), 
POINTER                      :: rho0_s_gs, rho_core, rhoz_cneo_s_gs
 
   85      CALL timeset(routinen, handle)
 
   86      NULLIFY (cell, dft_control, rho, pw_env, auxbas_pw_pool, &
 
   87               pw_pools, subsys, v_hartree_rspace, rho_r, rhoz_cneo_s_gs)
 
   90                      dft_control=dft_control, &
 
   93                      rho0_s_gs=rho0_s_gs, &
 
   94                      rhoz_cneo_s_gs=rhoz_cneo_s_gs, &
 
   98                      v_hartree_rspace=v_hartree_rspace)
 
  100      CALL pw_env_get(pw_env, auxbas_pw_pool=auxbas_pw_pool, &
 
  102      CALL auxbas_pw_pool%create_pw(wf_r)
 
  103      CALL auxbas_pw_pool%create_pw(vdip_r)
 
  105      IF (dft_control%qs_control%gapw) 
THEN 
  106         IF (dft_control%qs_control%gapw_control%nopaw_as_gpw) 
THEN 
  107            CALL pw_axpy(rho_core, rho0_s_gs)
 
  108            IF (
ASSOCIATED(rhoz_cneo_s_gs)) 
THEN 
  109               CALL pw_axpy(rhoz_cneo_s_gs, rho0_s_gs)
 
  112            CALL pw_axpy(rho_core, rho0_s_gs, -1.0_dp)
 
  113            IF (
ASSOCIATED(rhoz_cneo_s_gs)) 
THEN 
  114               CALL pw_axpy(rhoz_cneo_s_gs, rho0_s_gs, -1.0_dp)
 
  117            IF (
ASSOCIATED(rhoz_cneo_s_gs)) 
THEN 
  118               CALL pw_axpy(rhoz_cneo_s_gs, rho0_s_gs)
 
  121            IF (
ASSOCIATED(rhoz_cneo_s_gs)) 
THEN 
  122               CALL pw_axpy(rhoz_cneo_s_gs, rho0_s_gs, -1.0_dp)
 
  129      DO ispin = 1, dft_control%nspins
 
  130         CALL pw_axpy(rho_r(ispin), wf_r)
 
  133      ngrid(1:3) = wf_r%pw_grid%npts(1:3)
 
  134      idir_surfdip = dft_control%dir_surf_dip
 
  139         IF (i /= idir_surfdip) 
THEN 
  140            IF (abs(wf_r%pw_grid%dh(idir_surfdip, i)) > 1.e-7_dp) 
THEN 
  142               CALL cp_abort(__location__, &
 
  143                             "Dipole correction only for surface perpendicular to one Cartesian axis")
 
  151      ilow = wf_r%pw_grid%bounds(1, idir_surfdip)
 
  152      iup = wf_r%pw_grid%bounds(2, idir_surfdip)
 
  154      ALLOCATE (rhoavsurf(ilow:iup))
 
  157      bo => wf_r%pw_grid%bounds_local
 
  160      CALL pw_scale(wf_r, wf_r%pw_grid%vol)
 
  161      IF (idir_surfdip == 3) 
THEN 
  165         DO i = bo(1, 3), bo(2, 3)
 
  166            rhoavsurf(i) = 
accurate_sum(wf_r%array(bo(1, 1):bo(2, 1), bo(1, 2):bo(2, 2), i))
 
  169      ELSEIF (idir_surfdip == 2) 
THEN 
  173         DO i = bo(1, 2), bo(2, 2)
 
  174            rhoavsurf(i) = 
accurate_sum(wf_r%array(bo(1, 1):bo(2, 1), i, bo(1, 3):bo(2, 3)))
 
  180         DO i = bo(1, 1), bo(2, 1)
 
  181            rhoavsurf(i) = 
accurate_sum(wf_r%array(i, bo(1, 2):bo(2, 2), bo(1, 3):bo(2, 3)))
 
  184      CALL pw_scale(wf_r, 1.0_dp/wf_r%pw_grid%vol)
 
  185      rhoavsurf = rhoavsurf/wf_r%pw_grid%vol
 
  187      surfarea = cell%hmat(isurf, isurf)*cell%hmat(jsurf, jsurf) - &
 
  188                 cell%hmat(isurf, jsurf)*cell%hmat(jsurf, isurf)
 
  189      dsurf = surfarea/real(ngrid(isurf)*ngrid(jsurf), 
dp)
 
  192         CALL wf_r%pw_grid%para%group%sum(rhoavsurf)
 
  194      rhoavsurf(ilow:iup) = dsurf*rhoavsurf(ilow:iup)
 
  197      rhoavsurf(ilow:iup) = rhoavsurf(ilow:iup)/surfarea
 
  199      IF (dft_control%pos_dir_surf_dip < 0.0_dp) 
THEN 
  200         ilayer_min = ilow - 1 + minloc(abs(rhoavsurf(ilow:iup)), 1)
 
  202         pos_surf_dip = dft_control%pos_dir_surf_dip*
bohr 
  203         ilayer_min = ilow - 1 + nint(pos_surf_dip/dh(idir_surfdip, idir_surfdip)) + 1
 
  205      rhoav_min = abs(rhoavsurf(ilayer_min))
 
  206      IF (rhoav_min >= 1.e-5_dp) 
THEN 
  207         cpabort(
" Dipole correction needs more vacuum space above the surface ")
 
  210      height_min = real((ilayer_min - ilow), 
dp)*dh(idir_surfdip, idir_surfdip)
 
  215      dip_fac = wf_r%pw_grid%vol*dh(idir_surfdip, idir_surfdip)/real(ngrid(idir_surfdip), 
dp)
 
  217      DO i = ilayer_min + 1, ilayer_min + ngrid(idir_surfdip)
 
  218         hh = real((i - ilayer_min), 
dp)
 
  220            irho = i - ngrid(idir_surfdip)
 
  225         IF (abs(irho - ilayer_min) > width) 
THEN 
  228            cutoff = abs(sin(0.5_dp*
pi*real(abs(irho - ilayer_min), 
dp)/real(width, 
dp)))
 
  230         dip_hh = dip_hh + rhoavsurf(irho)*hh*dip_fac*cutoff
 
  233      DEALLOCATE (rhoavsurf)
 
  235      qs_env%surface_dipole_moment = dip_hh/
bohr 
  239      vdip_fac = dip_hh*4.0_dp*
pi 
  241      DO i = ilayer_min + 1, ilayer_min + ngrid(idir_surfdip)
 
  242         hh = real((i - ilayer_min), 
dp)*dh(idir_surfdip, idir_surfdip)
 
  243         vdip = vdip_fac*(-0.5_dp + (hh/cell%hmat(idir_surfdip, idir_surfdip)))* &
 
  244                v_hartree_rspace%pw_grid%dvol/surfarea
 
  246            irho = i - ngrid(idir_surfdip)
 
  251         IF (abs(irho - ilayer_min) > width) 
THEN 
  254            cutoff = abs(sin(0.5_dp*
pi*real(abs(irho - ilayer_min), 
dp)/real(width, 
dp)))
 
  258         IF (idir_surfdip == 3) 
THEN 
  259            vdip_r%array(bo(1, 1):bo(2, 1), bo(1, 2):bo(2, 2), irho) = &
 
  260               vdip_r%array(bo(1, 1):bo(2, 1), bo(1, 2):bo(2, 2), irho) + vdip
 
  261         ELSEIF (idir_surfdip == 2) 
THEN 
  262            IF (irho >= bo(1, 2) .AND. irho <= bo(2, 2)) 
THEN 
  263               vdip_r%array(bo(1, 1):bo(2, 1), irho, bo(1, 3):bo(2, 3)) = &
 
  264                  vdip_r%array(bo(1, 1):bo(2, 1), irho, bo(1, 3):bo(2, 3)) + vdip
 
  267            IF (irho >= bo(1, 1) .AND. irho <= bo(2, 1)) 
THEN 
  268               vdip_r%array(irho, bo(1, 2):bo(2, 2), bo(1, 3):bo(2, 3)) = &
 
  269                  vdip_r%array(irho, bo(1, 2):bo(2, 2), bo(1, 3):bo(2, 3)) + vdip
 
  276      energy%surf_dipole = 0.5_dp*
pw_integral_ab(vdip_r, wf_r, just_sum=.true.)
 
  279      CALL pw_axpy(vdip_r, v_hartree_rspace)
 
  281      CALL auxbas_pw_pool%give_back_pw(wf_r)
 
  282      CALL auxbas_pw_pool%give_back_pw(vdip_r)
 
  284      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, 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, 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.