39#include "./base/base_uses.f90"
49 REAL(kind=
dp) :: alpha = 0.0_dp
50 REAL(kind=
dp) :: mu = 0.0_dp
51 REAL(kind=
dp) :: t = 0.0_dp
52 REAL(kind=
dp) :: eps_hp = 0.0_dp
53 INTEGER :: natoms = 0, &
56 INTEGER,
DIMENSION(:),
POINTER :: atom_ids => null()
63 LOGICAL :: spherical = .false.
64 LOGICAL :: fullspace = .false.
65 INTEGER,
DIMENSION(2) :: distribution_layout = 0
66 INTEGER :: blocked = 0
67 END TYPE pw_grid_option
73 INTEGER,
DIMENSION(:),
ALLOCATABLE :: ref_mo_index
74 INTEGER :: ref_mo_spin = 1
75 INTEGER :: ref_nlumo = 0
76 LOGICAL :: sum_on_all_ref = .false.
77 INTEGER,
DIMENSION(:),
ALLOCATABLE :: td_mo_index
78 REAL(
dp),
DIMENSION(:),
ALLOCATABLE :: td_mo_occ
79 INTEGER :: td_mo_spin = 1
80 LOGICAL :: sum_on_all_td = .false.
81 CHARACTER(LEN=default_path_length) :: ref_mo_file_name =
""
82 LOGICAL :: propagate_ref = .false.
89 END TYPE proj_mo_p_type
95 LOGICAL :: converged = .false.
96 REAL(kind=
dp) :: eps_ener = 0.0_dp
97 INTEGER :: max_iter = 0
98 INTEGER :: mat_exp = 0
99 INTEGER :: propagator = 0
100 LOGICAL :: fixed_ions = .false.
103 INTEGER :: initial_wfn = 0
104 REAL(
dp) :: eps_exp = 0.0_dp
105 LOGICAL :: initial_step = .false.
106 LOGICAL :: hfx_redistribute = .false.
107 INTEGER :: aspc_order = 0
108 INTEGER :: sc_check_start = 0
109 LOGICAL :: apply_wfn_mix_init_restart = .false.
110 LOGICAL :: apply_delta_pulse = .false.
111 LOGICAL :: apply_delta_pulse_mag = .false.
112 LOGICAL :: periodic = .false.
113 LOGICAL :: linear_scaling = .false.
114 LOGICAL :: write_restart = .false.
115 INTEGER :: mcweeny_max_iter = 0
116 INTEGER :: acc_ref = 0
117 REAL(
dp) :: mcweeny_eps = 0.0_dp
118 INTEGER,
DIMENSION(3) :: delta_pulse_direction = 0
119 REAL(kind=
dp) :: delta_pulse_scale = 0.0_dp
120 LOGICAL :: velocity_gauge = .false.
121 REAL(kind=
dp),
DIMENSION(3) :: field = 0.0_dp
122 REAL(kind=
dp),
DIMENSION(3) :: vec_pot = 0.0_dp
123 LOGICAL :: nl_gauge_transform = .false.
124 LOGICAL :: is_proj_mo = .false.
125 TYPE(proj_mo_p_type),
DIMENSION(:), &
126 POINTER :: proj_mo_list => null()
128 LOGICAL :: save_local_moments = .false.
130 REAL(
dp),
DIMENSION(:),
POINTER :: moment_trace_user_ref_point => null()
131 REAL(
dp) :: ft_damping = -1.0_dp
132 REAL(
dp) :: ft_t0 = 0.0_dp
139 INTEGER,
DIMENSION(:, :),
POINTER :: print_pol_elements => null()
140 LOGICAL :: pade_requested = .false.
141 REAL(
dp) :: pade_e_min = 0.0_dp
142 REAL(
dp) :: pade_e_step = 0.02_dp
143 REAL(
dp) :: pade_e_max = 100.0_dp
144 REAL(
dp) :: pade_fit_e_min = 0.0_dp
145 REAL(
dp) :: pade_fit_e_max = 300.0_dp
152 LOGICAL :: self_consistent = .false.
153 LOGICAL :: orthogonal_basis = .false.
154 LOGICAL :: dispersion = .false.
156 INTEGER :: dispersion_type = 0
160 LOGICAL :: dftb3_diagonal = .false.
161 LOGICAL :: hb_sr_damp = .false.
162 REAL(kind=
dp) :: hb_sr_para = 0.0_dp
168 REAL(kind=
dp) :: eps_disp = 0.0_dp
169 REAL(kind=
dp) :: epscn = 0.0_dp
170 REAL(kind=
dp) :: exp_pre = 0.0_dp
171 REAL(kind=
dp) :: scaling = 0.0_dp
172 REAL(kind=
dp) :: rcdisp = 0.0_dp
173 REAL(kind=
dp),
DIMENSION(3) :: sd3 = 0.0_dp
174 REAL(kind=
dp),
DIMENSION(4) :: sd3bj = 0.0_dp
175 LOGICAL :: do_ewald = .false.
176 CHARACTER(LEN=default_path_length) :: sk_file_path =
""
177 CHARACTER(LEN=default_path_length) :: sk_file_list =
""
178 CHARACTER(LEN=default_string_length), &
179 DIMENSION(:, :),
POINTER :: sk_pair_list => null()
180 CHARACTER(LEN=default_path_length) :: uff_force_field =
""
181 CHARACTER(LEN=default_path_length) :: dispersion_parameter_file =
""
187 TYPE xtb_reference_cli_guess_type
188 LOGICAL :: enabled = .false.
189 LOGICAL :: efield_active = .false.
190 LOGICAL :: grad = .false.
193 REAL(kind=
dp),
DIMENSION(3) :: efield = 0.0_dp
194 REAL(kind=
dp) :: electronic_temperature_guess = 0.0_dp
195 CHARACTER(LEN=default_path_length) :: input_file =
""
196 CHARACTER(LEN=default_path_length) :: json_file =
""
197 CHARACTER(LEN=default_string_length) :: input_format =
"gen"
198 END TYPE xtb_reference_cli_guess_type
200 TYPE xtb_reference_cli_param_type
201 LOGICAL :: enabled = .false.
202 LOGICAL :: method_explicit = .false.
203 INTEGER :: method = 0
204 CHARACTER(LEN=default_path_length) :: input_file =
""
205 CHARACTER(LEN=default_path_length) :: output_file =
""
206 END TYPE xtb_reference_cli_param_type
208 TYPE xtb_reference_cli_fit_type
209 LOGICAL :: enabled = .false.
210 LOGICAL :: dry_run = .false.
211 CHARACTER(LEN=default_path_length) :: copy_file =
""
212 CHARACTER(LEN=default_path_length) :: input_file =
""
213 CHARACTER(LEN=default_path_length) :: param_file =
""
214 END TYPE xtb_reference_cli_fit_type
216 TYPE xtb_reference_cli_tagdiff_type
217 LOGICAL :: enabled = .false.
218 LOGICAL :: fit = .false.
219 CHARACTER(LEN=default_path_length) :: actual_file =
""
220 CHARACTER(LEN=default_path_length) :: reference_file =
""
221 END TYPE xtb_reference_cli_tagdiff_type
224 LOGICAL :: enabled = .false.
225 LOGICAL :: check_energy = .true.
226 LOGICAL :: check_forces = .true.
227 LOGICAL :: check_virial = .false.
228 LOGICAL :: keep_files = .false.
229 LOGICAL :: stop_on_error = .false.
230 LOGICAL :: efield_active = .false.
231 LOGICAL :: solvation_active = .false.
236 REAL(kind=
dp),
DIMENSION(3) :: efield = 0.0_dp
237 REAL(kind=
dp) :: electronic_temperature_guess = 0.0_dp
238 REAL(kind=
dp) :: error_limit = 1.0e-8_dp
239 CHARACTER(LEN=default_path_length) :: program_name =
"tblite"
240 CHARACTER(LEN=default_path_length) :: grad_file =
""
241 CHARACTER(LEN=default_path_length) :: json_file =
""
242 CHARACTER(LEN=default_path_length) :: post_processing =
""
243 CHARACTER(LEN=default_path_length) :: post_processing_output_file =
""
244 CHARACTER(LEN=default_path_length) :: restart_file =
""
245 CHARACTER(LEN=default_path_length) :: solvation_solvent =
""
246 CHARACTER(LEN=default_path_length) :: work_directory =
"."
247 CHARACTER(LEN=default_path_length) :: prefix =
"tblite-reference"
248 CHARACTER(LEN=default_string_length) :: input_format =
"gen"
249 TYPE(xtb_reference_cli_guess_type) :: guess_cli
250 TYPE(xtb_reference_cli_param_type) :: param_cli
251 TYPE(xtb_reference_cli_fit_type) :: fit_cli
252 TYPE(xtb_reference_cli_tagdiff_type) :: tagdiff_cli
257 INTEGER :: gfn_type = 1
259 LOGICAL :: do_ewald = .false.
260 LOGICAL :: do_tblite = .false.
261 LOGICAL :: tblite_mixer_damping_explicit = .false.
264 INTEGER :: h_sto_ng = 0
265 INTEGER :: tblite_method = 0
270 REAL(kind=
dp) :: tblite_accuracy = 1.0_dp
276 CHARACTER(LEN=default_path_length) :: tblite_param_file =
""
278 INTEGER :: vdw_type = -1
279 CHARACTER(LEN=default_path_length) :: parameter_file_path =
""
280 CHARACTER(LEN=default_path_length) :: parameter_file_name =
""
282 CHARACTER(LEN=default_path_length) :: dispersion_parameter_file =
""
283 REAL(kind=
dp) :: epscn = 0.0_dp
284 REAL(kind=
dp) :: rcdisp = 0.0_dp
285 REAL(kind=
dp) :: s6 = 0.0_dp, s8 = 0.0_dp
286 REAL(kind=
dp) :: a1 = 0.0_dp, a2 = 0.0_dp
288 REAL(kind=
dp) :: ks = 0.0_dp, kp = 0.0_dp, kd = 0.0_dp, ksp = 0.0_dp, k2sh = 0.0_dp
289 REAL(kind=
dp) :: kg = 0.0_dp, kf = 0.0_dp
290 REAL(kind=
dp) :: kcns = 0.0_dp, kcnp = 0.0_dp, kcnd = 0.0_dp
291 REAL(kind=
dp) :: ken = 0.0_dp
292 REAL(kind=
dp) :: ksen = 0.0_dp, kpen = 0.0_dp, kden = 0.0_dp
293 REAL(kind=
dp) :: ben = 0.0_dp
294 REAL(kind=
dp) :: kxr = 0.0_dp, kx2 = 0.0_dp
295 REAL(kind=
dp) :: enscale = 0.0_dp
297 LOGICAL :: xb_interaction = .false.
298 LOGICAL :: do_nonbonded = .false.
299 LOGICAL :: coulomb_interaction = .false.
300 LOGICAL :: coulomb_lr = .false.
301 LOGICAL :: tb3_interaction = .false.
302 LOGICAL :: check_atomic_charges = .false.
303 LOGICAL :: var_dipole = .false.
305 REAL(kind=
dp) :: xb_radius = 0.0_dp
306 REAL(kind=
dp) :: coulomb_sr_cut = 0.0_dp
307 REAL(kind=
dp) :: coulomb_sr_eps = 0.0_dp
309 CHARACTER(LEN=default_string_length), &
310 DIMENSION(:, :),
POINTER :: kab_param => null()
311 INTEGER,
DIMENSION(:, :),
POINTER :: kab_types => null()
312 INTEGER :: kab_nval = 0
313 REAL,
DIMENSION(:),
POINTER :: kab_vals => null()
316 REAL(kind=
dp) :: eps_pair = 0.0_dp
317 REAL(kind=
dp),
DIMENSION(:, :), &
318 POINTER :: rcpair => null()
321 REAL(kind=
dp) :: ksrb = 0.0_dp, esrb = 0.0_dp, gscal = 0.0_dp
322 REAL(kind=
dp) :: c1srb = 0.0_dp, c2srb = 0.0_dp, shift = 0.0_dp
325 INTEGER :: enshift_type = 1
334 LOGICAL :: orthogonal_basis = .false.
335 LOGICAL :: analytical_gradients = .false.
336 LOGICAL :: force_kdsod_ex = .false.
337 LOGICAL :: do_ewald = .false., do_ewald_r3 = .false., do_ewald_gks = .false.
338 INTEGER :: integral_screening = 0, periodic_type = 0
339 INTEGER :: max_multipole = 0
340 INTEGER :: ga_ncells = 0
341 REAL(kind=
dp) :: delta = 0.0_dp
343 LOGICAL :: dispersion = .false.
344 REAL(kind=
dp) :: rcdisp = 0.0_dp
345 REAL(kind=
dp) :: epscn = 0.0_dp
346 REAL(kind=
dp),
DIMENSION(3) :: sd3 = 0.0_dp
347 CHARACTER(LEN=default_path_length) :: dispersion_parameter_file =
""
349 REAL(kind=
dp) :: cutoff_lrc = 0.0_dp, taper_lrc = 0.0_dp, range_lrc = 0.0_dp
350 REAL(kind=
dp) :: cutoff_cou = 0.0_dp, taper_cou = 0.0_dp, range_cou = 0.0_dp
351 REAL(kind=
dp) :: cutoff_exc = 0.0_dp, taper_exc = 0.0_dp, range_exc = 0.0_dp
352 REAL(kind=
dp) :: taper_scr = 0.0_dp, range_scr = 0.0_dp
359 INTEGER :: basis_1c = 0
360 REAL(kind=
dp) :: eps_fit = 0.0_dp, &
362 eps_vrho0 = 0.0_dp, &
365 INTEGER :: ladd_rho0 = 0, &
369 LOGICAL :: accurate_xcint = .false.
370 REAL(kind=
dp) :: aweights = 0.0_dp
371 REAL(kind=
dp),
DIMENSION(:),
POINTER :: aw => null()
372 LOGICAL :: alpha0_hard_from_input = .false., &
373 force_paw = .false., &
374 non_paw_atoms = .false., &
375 nopaw_as_gpw = .false.
376 REAL(kind=
dp) :: alpha0_hard = 0.0_dp
377 REAL(kind=
dp) :: max_rad_local = 0.0_dp
384 REAL(kind=
dp) :: actual_time = 0.0_dp
385 REAL(kind=
dp),
DIMENSION(:),
POINTER :: polarisation => null()
386 INTEGER :: envelop_id = 0
387 REAL(kind=
dp),
DIMENSION(:),
POINTER :: envelop_r_vars => null()
388 INTEGER,
DIMENSION(:),
POINTER :: envelop_i_vars => null()
389 REAL(kind=
dp) :: strength = 0.0_dp
390 REAL(kind=
dp) :: phase_offset = 0.0_dp
391 REAL(kind=
dp) :: wavelength = 0.0_dp
392 REAL(kind=
dp),
DIMENSION(3) :: vec_pot_initial = 0.0_dp
397 END TYPE efield_p_type
402 TYPE period_efield_type
403 LOGICAL :: displacement_field = .false.
404 REAL(kind=
dp),
DIMENSION(3) :: polarisation = 0.0_dp
405 REAL(kind=
dp),
DIMENSION(3) :: d_filter = 0.0_dp
406 REAL(kind=
dp) :: strength = 0.0_dp
407 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:) :: strength_list
408 INTEGER :: start_frame = 0
409 INTEGER :: end_frame = -1
410 END TYPE period_efield_type
416 REAL(kind=
dp) :: strength = 0.0_dp
417 REAL(kind=
dp) ::
TARGET = 0.0_dp
418 INTEGER :: natoms = 0
419 INTEGER,
POINTER,
DIMENSION(:) :: atoms => null()
426 INTEGER :: ref_count = 0
427 REAL(kind=
dp) :: strength = 0.0_dp
428 REAL(kind=
dp) ::
TARGET = 0.0_dp
429 REAL(kind=
dp) :: ddapc_order_p = 0.0_dp
430 INTEGER :: functional_form = 0
431 INTEGER :: natoms = 0
432 INTEGER,
POINTER,
DIMENSION(:) :: atoms => null()
433 REAL(kind=
dp),
POINTER,
DIMENSION(:) :: coeff => null()
434 INTEGER :: density_type = 0
441 REAL(kind=
dp) :: strength = 0.0_dp
442 REAL(kind=
dp) ::
TARGET = 0.0_dp
443 REAL(kind=
dp) :: s2_order_p = 0.0_dp
444 INTEGER :: functional_form = 0
451 INTEGER,
DIMENSION(:),
ALLOCATABLE ::
list
452 END TYPE admm_block_type
455 REAL(kind=
dp) :: eps_filter = 0.0_dp
456 INTEGER :: admm_type = 0
457 INTEGER :: purification_method = 0
458 INTEGER :: method = 0
459 LOGICAL :: charge_constrain = .false.
460 INTEGER :: scaling_model = 0
461 INTEGER :: aux_exch_func = 0
462 LOGICAL :: aux_exch_func_param = .false.
463 REAL(kind=
dp),
DIMENSION(3) :: aux_x_param = 0.0_dp
464 TYPE(admm_block_type),
DIMENSION(:), &
465 ALLOCATABLE :: blocks
472 LOGICAL :: read_from_cube = .false.
473 LOGICAL :: maxwell_solver = .false.
474 LOGICAL :: static = .false.
475 REAL(kind=
dp) :: scaling_factor = 0.0_dp
482 LOGICAL :: log_test = .false.
483 INTEGER :: int_test = 0
484 REAL(kind=
dp) :: real_test = 0.0_dp
493 INTEGER :: method_id = 0
494 REAL(kind=
dp) :: eps_core_charge = 0.0_dp, &
495 eps_kg_orb = 0.0_dp, &
496 eps_pgf_orb = 0.0_dp, &
499 eps_rho_gspace = 0.0_dp, &
500 eps_rho_rspace = 0.0_dp, &
501 eps_filter_matrix = 0.0_dp, &
502 eps_gvg_rspace = 0.0_dp, &
503 progression_factor = 0.0_dp, &
504 relative_cutoff = 0.0_dp
505 LOGICAL :: do_almo_scf = .false.
506 LOGICAL :: do_ls_scf = .false.
507 LOGICAL :: do_kg = .false.
508 LOGICAL :: commensurate_mgrids = .false.
509 LOGICAL :: realspace_mgrids = .false.
510 LOGICAL :: gapw = .false., gapw_xc = .false., gpw = .false., pao = .false.
511 LOGICAL :: lrigpw = .false., rigpw = .false.
512 LOGICAL :: lri_optbas = .false.
513 LOGICAL :: ofgpw = .false.
514 LOGICAL :: dftb = .false.
515 LOGICAL :: xtb = .false.
516 LOGICAL :: semi_empirical = .false.
517 LOGICAL :: mulliken_restraint = .false.
518 LOGICAL :: ddapc_restraint = .false.
519 LOGICAL :: ddapc_restraint_is_spin = .false.
520 LOGICAL :: ddapc_explicit_potential = .false.
521 LOGICAL :: cdft = .false.
522 LOGICAL :: et_coupling_calc = .false.
523 LOGICAL :: s2_restraint = .false.
524 INTEGER :: do_ppl_method = 0
525 INTEGER :: wf_interpolation_method_nr = 0
526 INTEGER :: wf_extrapolation_order = 0
527 INTEGER :: periodicity = 0
528 REAL(kind=
dp) :: pairlist_radius = 0.0_dp
529 REAL(kind=
dp) :: cutoff = 0.0_dp
530 REAL(kind=
dp),
DIMENSION(:),
POINTER :: e_cutoff => null()
532 POINTER :: mulliken_restraint_control => null()
534 DIMENSION(:),
POINTER :: ddapc_restraint_control => null()
540 POINTER :: se_control => null()
542 TYPE(pw_grid_option) :: pw_grid_opt = pw_grid_option()
543 LOGICAL :: skip_load_balance_distributed = .false.
545 LOGICAL :: ref_embed_subsys = .false.
546 LOGICAL :: cluster_embed_subsys = .false.
547 LOGICAL :: high_level_embed_subsys = .false.
548 LOGICAL :: dfet_embedded = .false.
549 LOGICAL :: dmfet_embedded = .false.
556 LOGICAL :: sccs_activated = .false.
557 INTEGER :: derivative_method = 0, &
560 REAL(kind=
dp) :: alpha_solvent = 0.0_dp, &
562 beta_solvent = 0.0_dp, &
563 delta_rho = 0.0_dp, &
566 epsilon_solvent = 0.0_dp, &
567 gamma_solvent = 0.0_dp, &
580 LOGICAL :: do_ewald = .false.
581 LOGICAL :: do_exchange = .false.
582 REAL(kind=
dp) :: hfx_fraction = 0.0_dp
583 REAL(kind=
dp) :: eps_td_filter = 0.0_dp
584 REAL(kind=
dp) :: mn_alpha = 0.0_dp
585 REAL(kind=
dp) :: mn_beta = 0.0_dp
586 REAL(kind=
dp) :: coulomb_sr_cut = 0.0_dp
587 REAL(kind=
dp) :: coulomb_sr_eps = 0.0_dp
596 REAL(kind=
dp),
DIMENSION(:),
POINTER :: fermia => null()
597 REAL(kind=
dp),
DIMENSION(:, :),
POINTER :: fermib => null()
604 INTEGER :: surf_normal = 0
611 INTEGER :: surf_normal = 0
612 REAL(kind=
dp) :: dist_edge = 0.0_dp, &
622 LOGICAL :: enabled = .false.
624 INTEGER :: nstates = 0
626 INTEGER :: niters = 0
632 INTEGER :: nprocs = 0
634 INTEGER :: kernel = 0
636 INTEGER :: spinflip = 0
638 LOGICAL :: do_hfx = .false.
639 LOGICAL :: do_admm = .false.
641 LOGICAL :: do_hfxsr = .false.
642 LOGICAL :: hfxsr_re_int = .true.
643 INTEGER :: hfxsr_primbas = 0
644 LOGICAL :: do_hfxlr = .false.
645 REAL(kind=
dp) :: hfxlr_rcut = 0.0_dp, hfxlr_scale = 0.0_dp
646 LOGICAL :: do_exck = .false.
650 INTEGER :: oe_corr = 0
652 REAL(kind=
dp) :: ev_shift = 0.0_dp, eos_shift = 0.0_dp
654 INTEGER,
DIMENSION(2) :: nactive = -1
656 REAL(kind=
dp) :: conv = 0.0_dp
658 REAL(kind=
dp) :: min_excitation_amplitude = 0.0_dp
661 REAL(kind=
dp) :: orthogonal_eps = 0.0_dp
663 LOGICAL :: is_restart = .false.
665 LOGICAL :: rks_triplets = .false.
667 LOGICAL :: do_lrigpw = .false.
669 LOGICAL :: do_smearing = .false.
671 LOGICAL :: do_bse = .false.
672 LOGICAL :: do_bse_w_only = .false.
673 LOGICAL :: do_bse_gw_only = .false.
675 INTEGER :: auto_basis_p_lri_aux = 1
677 LOGICAL :: admm_symm = .false.
679 LOGICAL :: admm_xc_correction = .false.
681 LOGICAL :: do_exciton_descriptors = .false.
682 LOGICAL :: do_directional_exciton_descriptors = .false.
687 INTEGER :: dipole_form = 0
689 INTEGER :: dipole_reference = 0
691 REAL(kind=
dp),
DIMENSION(:),
POINTER :: dipole_ref_point => null()
694 LOGICAL :: do_soc = .false.
699 INTEGER :: mgrid_ngrids = 0
701 LOGICAL :: mgrid_commensurate_mgrids = .false.
705 LOGICAL :: mgrid_is_explicit = .false.
707 LOGICAL :: mgrid_realspace_mgrids = .false.
709 LOGICAL :: mgrid_skip_load_balance = .false.
711 REAL(kind=
dp) :: mgrid_cutoff = 0.0_dp
714 REAL(kind=
dp) :: mgrid_progression_factor = 0.0_dp
716 REAL(kind=
dp) :: mgrid_relative_cutoff = 0.0_dp
719 REAL(kind=
dp),
DIMENSION(:),
POINTER :: mgrid_e_cutoff => null()
729 LOGICAL :: enabled = .false.
730 INTEGER :: core_states = 0
731 INTEGER :: valence_states = 0
745 TYPE(period_efield_type),
POINTER :: period_efield => null()
757 TYPE(efield_p_type),
POINTER, &
758 DIMENSION(:) :: efield_fields => null()
760 DIMENSION(:) :: probe => null()
761 INTEGER :: nspins = 0, &
765 plus_u_method_id = 0, &
768 INTEGER :: sic_list_id = 0
769 INTEGER :: auto_basis_ri_aux = 1, &
770 auto_basis_aux_fit = 1, &
771 auto_basis_lri_aux = 1, &
772 auto_basis_p_lri_aux = 1, &
773 auto_basis_ri_hxc = 1, &
774 auto_basis_ri_xas = 1, &
775 auto_basis_ri_hfx = 1, &
777 REAL(kind=
dp) :: relax_multiplicity = 0.0_dp, &
778 sic_scaling_a = 0.0_dp, &
779 sic_scaling_b = 0.0_dp, &
780 pos_dir_surf_dip = 0.0_dp
781 LOGICAL :: do_xas_calculation = .false., &
782 do_xas_tdp_calculation = .false., &
783 drho_by_collocation = .false., &
784 use_kinetic_energy_density = .false., &
785 restricted = .false., &
790 apply_efield = .false., &
791 apply_efield_field = .false., &
792 apply_vector_potential = .false., &
793 apply_period_efield = .false., &
794 apply_external_potential = .false., &
795 eval_external_potential = .false., &
797 do_admm_dm = .false., &
798 do_admm_mo = .false., &
800 low_spin_roks = .false., &
801 apply_external_density = .false., &
802 read_external_density = .false., &
803 apply_external_vxc = .false., &
804 read_external_vxc = .false., &
805 correct_surf_dip = .false., &
806 surf_dip_correct_switch = .false., &
807 switch_surf_dip = .false., &
808 correct_el_density_dip = .false., &
810 apply_embed_pot = .false., &
811 apply_dmfet_pot = .false., &
819 CHARACTER(len=*),
PARAMETER,
PRIVATE :: modulen =
'cp_control_types'
868 SUBROUTINE mulliken_control_create(mulliken_restraint_control)
871 mulliken_restraint_control%strength = 0.1_dp
872 mulliken_restraint_control%target = 1.0_dp
873 mulliken_restraint_control%natoms = 0
874 NULLIFY (mulliken_restraint_control%atoms)
875 END SUBROUTINE mulliken_control_create
883 SUBROUTINE mulliken_control_release(mulliken_restraint_control)
886 IF (
ASSOCIATED(mulliken_restraint_control%atoms)) &
887 DEALLOCATE (mulliken_restraint_control%atoms)
888 mulliken_restraint_control%strength = 0.0_dp
889 mulliken_restraint_control%target = 0.0_dp
890 mulliken_restraint_control%natoms = 0
891 END SUBROUTINE mulliken_control_release
903 ddapc_restraint_control%strength = 0.1_dp
904 ddapc_restraint_control%ddapc_order_p = 0.0_dp
905 ddapc_restraint_control%functional_form = -1
906 ddapc_restraint_control%target = 1.0_dp
907 ddapc_restraint_control%natoms = 0
908 NULLIFY (ddapc_restraint_control%atoms)
909 NULLIFY (ddapc_restraint_control%coeff)
919 SUBROUTINE ddapc_control_release(ddapc_restraint_control)
922 IF (
ASSOCIATED(ddapc_restraint_control%atoms)) &
923 DEALLOCATE (ddapc_restraint_control%atoms)
924 IF (
ASSOCIATED(ddapc_restraint_control%coeff)) &
925 DEALLOCATE (ddapc_restraint_control%coeff)
926 ddapc_restraint_control%strength = 0.0_dp
927 ddapc_restraint_control%target = 0.0_dp
928 ddapc_restraint_control%natoms = 0
929 END SUBROUTINE ddapc_control_release
937 SUBROUTINE s2_control_create(s2_restraint_control)
940 s2_restraint_control%strength = 0.1_dp
941 s2_restraint_control%s2_order_p = 0.0_dp
942 s2_restraint_control%functional_form = -1
943 s2_restraint_control%target = 1.0_dp
944 END SUBROUTINE s2_control_create
952 SUBROUTINE s2_control_release(s2_restraint_control)
955 s2_restraint_control%strength = 0.0_dp
956 s2_restraint_control%target = 0.0_dp
957 END SUBROUTINE s2_control_release
969 NULLIFY (dft_control%xas_control)
970 NULLIFY (dft_control%qs_control)
971 NULLIFY (dft_control%tddfpt2_control)
972 NULLIFY (dft_control%rixs_control)
973 NULLIFY (dft_control%efield_fields)
974 NULLIFY (dft_control%period_efield)
975 NULLIFY (dft_control%admm_control)
976 NULLIFY (dft_control%expot_control)
977 NULLIFY (dft_control%maxwell_control)
978 NULLIFY (dft_control%smeagol_control)
979 NULLIFY (dft_control%rtp_control)
980 NULLIFY (dft_control%sccs_control)
981 NULLIFY (dft_control%probe)
982 NULLIFY (dft_control%paep_control)
983 NULLIFY (dft_control%pcc_control)
984 dft_control%do_sccs = .false.
985 dft_control%apply_embed_pot = .false.
986 dft_control%apply_dmfet_pot = .false.
987 dft_control%hairy_probes = .false.
988 dft_control%do_pcc = .false.
989 dft_control%do_paep = .false.
990 CALL qs_control_create(dft_control%qs_control)
991 CALL tddfpt2_control_create(dft_control%tddfpt2_control)
1008 CALL qs_control_release(dft_control%qs_control)
1009 CALL tddfpt2_control_release(dft_control%tddfpt2_control)
1011 IF (
ASSOCIATED(dft_control%xas_control))
THEN
1013 DEALLOCATE (dft_control%xas_control)
1016 CALL expot_control_release(dft_control%expot_control)
1017 CALL maxwell_control_release(dft_control%maxwell_control)
1019 CALL efield_fields_release(dft_control%efield_fields)
1020 IF (
ASSOCIATED(dft_control%probe))
THEN
1021 DO i = 1,
SIZE(dft_control%probe)
1022 DEALLOCATE (dft_control%probe(i)%atom_ids)
1024 DEALLOCATE (dft_control%probe)
1026 IF (
ASSOCIATED(dft_control%sccs_control))
DEALLOCATE (dft_control%sccs_control)
1027 IF (
ASSOCIATED(dft_control%period_efield))
THEN
1028 DEALLOCATE (dft_control%period_efield)
1030 IF (
ASSOCIATED(dft_control%rtp_control))
THEN
1031 CALL proj_mo_list_release(dft_control%rtp_control%proj_mo_list)
1032 DEALLOCATE (dft_control%rtp_control)
1034 IF (
ASSOCIATED(dft_control%pcc_control))
DEALLOCATE (dft_control%pcc_control)
1035 IF (
ASSOCIATED(dft_control%paep_control))
DEALLOCATE (dft_control%paep_control)
1043 SUBROUTINE qs_control_create(qs_control)
1046 cpassert(.NOT.
ASSOCIATED(qs_control))
1047 ALLOCATE (qs_control)
1049 NULLIFY (qs_control%e_cutoff)
1050 NULLIFY (qs_control%gapw_control)
1051 NULLIFY (qs_control%mulliken_restraint_control)
1052 NULLIFY (qs_control%ddapc_restraint_control)
1053 NULLIFY (qs_control%s2_restraint_control)
1054 NULLIFY (qs_control%se_control)
1055 NULLIFY (qs_control%dftb_control)
1056 NULLIFY (qs_control%xtb_control)
1057 NULLIFY (qs_control%cdft_control)
1058 NULLIFY (qs_control%ddapc_restraint_control)
1060 ALLOCATE (qs_control%mulliken_restraint_control)
1061 CALL mulliken_control_create(qs_control%mulliken_restraint_control)
1062 ALLOCATE (qs_control%s2_restraint_control)
1063 CALL s2_control_create(qs_control%s2_restraint_control)
1064 ALLOCATE (qs_control%gapw_control)
1065 CALL se_control_create(qs_control%se_control)
1066 CALL dftb_control_create(qs_control%dftb_control)
1067 CALL xtb_control_create(qs_control%xtb_control)
1068 ALLOCATE (qs_control%cdft_control)
1070 END SUBROUTINE qs_control_create
1076 SUBROUTINE qs_control_release(qs_control)
1081 IF (
ASSOCIATED(qs_control))
THEN
1082 CALL mulliken_control_release(qs_control%mulliken_restraint_control)
1083 DEALLOCATE (qs_control%mulliken_restraint_control)
1084 CALL s2_control_release(qs_control%s2_restraint_control)
1085 DEALLOCATE (qs_control%s2_restraint_control)
1086 CALL se_control_release(qs_control%se_control)
1087 CALL dftb_control_release(qs_control%dftb_control)
1088 CALL xtb_control_release(qs_control%xtb_control)
1089 IF (
ASSOCIATED(qs_control%cdft_control))
THEN
1091 DEALLOCATE (qs_control%cdft_control)
1094 IF (
ASSOCIATED(qs_control%e_cutoff))
THEN
1095 DEALLOCATE (qs_control%e_cutoff)
1097 IF (
ASSOCIATED(qs_control%gapw_control))
THEN
1098 IF (
ASSOCIATED(qs_control%gapw_control%aw))
THEN
1099 DEALLOCATE (qs_control%gapw_control%aw)
1101 DEALLOCATE (qs_control%gapw_control)
1103 IF (
ASSOCIATED(qs_control%ddapc_restraint_control))
THEN
1104 DO i = 1,
SIZE(qs_control%ddapc_restraint_control)
1105 CALL ddapc_control_release(qs_control%ddapc_restraint_control(i))
1107 DEALLOCATE (qs_control%ddapc_restraint_control)
1109 DEALLOCATE (qs_control)
1111 END SUBROUTINE qs_control_release
1119 SUBROUTINE tddfpt2_control_create(tddfpt_control)
1122 CHARACTER(len=*),
PARAMETER :: routinen =
'tddfpt2_control_create'
1126 cpassert(.NOT.
ASSOCIATED(tddfpt_control))
1127 CALL timeset(routinen, handle)
1129 ALLOCATE (tddfpt_control)
1130 tddfpt_control%do_soc = .false.
1132 CALL timestop(handle)
1133 END SUBROUTINE tddfpt2_control_create
1141 SUBROUTINE tddfpt2_control_release(tddfpt_control)
1144 CHARACTER(len=*),
PARAMETER :: routinen =
'tddfpt2_control_release'
1148 CALL timeset(routinen, handle)
1150 IF (
ASSOCIATED(tddfpt_control))
THEN
1151 DEALLOCATE (tddfpt_control)
1154 CALL timestop(handle)
1155 END SUBROUTINE tddfpt2_control_release
1164 cpassert(.NOT.
ASSOCIATED(rixs_control))
1165 ALLOCATE (rixs_control)
1167 NULLIFY (rixs_control%tddfpt2_control)
1168 CALL tddfpt2_control_create(rixs_control%tddfpt2_control)
1169 NULLIFY (rixs_control%xas_tdp_control)
1181 IF (
ASSOCIATED(rixs_control))
THEN
1182 CALL tddfpt2_control_release(rixs_control%tddfpt2_control)
1185 DEALLOCATE (rixs_control)
1194 SUBROUTINE proj_mo_list_release(proj_mo_list)
1195 TYPE(proj_mo_p_type),
DIMENSION(:),
POINTER :: proj_mo_list
1197 INTEGER :: i, mo_ref_nbr
1199 IF (
ASSOCIATED(proj_mo_list))
THEN
1200 DO i = 1,
SIZE(proj_mo_list)
1201 IF (
ASSOCIATED(proj_mo_list(i)%proj_mo))
THEN
1202 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%ref_mo_index)) &
1203 DEALLOCATE (proj_mo_list(i)%proj_mo%ref_mo_index)
1204 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%mo_ref))
THEN
1205 DO mo_ref_nbr = 1,
SIZE(proj_mo_list(i)%proj_mo%mo_ref)
1206 CALL cp_fm_release(proj_mo_list(i)%proj_mo%mo_ref(mo_ref_nbr))
1208 DEALLOCATE (proj_mo_list(i)%proj_mo%mo_ref)
1210 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%td_mo_index)) &
1211 DEALLOCATE (proj_mo_list(i)%proj_mo%td_mo_index)
1212 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%td_mo_occ)) &
1213 DEALLOCATE (proj_mo_list(i)%proj_mo%td_mo_occ)
1214 DEALLOCATE (proj_mo_list(i)%proj_mo)
1217 DEALLOCATE (proj_mo_list)
1219 END SUBROUTINE proj_mo_list_release
1225 SUBROUTINE efield_fields_release(efield_fields)
1226 TYPE(efield_p_type),
DIMENSION(:),
POINTER :: efield_fields
1230 IF (
ASSOCIATED(efield_fields))
THEN
1231 DO i = 1,
SIZE(efield_fields)
1232 IF (
ASSOCIATED(efield_fields(i)%efield))
THEN
1233 IF (
ASSOCIATED(efield_fields(i)%efield%envelop_r_vars))
THEN
1234 DEALLOCATE (efield_fields(i)%efield%envelop_r_vars)
1236 IF (
ASSOCIATED(efield_fields(i)%efield%envelop_i_vars))
THEN
1237 DEALLOCATE (efield_fields(i)%efield%envelop_i_vars)
1239 IF (
ASSOCIATED(efield_fields(i)%efield%polarisation)) &
1240 DEALLOCATE (efield_fields(i)%efield%polarisation)
1241 DEALLOCATE (efield_fields(i)%efield)
1244 DEALLOCATE (efield_fields)
1246 END SUBROUTINE efield_fields_release
1252 SUBROUTINE dftb_control_create(dftb_control)
1255 cpassert(.NOT.
ASSOCIATED(dftb_control))
1256 ALLOCATE (dftb_control)
1258 NULLIFY (dftb_control%sk_pair_list)
1259 END SUBROUTINE dftb_control_create
1265 SUBROUTINE dftb_control_release(dftb_control)
1268 IF (
ASSOCIATED(dftb_control))
THEN
1269 IF (
ASSOCIATED(dftb_control%sk_pair_list))
THEN
1270 DEALLOCATE (dftb_control%sk_pair_list)
1272 DEALLOCATE (dftb_control)
1274 END SUBROUTINE dftb_control_release
1280 SUBROUTINE xtb_control_create(xtb_control)
1283 cpassert(.NOT.
ASSOCIATED(xtb_control))
1284 ALLOCATE (xtb_control)
1286 NULLIFY (xtb_control%kab_param)
1287 NULLIFY (xtb_control%kab_vals)
1288 NULLIFY (xtb_control%kab_types)
1289 NULLIFY (xtb_control%nonbonded)
1290 NULLIFY (xtb_control%rcpair)
1292 END SUBROUTINE xtb_control_create
1298 SUBROUTINE xtb_control_release(xtb_control)
1301 IF (
ASSOCIATED(xtb_control))
THEN
1302 IF (
ASSOCIATED(xtb_control%kab_param))
THEN
1303 DEALLOCATE (xtb_control%kab_param)
1305 IF (
ASSOCIATED(xtb_control%kab_vals))
THEN
1306 DEALLOCATE (xtb_control%kab_vals)
1308 IF (
ASSOCIATED(xtb_control%kab_types))
THEN
1309 DEALLOCATE (xtb_control%kab_types)
1311 IF (
ASSOCIATED(xtb_control%rcpair))
THEN
1312 DEALLOCATE (xtb_control%rcpair)
1314 IF (
ASSOCIATED(xtb_control%nonbonded))
THEN
1317 DEALLOCATE (xtb_control)
1319 END SUBROUTINE xtb_control_release
1325 SUBROUTINE se_control_create(se_control)
1328 cpassert(.NOT.
ASSOCIATED(se_control))
1329 ALLOCATE (se_control)
1330 END SUBROUTINE se_control_create
1336 SUBROUTINE se_control_release(se_control)
1339 IF (
ASSOCIATED(se_control))
THEN
1340 DEALLOCATE (se_control)
1342 END SUBROUTINE se_control_release
1351 cpassert(.NOT.
ASSOCIATED(admm_control))
1352 ALLOCATE (admm_control)
1363 IF (
ASSOCIATED(admm_control))
THEN
1364 DEALLOCATE (admm_control)
1375 cpassert(.NOT.
ASSOCIATED(expot_control))
1376 ALLOCATE (expot_control)
1377 expot_control%read_from_cube = .false.
1378 expot_control%maxwell_solver = .false.
1379 expot_control%static = .true.
1380 expot_control%scaling_factor = 1.0_dp
1388 SUBROUTINE expot_control_release(expot_control)
1391 IF (
ASSOCIATED(expot_control))
THEN
1392 DEALLOCATE (expot_control)
1395 END SUBROUTINE expot_control_release
1404 cpassert(.NOT.
ASSOCIATED(maxwell_control))
1405 ALLOCATE (maxwell_control)
1413 SUBROUTINE maxwell_control_release(maxwell_control)
1416 IF (
ASSOCIATED(maxwell_control))
THEN
1417 DEALLOCATE (maxwell_control)
1420 END SUBROUTINE maxwell_control_release
Defines control structures, which contain the parameters and the settings for the DFT-based calculati...
subroutine, public rixs_control_release(rixs_control)
Releases the rixs_control_type.
subroutine, public admm_control_release(admm_control)
...
subroutine, public dft_control_create(dft_control)
allocates and perform a very basic initialization
subroutine, public expot_control_create(expot_control)
...
subroutine, public maxwell_control_create(maxwell_control)
...
subroutine, public ddapc_control_create(ddapc_restraint_control)
create the ddapc_restraint_type
subroutine, public admm_control_create(admm_control)
...
subroutine, public dft_control_release(dft_control)
...
subroutine, public rixs_control_create(rixs_control)
Creates and initializes the rixs_control_type.
represent a full matrix distributed on many processors
Add the DFT+U contribution to the Hamiltonian matrix.
Defines the basic variable types.
integer, parameter, public dp
integer, parameter, public default_string_length
integer, parameter, public default_path_length
An array-based list which grows on demand. When the internal array is full, a new array of twice the ...
subroutine, public pair_potential_p_release(potparm)
Release Data-structure that constains potential parameters.
Defines CDFT control structures.
subroutine, public cdft_control_release(cdft_control)
release the cdft_control_type
subroutine, public cdft_control_create(cdft_control)
create the cdft_control_type
Input control types for NEGF/SMEAGOL transport calculations.
subroutine, public smeagol_control_release(smeagol_control)
release SMEAGOL control object
subroutine, public smeagol_control_create(smeagol_control)
allocate control options for SMEAGOL calculation
CP2K-side tblite-compatible SCC Broyden mixer.
Defines control structures, which contain the parameters and the settings for the calculations.
subroutine, public xas_control_release(xas_control)
...
Define XAS TDP control type and associated create, release, etc subroutines, as well as XAS TDP envir...
subroutine, public xas_tdp_control_release(xas_tdp_control)
Releases the xas_tdp_control_type.
subroutine, public xas_tdp_control_create(xas_tdp_control)
Creates and initializes the xas_tdp_control_type.
SMEAGOL-related input parameters.
A type that holds controlling information for a xas calculation.
Type containing control information for TDP XAS calculations.