45 REAL(kind=
dp),
INTENT(IN) :: tdiag
46 INTEGER,
INTENT(IN) :: nelectron_total, iounit
48 REAL(kind=
dp),
DIMENSION(:),
POINTER :: tot_rho_r
55 CALL get_qs_env(qs_env=qs_env, energy=energy, dft_control=dft_control)
56 IF (qs_env%harris_method)
THEN
57 cpassert(.NOT. dft_control%qs_control%gapw)
58 cpassert(.NOT. dft_control%qs_control%gapw_xc)
60 CALL get_qs_env(qs_env=qs_env, rho=rho, qs_charges=qs_charges)
62 WRITE (unit=iounit, fmt=
"(/,(T3,A,T41,2F20.10))") &
63 "Electronic density on regular grids: ", &
65 sum(tot_rho_r) + nelectron_total, &
66 "Core density on regular grids:", &
67 qs_charges%total_rho_core_rspace, &
68 qs_charges%total_rho_core_rspace - real(nelectron_total + dft_control%charge,
dp)
69 WRITE (unit=iounit, fmt=
"(T3,A,T41,F20.10)") &
70 "Total charge density on r-space grids: ", &
72 qs_charges%total_rho_core_rspace, &
73 "Total charge density g-space grids: ", &
74 qs_charges%total_rho_gspace
76 WRITE (unit=iounit, fmt=
"(/,T2,A,T40,A,F10.2,T61,F20.10)") &
77 "Diagonalization",
"Time:", tdiag, energy%band
79 WRITE (unit=iounit, fmt=
"((T3,A,T56,F25.14))") &
80 "Core Hamiltonian energy: ", energy%core, &
81 "Overlap energy of the core charge distribution:", energy%core_overlap, &
82 "Self energy of the core charge distribution: ", energy%core_self, &
83 "Hartree energy: ", energy%hartree, &
84 "Exchange-correlation energy: ", energy%exc
85 IF (energy%dispersion /= 0.0_dp) &
86 WRITE (unit=iounit, fmt=
"(T3,A,T56,F25.14)") &
87 "Dispersion energy: ", energy%dispersion
88 IF (energy%gcp /= 0.0_dp) &
89 WRITE (unit=iounit, fmt=
"(T3,A,T56,F25.14)") &
90 "gCP energy: ", energy%gcp
91 IF (energy%efield /= 0.0_dp) &
92 WRITE (unit=iounit, fmt=
"(T3,A,T56,F25.14)") &
93 "Electric field interaction energy: ", energy%efield
95 ELSEIF (dft_control%qs_control%semi_empirical)
THEN
96 cpabort(
"NONSCF not available")
97 ELSEIF (dft_control%qs_control%dftb)
THEN
98 cpassert(energy%dftb3 == 0.0_dp)
99 energy%total = energy%total + energy%band + energy%qmmm_el
100 WRITE (unit=iounit, fmt=
"(/,T2,A,T40,A,F10.2,T61,F20.10)") &
101 "Diagonalization",
"Time:", tdiag, energy%total
102 WRITE (unit=iounit, fmt=
"((T3,A,T56,F25.14))") &
103 "Core Hamiltonian energy: ", energy%core, &
104 "Repulsive potential energy: ", energy%repulsive, &
105 "Dispersion energy: ", energy%dispersion
106 IF (energy%efield /= 0.0_dp) &
107 WRITE (unit=iounit, fmt=
"(T3,A,T56,F25.14)") &
108 "Electric field interaction energy: ", energy%efield
109 ELSEIF (dft_control%qs_control%xtb)
THEN
110 energy%total = energy%total + energy%band + energy%qmmm_el
111 WRITE (unit=iounit, fmt=
"(/,T2,A,T40,A,F10.2,T61,F20.10)") &
112 "Diagonalization",
"Time:", tdiag, energy%total
113 cpassert(dft_control%qs_control%xtb_control%gfn_type == 0)
114 WRITE (unit=iounit, fmt=
"((T3,A,T56,F25.14))") &
115 "Core Hamiltonian energy: ", energy%core, &
116 "Repulsive potential energy: ", energy%repulsive, &
117 "SRB Correction energy: ", energy%srb, &
118 "Charge equilibration energy: ", energy%eeq, &
119 "Dispersion energy: ", energy%dispersion
120 IF (dft_control%qs_control%xtb_control%do_nonbonded) &
121 WRITE (unit=iounit, fmt=
"(T3,A,T56,F25.14)") &
122 "Correction for nonbonded interactions: ", energy%xtb_nonbonded
123 IF (energy%efield /= 0.0_dp) &
124 WRITE (unit=iounit, fmt=
"(T3,A,T56,F25.14)") &
125 "Electric field interaction energy: ", energy%efield
127 cpabort(
"NONSCF not available")
129 IF (dft_control%smear)
THEN
130 WRITE (unit=iounit, fmt=
"((T3,A,T56,F25.14))") &
131 "Electronic entropic energy:", energy%kTS
132 WRITE (unit=iounit, fmt=
"((T3,A,T56,F25.14))") &
133 "Fermi energy:", energy%efermi
135 IF (energy%qmmm_el /= 0.0_dp)
THEN
136 WRITE (unit=iounit, fmt=
"(T3,A,T56,F25.14)") &
137 "QM/MM Electrostatic energy: ", energy%qmmm_el
138 IF (qs_env%qmmm_env_qm%image_charge)
THEN
139 WRITE (unit=iounit, fmt=
"(T3,A,T56,F25.14)") &
140 "QM/MM image charge energy: ", energy%image_charge
144 WRITE (unit=iounit, fmt=
"(/,(T3,A,T56,F25.14))") &
145 "Total energy: ", energy%total
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.