113#include "./base/base_uses.f90"
120 CHARACTER(len=*),
PARAMETER,
PRIVATE :: moduleN =
'qs_linres_module'
134 SUBROUTINE vcd_linres(qs_env, p_env)
135 TYPE(qs_environment_type),
POINTER :: qs_env
136 TYPE(qs_p_env_type) :: p_env
138 INTEGER :: beta, i, latom
139 LOGICAL :: mfp_is_done, mfp_repeat
140 TYPE(vcd_env_type) :: vcd_env
147 mfp_repeat = vcd_env%distributed_origin
148 mfp_is_done = .false.
150 qs_env%linres_control%linres_restart = .true.
154 DO latom = 1,
SIZE(vcd_env%dcdr_env%list_of_atoms)
155 vcd_env%dcdr_env%lambda = vcd_env%dcdr_env%list_of_atoms(latom)
162 vcd_env%dcdr_env%beta = beta
163 vcd_env%dcdr_env%deltaR(vcd_env%dcdr_env%beta, vcd_env%dcdr_env%lambda) = 1._dp
168 CALL apt_dr(qs_env, vcd_env%dcdr_env)
174 CALL apt_dv(vcd_env, qs_env)
175 CALL aat_dv(vcd_env, qs_env)
177 IF (vcd_env%do_mfp)
THEN
181 IF (.NOT. mfp_is_done .OR. mfp_repeat)
THEN
183 IF (vcd_env%origin_dependent_op_mfp)
THEN
184 cpwarn(
"Using the origin dependent MFP operator")
198 vcd_env%dcdr_env%apt_total_dcdr(:, :, vcd_env%dcdr_env%lambda) = &
199 vcd_env%dcdr_env%apt_el_dcdr(:, :, vcd_env%dcdr_env%lambda) &
200 + vcd_env%dcdr_env%apt_nuc_dcdr(:, :, vcd_env%dcdr_env%lambda)
202 vcd_env%apt_total_nvpt(:, :, vcd_env%dcdr_env%lambda) = &
203 vcd_env%apt_el_nvpt(:, :, vcd_env%dcdr_env%lambda) + vcd_env%apt_nuc_nvpt(:, :, vcd_env%dcdr_env%lambda)
205 IF (vcd_env%do_mfp) &
206 vcd_env%aat_atom_mfp(:, :, vcd_env%dcdr_env%lambda) = vcd_env%aat_atom_mfp(:, :, vcd_env%dcdr_env%lambda)*4._dp
213 END SUBROUTINE vcd_linres
225 SUBROUTINE dcdr_linres(qs_env, p_env)
226 TYPE(qs_environment_type),
POINTER :: qs_env
227 TYPE(qs_p_env_type) :: p_env
229 INTEGER :: beta, latom
230 TYPE(dcdr_env_type) :: dcdr_env
231 TYPE(polar_env_type),
POINTER :: polar_env
236 IF (.NOT. dcdr_env%z_matrix_method)
THEN
238 DO latom = 1,
SIZE(dcdr_env%list_of_atoms)
239 dcdr_env%lambda = dcdr_env%list_of_atoms(latom)
244 dcdr_env%deltaR(dcdr_env%beta, dcdr_env%lambda) = 1._dp
249 IF (.NOT. dcdr_env%localized_psi0)
THEN
250 CALL apt_dr(qs_env, dcdr_env)
251 ELSE IF (dcdr_env%localized_psi0)
THEN
257 dcdr_env%apt_total_dcdr(:, :, dcdr_env%lambda) = &
258 dcdr_env%apt_el_dcdr(:, :, dcdr_env%lambda) + dcdr_env%apt_nuc_dcdr(:, :, dcdr_env%lambda)
264 CALL get_qs_env(qs_env=qs_env, polar_env=polar_env)
267 IF (.NOT. dcdr_env%localized_psi0)
THEN
273 polar_env%do_periodic = .false.
276 DO latom = 1,
SIZE(dcdr_env%list_of_atoms)
277 dcdr_env%lambda = dcdr_env%list_of_atoms(latom)
282 dcdr_env%deltaR(dcdr_env%beta, dcdr_env%lambda) = 1._dp
285 IF (.NOT. dcdr_env%localized_psi0)
THEN
286 CALL apt_dr(qs_env, dcdr_env)
292 dcdr_env%apt_total_dcdr(:, :, dcdr_env%lambda) = &
293 dcdr_env%apt_el_dcdr(:, :, dcdr_env%lambda) + dcdr_env%apt_nuc_dcdr(:, :, dcdr_env%lambda)
300 END SUBROUTINE dcdr_linres
313 CHARACTER(LEN=*),
PARAMETER :: routinen =
'linres_calculation'
318 CALL timeset(routinen, handle)
322 cpassert(
ASSOCIATED(force_env))
323 cpassert(force_env%ref_count > 0)
325 SELECT CASE (force_env%in_use)
329 qs_env => force_env%qmmm_env%qs_env
331 cpabort(
"Does not recognize this force_env")
334 qs_env%linres_run = .true.
338 CALL timestop(handle)
357 CHARACTER(LEN=*),
PARAMETER :: routinen =
'linres_calculation_low'
359 INTEGER :: every_n_step, handle, iounit
360 LOGICAL :: dcdr_present, epr_present, issc_present, &
361 lr_calculation, nmr_present, &
362 polar_present, vcd_present
369 CALL timeset(routinen, handle)
371 lr_calculation = .false.
372 nmr_present = .false.
373 epr_present = .false.
374 issc_present = .false.
375 polar_present = .false.
376 dcdr_present = .false.
378 NULLIFY (dft_control, linres_control, logger, prop_section, lr_section)
386 IF (lr_calculation .AND.
modulo(qs_env%sim_step, every_n_step) == 0)
THEN
387 CALL linres_init(lr_section, p_env, qs_env)
389 extension=
".linresLog")
390 CALL get_qs_env(qs_env=qs_env, dft_control=dft_control, &
391 linres_control=linres_control)
394 linres_control%property =
lr_none
402 IF (nmr_present .OR. epr_present)
THEN
403 CALL nmr_epr_linres(linres_control, qs_env, p_env, dft_control, &
404 nmr_present, epr_present, iounit)
411 IF (issc_present)
THEN
412 CALL issc_linres(linres_control, qs_env, p_env, dft_control)
418 IF (polar_present)
THEN
419 CALL polar_linres(qs_env, p_env)
426 IF (dcdr_present)
THEN
427 CALL dcdr_linres(qs_env, p_env)
434 IF (vcd_present)
THEN
435 CALL vcd_linres(qs_env, p_env)
443 WRITE (unit=iounit, fmt=
"(/,T2,A,/,T25,A,/,T2,A,/)") &
445 "ENDED LINRES CALCULATION", &
449 "PRINT%PROGRAM_RUN_INFO")
452 CALL timestop(handle)
468 SUBROUTINE linres_init(lr_section, p_env, qs_env)
474 INTEGER :: iounit, ispin
477 TYPE(
dbcsr_p_type),
DIMENSION(:),
POINTER :: matrix_ks, rho_ao
487 extension=
".linresLog")
488 NULLIFY (dft_control, linres_control, loc_section, rho, mos, matrix_ks, rho_ao)
490 ALLOCATE (linres_control)
491 CALL set_qs_env(qs_env=qs_env, linres_control=linres_control)
493 dft_control=dft_control, matrix_ks=matrix_ks, mos=mos, rho=rho)
499 l_val=linres_control%localized_psi0)
500 IF (linres_control%localized_psi0)
THEN
502 WRITE (unit=iounit, fmt=
"(/,T3,A,A)") &
503 "Localization of ground state orbitals", &
504 " before starting linear response calculation"
509 DO ispin = 1, dft_control%nspins
521 CALL section_vals_val_get(lr_section,
"PRECONDITIONER", i_val=linres_control%preconditioner_type)
525 WRITE (unit=iounit, fmt=
"(/,T2,A,/,T25,A,/,T2,A,/)") &
527 "START LINRES CALCULATION", &
530 WRITE (unit=iounit, fmt=
"(T2,A)") &
531 "LINRES| Properties to be calculated:"
533 IF (do_it)
WRITE (unit=iounit, fmt=
"(T62,A)")
"NMR Chemical Shift"
535 IF (do_it)
WRITE (unit=iounit, fmt=
"(T68,A)")
"EPR g Tensor"
537 IF (do_it)
WRITE (unit=iounit, fmt=
"(T43,A)")
"Indirect spin-spin coupling constants"
539 IF (do_it)
WRITE (unit=iounit, fmt=
"(T57,A)")
"Electric Polarizability"
541 IF (linres_control%localized_psi0)
WRITE (unit=iounit, fmt=
"(T2,A,T65,A)") &
542 "LINRES|",
" LOCALIZED PSI0"
544 WRITE (unit=iounit, fmt=
"(T2,A,T60,A)") &
545 "LINRES| Optimization algorithm",
" Conjugate Gradients"
547 SELECT CASE (linres_control%preconditioner_type)
549 WRITE (unit=iounit, fmt=
"(T2,A,T60,A)") &
550 "LINRES| Preconditioner",
" NONE"
552 WRITE (unit=iounit, fmt=
"(T2,A,T60,A)") &
553 "LINRES| Preconditioner",
" FULL_SINGLE"
555 WRITE (unit=iounit, fmt=
"(T2,A,T60,A)") &
556 "LINRES| Preconditioner",
" FULL_KINETIC"
558 WRITE (unit=iounit, fmt=
"(T2,A,T60,A)") &
559 "LINRES| Preconditioner",
" FULL_S_INVERSE"
561 WRITE (unit=iounit, fmt=
"(T2,A,T60,A)") &
562 "LINRES| Preconditioner",
" FULL_SINGLE_INVERSE"
564 WRITE (unit=iounit, fmt=
"(T2,A,T60,A)") &
565 "LINRES| Preconditioner",
" FULL_ALL"
567 cpabort(
"Preconditioner NYI")
570 WRITE (unit=iounit, fmt=
"(T2,A,T72,ES8.1)") &
571 "LINRES| EPS", linres_control%eps
572 WRITE (unit=iounit, fmt=
"(T2,A,T72,I8)") &
573 "LINRES| MAX_ITER", linres_control%max_iter
579 CALL p_env_create(p_env, qs_env, orthogonal_orbitals=.true., linres_control=linres_control)
584 p_env%new_preconditioner = .true.
586 "PRINT%PROGRAM_RUN_INFO")
588 END SUBROUTINE linres_init
600 SUBROUTINE nmr_epr_linres(linres_control, qs_env, p_env, dft_control, nmr_present, epr_present, iounit)
606 LOGICAL :: nmr_present, epr_present
619 IF (.NOT. linres_control%localized_psi0)
THEN
620 CALL cp_abort(__location__, &
621 "Are you sure that you want to calculate the chemical "// &
622 "shift without localized psi0?")
624 dft_control%nspins, centers_only=.true.)
626 IF (dft_control%nspins /= 2 .AND. epr_present)
THEN
627 cpabort(
"LSD is needed to perform a g tensor calculation!")
632 IF (qs_env%qmmm)
do_qmmm = .true.
639 IF (current_env%all_pert_op_done)
THEN
641 IF (nmr_present)
THEN
646 IF (epr_present)
THEN
663 IF (nmr_present)
THEN
664 CALL nmr_shift(nmr_env, current_env, qs_env, ib)
668 IF (epr_present)
THEN
670 CALL epr_g_so(epr_env, current_env, qs_env, ib)
671 CALL epr_g_soo(epr_env, current_env, qs_env, ib)
676 IF (nmr_present)
THEN
682 IF (epr_present)
THEN
689 WRITE (iounit,
"(T10,A,/T20,A,/)") &
690 "CURRENT: Not all responses to perturbation operators could be calculated.", &
691 " Hence: NO nmr and NO epr possible."
697 END SUBROUTINE nmr_epr_linres
706 SUBROUTINE issc_linres(linres_control, qs_env, p_env, dft_control)
719 IF (.NOT. linres_control%localized_psi0)
THEN
720 CALL cp_abort(__location__, &
721 "Are you sure that you want to calculate the chemical "// &
722 "shift without localized psi0?")
724 dft_control%nspins, centers_only=.true.)
729 IF (qs_env%qmmm)
do_qmmm = .true.
739 DO iatom = 1, issc_env%issc_natms
749 END SUBROUTINE issc_linres
758 SUBROUTINE polar_linres(qs_env, p_env)
769 END SUBROUTINE polar_linres
static GRID_HOST_DEVICE int modulo(int a, int m)
Equivalent of Fortran's MODULO, which always return a positive number. https://gcc....
collects all references to literature in CP2K as new algorithms / method are included from literature...
integer, save, public weber2009
integer, save, public ditler2021
integer, save, public ditler2022
Defines control structures, which contain the parameters and the settings for the DFT-based calculati...
various routines to log and control the output. The idea is that decisions about where to log should ...
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,...
Interface for the force calculations.
integer, parameter, public use_qmmm
recursive subroutine, public force_env_get(force_env, in_use, fist_env, qs_env, meta_env, fp_env, subsys, para_env, potential_energy, additional_potential, kinetic_energy, harmonic_shell, kinetic_shell, cell, sub_force_env, qmmm_env, qmmmx_env, eip_env, pwdft_env, globenv, input, force_env_section, method_name_id, root_section, mixed_env, nnp_env, embed_env, ipi_env)
returns various attributes about the force environment
integer, parameter, public use_qs_force
Defines the basic variable types.
integer, parameter, public dp
Calculate the derivatives of the MO coefficients wrt nuclear coordinates.
subroutine, public dcdr_env_cleanup(qs_env, dcdr_env)
Deallocate the dcdr environment.
subroutine, public dcdr_print(dcdr_env, qs_env)
Print the APT and sum rules.
subroutine, public dcdr_env_init(dcdr_env, qs_env)
Initialize the dcdr environment.
Calculate the derivatives of the MO coefficients wrt nuclear coordinates.
subroutine, public prepare_per_atom(dcdr_env, qs_env)
Prepare the environment for a choice of lambda.
subroutine, public apt_dr_localization(qs_env, dcdr_env)
Calculate atomic polar tensor using the localized dipole operator.
subroutine, public apt_dr(qs_env, dcdr_env)
Calculate atomic polar tensor.
subroutine, public dcdr_response_dr(dcdr_env, p_env, qs_env)
Get the dC/dR by solving the Sternheimer equation, using the op_dR matrix.
subroutine, public dcdr_build_op_dr(dcdr_env, qs_env)
Build the operator for the position perturbation.
collects routines that calculate density matrices
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.
subroutine, public set_qs_env(qs_env, super_cell, mos, qmmm, qmmm_periodic, ewald_env, ewald_pw, mpools, rho_external, external_vxc, mask, scf_control, rel_control, qs_charges, ks_env, ks_qmmm_env, wf_history, scf_env, active_space, input, oce, rho_atom_set, rho0_atom_set, rho0_mpole, run_rtp, rtp, rhoz_set, rhoz_tot, ecoul_1c, has_unit_metric, requires_mo_derivs, mo_derivs, mo_loc_history, efield, linres_control, xas_env, cp_ddapc_env, cp_ddapc_ewald, outer_scf_history, outer_scf_ihistory, x_data, et_coupling, dftb_potential, se_taper, se_store_int_env, se_nddo_mpole, se_nonbond_env, admm_env, ls_scf_env, do_transport, transport_env, lri_env, lri_density, exstate_env, ec_env, dispersion_env, harris_env, gcp_env, mp2_env, bs_env, kg_env, force, kpoints, wanniercentres, almo_scf_env, gradient_history, variable_history, embed_pot, spin_embed_pot, polar_env, mos_last_converged, eeq, rhs)
Set the QUICKSTEP environment.
Chemical shift calculation by dfpt Initialization of the nmr_env, creation of the special neighbor li...
subroutine, public current_response(current_env, p_env, qs_env)
...
subroutine, public current_env_init(current_env, qs_env)
...
subroutine, public current_env_cleanup(current_env)
...
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...
subroutine, public current_build_chi(current_env, qs_env, ib)
...
Calculates Nabla V_KS (local part if PSP) on the different grids.
subroutine, public epr_nablavks(epr_env, qs_env)
Evaluates Nabla V_KS on the grids.
subroutine, public epr_g_soo(epr_env, current_env, qs_env, ib)
Calculates g_soo (soft part only for now)
subroutine, public epr_g_so(epr_env, current_env, qs_env, ib)
Calculates g_so.
subroutine, public epr_g_zke(epr_env, qs_env)
Calculate zke part of the g tensor.
subroutine, public epr_ind_magnetic_field(epr_env, current_env, qs_env, ib)
...
subroutine, public epr_g_print(epr_env, qs_env)
Prints the g tensor.
g tensor calculation by dfpt Initialization of the epr_env, creation of the special neighbor lists Pe...
subroutine, public epr_env_cleanup(epr_env)
Deallocate the epr environment.
subroutine, public epr_env_init(epr_env, qs_env)
Initialize the epr environment.
Chemical shift calculation by dfpt Initialization of the issc_env, creation of the special neighbor l...
subroutine, public issc_issc(issc_env, qs_env, iatom)
...
subroutine, public issc_response(issc_env, p_env, qs_env)
Initialize the issc environment.
subroutine, public issc_env_cleanup(issc_env)
Deallocate the issc environment.
subroutine, public issc_env_init(issc_env, qs_env)
Initialize the issc environment.
subroutine, public issc_print(issc_env, qs_env)
...
localize wavefunctions linear response scf
subroutine, public linres_localize(qs_env, linres_control, nspins, centers_only)
Find the centers and spreads of the wfn, if required apply a localization algorithm.
Contains the setup for the calculation of properties by linear response by the application of second ...
subroutine, public linres_calculation(force_env)
Driver for the linear response calculatios.
subroutine, public linres_calculation_low(qs_env)
Linear response can be called as run type or as post scf calculation Initialize the perturbation envi...
from the response current density calculates the shift tensor and the susceptibility
subroutine, public nmr_shift_print(nmr_env, current_env, qs_env)
Shielding tensor and Chi are printed into a file if required from input It is possible to print only ...
subroutine, public nmr_shift(nmr_env, current_env, qs_env, ib)
...
Chemical shift calculation by dfpt Initialization of the nmr_env, creation of the special neighbor li...
subroutine, public nmr_env_cleanup(nmr_env)
Deallocate the nmr environment.
subroutine, public nmr_env_init(nmr_env, qs_env)
Initialize the nmr environment.
Calculate the operators p rxp and D needed in the optimization of the different contribution of the f...
subroutine, public polar_operators_local_wannier(qs_env, dcdr_env)
Calculate the dipole operator referenced at the Wannier centers in the MO basis.
subroutine, public current_operators(current_env, qs_env)
Calculate the first order hamiltonian applied to the ao and then apply them to the ground state orbit...
subroutine, public polar_operators(qs_env)
Calculate the dipole operator in the AO basis and its derivative wrt to MOs.
subroutine, public polar_operators_local(qs_env)
Calculate the Berry phase operator in the AO basis and then the derivative of the Berry phase operato...
subroutine, public issc_operators(issc_env, qs_env, iatom)
...
Polarizability calculation by dfpt Initialization of the polar_env, Perturbation Hamiltonian by appli...
subroutine, public polar_polar(qs_env)
...
subroutine, public polar_print(qs_env)
Print information related to the polarisability tensor.
subroutine, public polar_env_init(qs_env)
Initialize the polar environment.
subroutine, public polar_response(p_env, qs_env)
Calculate the polarisability tensor using response theory.
Type definitiona for linear response calculations.
subroutine, public get_polar_env(polar_env, do_raman, do_periodic, dberry_psi0, polar, psi1_dberry, run_stopped)
...
subroutine, public mfp_build_operator_gauge_independent(vcd_env, qs_env, alpha)
...
subroutine, public mfp_response(vcd_env, p_env, qs_env, alpha)
Get the dC/dB using the vcd_envop_dB.
subroutine, public mfp_build_operator_gauge_dependent(vcd_env, qs_env, alpha)
...
subroutine, public mfp_aat(vcd_env, qs_env)
...
Definition and initialisation of the mo data type.
Utility functions for the perturbation calculations.
subroutine, public p_env_psi0_changed(p_env, qs_env)
To be called after the value of psi0 has changed. Recalculates the quantities S_psi0 and m_epsilon.
subroutine, public p_env_create(p_env, qs_env, p1_option, p1_admm_option, orthogonal_orbitals, linres_control)
allocates and initializes the perturbation environment (no setup)
basis types for the calculation of the perturbation of density theory.
subroutine, public p_env_release(p_env)
relases the given p_env (see doc/ReferenceCounting.html)
methods of the rho structure (defined in qs_rho_types)
subroutine, public qs_rho_update_rho(rho_struct, qs_env, rho_xc_external, local_rho_set, task_list_external, task_list_external_soft, pw_env_external, para_env_external)
updates rho_r and rho_g to the rhorho_ao. if use_kinetic_energy_density also computes tau_r and tau_g...
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...
subroutine, public vcd_print(vcd_env, qs_env)
Print the APTs, AATs, and sum rules.
subroutine, public vcd_env_cleanup(qs_env, vcd_env)
Deallocate the vcd environment.
subroutine, public vcd_env_init(vcd_env, qs_env)
Initialize the vcd environment.
subroutine, public vcd_build_op_dv(vcd_env, qs_env)
What we are building here is the operator for the NVPT response: H0 * C1 - S0 * E0 * C1 = - op_dV lin...
subroutine, public vcd_response_dv(vcd_env, p_env, qs_env)
Get the dC/dV using the vcd_envop_dV.
subroutine, public aat_dv(vcd_env, qs_env)
Compute I_{alpha beta}^lambda = d/dV^lambda_beta <m_alpha> = d/dV^lambda_beta < r x.
subroutine, public apt_dv(vcd_env, qs_env)
Compute E_{alpha beta}^lambda = d/dV^lambda_beta <\mu_alpha> = d/dV^lambda_beta <.
subroutine, public prepare_per_atom_vcd(vcd_env, qs_env)
Initialize the matrices for the NVPT calculation.
type of a logger, at the moment it contains just a print level starting at which level it should be l...
wrapper to abstract the force evaluation of the various methods
General settings for linear response calculations.
Represent a qs system that is perturbed. Can calculate the linear operator and the rhs of the system ...
keeps the density in various representations, keeping track of which ones are valid.