61 REAL(
dp),
DIMENSION(3),
INTENT(OUT) :: rpoint
62 REAL(
dp),
DIMENSION(3),
INTENT(OUT),
OPTIONAL :: drpoint
65 INTEGER,
INTENT(IN) :: reference
66 REAL(kind=
dp),
DIMENSION(:),
OPTIONAL,
POINTER :: ref_point
67 INTEGER,
INTENT(IN),
OPTIONAL :: ifirst, ilast
69 INTEGER :: akind, ia, iatom, ikind
70 LOGICAL :: do_molecule
71 REAL(
dp) :: charge, mass, mass_low, mtot, ztot
72 REAL(
dp),
DIMENSION(3) :: center, ria
80 cpassert(
PRESENT(ifirst) .EQV.
PRESENT(ilast))
81 NULLIFY (cell, particle_set, qs_kind_set, local_particles, para_env)
82 IF (
PRESENT(qs_env))
THEN
83 CALL get_qs_env(qs_env, cell=cell, particle_set=particle_set, &
84 qs_kind_set=qs_kind_set, &
85 local_particles=local_particles, para_env=para_env)
87 IF (
PRESENT(fist_env))
THEN
88 CALL fist_env_get(fist_env, cell=cell, particle_set=particle_set, &
89 local_particles=local_particles, para_env=para_env)
92 IF (
PRESENT(ifirst) .AND.
PRESENT(ilast)) do_molecule = .true.
93 IF (
PRESENT(drpoint)) drpoint = 0.0_dp
95 cpabort(
"User reference point not supplied!")
97 SELECT CASE (reference)
99 cpabort(
"Type of reference point not implemented")
104 IF (do_molecule)
THEN
105 mass_low = -huge(mass_low)
107 DO iatom = ifirst, ilast
108 atomic_kind => particle_set(iatom)%atomic_kind
110 IF (mass > mass_low)
THEN
112 center = particle_set(iatom)%r
115 DO iatom = ifirst, ilast
116 ria = particle_set(iatom)%r
117 ria =
pbc(ria - center, cell) + center
118 atomic_kind => particle_set(iatom)%atomic_kind
120 rpoint(:) = rpoint(:) + mass*ria(:)
121 IF (
PRESENT(drpoint)) drpoint = drpoint + mass*particle_set(iatom)%v
125 DO ikind = 1,
SIZE(local_particles%n_el)
126 DO ia = 1, local_particles%n_el(ikind)
127 iatom = local_particles%list(ikind)%array(ia)
128 ria = particle_set(iatom)%r
130 atomic_kind => particle_set(iatom)%atomic_kind
132 rpoint(:) = rpoint(:) + mass*ria(:)
133 IF (
PRESENT(drpoint)) drpoint = drpoint + mass*particle_set(iatom)%v
137 CALL para_env%sum(rpoint)
138 CALL para_env%sum(mtot)
140 IF (abs(mtot) > 0._dp)
THEN
141 rpoint(:) = rpoint(:)/mtot
142 IF (
PRESENT(drpoint)) drpoint = drpoint/mtot
148 IF (do_molecule)
THEN
149 mass_low = -huge(mass_low)
151 DO iatom = ifirst, ilast
152 atomic_kind => particle_set(iatom)%atomic_kind
154 IF (mass > mass_low)
THEN
156 center = particle_set(iatom)%r
159 DO iatom = ifirst, ilast
160 ria = particle_set(iatom)%r
161 ria =
pbc(ria - center, cell) + center
162 atomic_kind => particle_set(iatom)%atomic_kind
164 CALL get_qs_kind(qs_kind_set(akind), core_charge=charge)
165 rpoint(:) = rpoint(:) + charge*ria(:)
166 IF (
PRESENT(drpoint)) drpoint = drpoint + charge*particle_set(iatom)%v
170 DO ikind = 1,
SIZE(local_particles%n_el)
171 DO ia = 1, local_particles%n_el(ikind)
172 iatom = local_particles%list(ikind)%array(ia)
173 ria = particle_set(iatom)%r
175 atomic_kind => particle_set(iatom)%atomic_kind
177 CALL get_qs_kind(qs_kind_set(akind), core_charge=charge)
178 rpoint(:) = rpoint(:) + charge*ria(:)
179 IF (
PRESENT(drpoint)) drpoint = drpoint + charge*particle_set(iatom)%v
183 CALL para_env%sum(rpoint)
184 CALL para_env%sum(ztot)
186 IF (abs(ztot) > 0._dp)
THEN
187 rpoint(:) = rpoint(:)/ztot
188 IF (
PRESENT(drpoint)) drpoint = drpoint/ztot
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.
subroutine, public get_qs_kind(qs_kind, basis_set, basis_type, ncgf, nsgf, all_potential, tnadd_potential, gth_potential, sgp_potential, upf_potential, cneo_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, monovalent, floating, name, element_symbol, pao_basis_size, pao_model_file, pao_potentials, pao_descriptors, nelec)
Get attributes of an atomic kind.