32#include "./base/base_uses.f90"
42 REAL(kind=
dp) :: alpha = 0.0_dp
43 REAL(kind=
dp) :: mu = 0.0_dp
44 REAL(kind=
dp) :: t = 0.0_dp
45 REAL(kind=
dp) :: eps_hp = 0.0_dp
46 INTEGER :: natoms = 0, &
49 INTEGER,
DIMENSION(:),
POINTER :: atom_ids => null()
56 LOGICAL :: spherical = .false.
57 LOGICAL :: fullspace = .false.
58 INTEGER,
DIMENSION(2) :: distribution_layout = 0
59 INTEGER :: blocked = 0
60 END TYPE pw_grid_option
66 INTEGER,
DIMENSION(:),
ALLOCATABLE :: ref_mo_index
67 INTEGER :: ref_mo_spin = 1
68 INTEGER :: ref_nlumo = 0
69 LOGICAL :: sum_on_all_ref = .false.
70 INTEGER,
DIMENSION(:),
ALLOCATABLE :: td_mo_index
71 REAL(
dp),
DIMENSION(:),
ALLOCATABLE :: td_mo_occ
72 INTEGER :: td_mo_spin = 1
73 LOGICAL :: sum_on_all_td = .false.
74 CHARACTER(LEN=default_path_length) :: ref_mo_file_name =
""
75 LOGICAL :: propagate_ref = .false.
82 END TYPE proj_mo_p_type
88 LOGICAL :: converged = .false.
89 REAL(kind=
dp) :: eps_ener = 0.0_dp
90 INTEGER :: max_iter = 0
91 INTEGER :: mat_exp = 0
92 INTEGER :: propagator = 0
93 LOGICAL :: fixed_ions = .false.
96 INTEGER :: initial_wfn = 0
97 REAL(
dp) :: eps_exp = 0.0_dp
98 LOGICAL :: initial_step = .false.
99 LOGICAL :: hfx_redistribute = .false.
100 INTEGER :: aspc_order = 0
101 INTEGER :: sc_check_start = 0
102 LOGICAL :: apply_wfn_mix_init_restart = .false.
103 LOGICAL :: apply_delta_pulse = .false.
104 LOGICAL :: apply_delta_pulse_mag = .false.
105 LOGICAL :: periodic = .false.
106 LOGICAL :: linear_scaling = .false.
107 LOGICAL :: write_restart = .false.
108 INTEGER :: mcweeny_max_iter = 0
109 INTEGER :: acc_ref = 0
110 REAL(
dp) :: mcweeny_eps = 0.0_dp
111 INTEGER,
DIMENSION(3) :: delta_pulse_direction = 0
112 REAL(kind=
dp) :: delta_pulse_scale = 0.0_dp
113 LOGICAL :: velocity_gauge = .false.
114 REAL(kind=
dp),
DIMENSION(3) :: field = 0.0_dp
115 REAL(kind=
dp),
DIMENSION(3) :: vec_pot = 0.0_dp
116 LOGICAL :: nl_gauge_transform = .false.
117 LOGICAL :: is_proj_mo = .false.
118 TYPE(proj_mo_p_type),
DIMENSION(:), &
119 POINTER :: proj_mo_list => null()
126 LOGICAL :: self_consistent = .false.
127 LOGICAL :: orthogonal_basis = .false.
128 LOGICAL :: dispersion = .false.
129 INTEGER :: dispersion_type = 0
130 LOGICAL :: dftb3_diagonal = .false.
131 LOGICAL :: hb_sr_damp = .false.
132 REAL(kind=
dp) :: hb_sr_para = 0.0_dp
133 REAL(kind=
dp) :: eps_disp = 0.0_dp
134 REAL(kind=
dp) :: epscn = 0.0_dp
135 REAL(kind=
dp) :: exp_pre = 0.0_dp
136 REAL(kind=
dp) :: scaling = 0.0_dp
137 REAL(kind=
dp) :: rcdisp = 0.0_dp
138 REAL(kind=
dp),
DIMENSION(3) :: sd3 = 0.0_dp
139 REAL(kind=
dp),
DIMENSION(4) :: sd3bj = 0.0_dp
140 LOGICAL :: do_ewald = .false.
141 CHARACTER(LEN=default_path_length) :: sk_file_path =
""
142 CHARACTER(LEN=default_path_length) :: sk_file_list =
""
143 CHARACTER(LEN=default_string_length), &
144 DIMENSION(:, :),
POINTER :: sk_pair_list => null()
145 CHARACTER(LEN=default_path_length) :: uff_force_field =
""
146 CHARACTER(LEN=default_path_length) :: dispersion_parameter_file =
""
154 INTEGER :: gfn_type = 1
156 LOGICAL :: do_ewald = .false.
157 LOGICAL :: do_tblite = .false.
160 INTEGER :: h_sto_ng = 0
161 INTEGER :: tblite_method = 0
163 INTEGER :: vdw_type = -1
164 CHARACTER(LEN=default_path_length) :: parameter_file_path =
""
165 CHARACTER(LEN=default_path_length) :: parameter_file_name =
""
167 CHARACTER(LEN=default_path_length) :: dispersion_parameter_file =
""
168 REAL(kind=
dp) :: epscn = 0.0_dp
169 REAL(kind=
dp) :: rcdisp = 0.0_dp
170 REAL(kind=
dp) :: s6 = 0.0_dp, s8 = 0.0_dp
171 REAL(kind=
dp) :: a1 = 0.0_dp, a2 = 0.0_dp
173 REAL(kind=
dp) :: ks = 0.0_dp, kp = 0.0_dp, kd = 0.0_dp, ksp = 0.0_dp, k2sh = 0.0_dp
174 REAL(kind=
dp) :: kg = 0.0_dp, kf = 0.0_dp
175 REAL(kind=
dp) :: kcns = 0.0_dp, kcnp = 0.0_dp, kcnd = 0.0_dp
176 REAL(kind=
dp) :: ken = 0.0_dp
177 REAL(kind=
dp) :: ksen = 0.0_dp, kpen = 0.0_dp, kden = 0.0_dp
178 REAL(kind=
dp) :: ben = 0.0_dp
179 REAL(kind=
dp) :: kxr = 0.0_dp, kx2 = 0.0_dp
180 REAL(kind=
dp) :: enscale = 0.0_dp
182 LOGICAL :: xb_interaction = .false.
183 LOGICAL :: do_nonbonded = .false.
184 LOGICAL :: coulomb_interaction = .false.
185 LOGICAL :: coulomb_lr = .false.
186 LOGICAL :: tb3_interaction = .false.
187 LOGICAL :: check_atomic_charges = .false.
188 LOGICAL :: var_dipole = .false.
190 REAL(kind=
dp) :: xb_radius = 0.0_dp
191 REAL(kind=
dp) :: coulomb_sr_cut = 0.0_dp
192 REAL(kind=
dp) :: coulomb_sr_eps = 0.0_dp
194 CHARACTER(LEN=default_string_length), &
195 DIMENSION(:, :),
POINTER :: kab_param => null()
196 INTEGER,
DIMENSION(:, :),
POINTER :: kab_types => null()
197 INTEGER :: kab_nval = 0
198 REAL,
DIMENSION(:),
POINTER :: kab_vals => null()
201 REAL(kind=
dp) :: eps_pair = 0.0_dp
202 REAL(kind=
dp),
DIMENSION(:, :), &
203 POINTER :: rcpair => null()
206 REAL(kind=
dp) :: ksrb = 0.0_dp, esrb = 0.0_dp, gscal = 0.0_dp
207 REAL(kind=
dp) :: c1srb = 0.0_dp, c2srb = 0.0_dp, shift = 0.0_dp
210 INTEGER :: enshift_type = 1
218 LOGICAL :: orthogonal_basis = .false.
219 LOGICAL :: analytical_gradients = .false.
220 LOGICAL :: force_kdsod_ex = .false.
221 LOGICAL :: do_ewald = .false., do_ewald_r3 = .false., do_ewald_gks = .false.
222 INTEGER :: integral_screening = 0, periodic_type = 0
223 INTEGER :: max_multipole = 0
224 INTEGER :: ga_ncells = 0
225 REAL(kind=
dp) :: delta = 0.0_dp
227 LOGICAL :: dispersion = .false.
228 REAL(kind=
dp) :: rcdisp = 0.0_dp
229 REAL(kind=
dp) :: epscn = 0.0_dp
230 REAL(kind=
dp),
DIMENSION(3) :: sd3 = 0.0_dp
231 CHARACTER(LEN=default_path_length) :: dispersion_parameter_file =
""
233 REAL(kind=
dp) :: cutoff_lrc = 0.0_dp, taper_lrc = 0.0_dp, range_lrc = 0.0_dp
234 REAL(kind=
dp) :: cutoff_cou = 0.0_dp, taper_cou = 0.0_dp, range_cou = 0.0_dp
235 REAL(kind=
dp) :: cutoff_exc = 0.0_dp, taper_exc = 0.0_dp, range_exc = 0.0_dp
236 REAL(kind=
dp) :: taper_scr = 0.0_dp, range_scr = 0.0_dp
243 INTEGER :: basis_1c = 0
244 REAL(kind=
dp) :: eps_fit = 0.0_dp, &
246 eps_vrho0 = 0.0_dp, &
249 INTEGER :: ladd_rho0 = 0, &
253 LOGICAL :: lrho1_eq_lrho0 = .false.
254 LOGICAL :: alpha0_hard_from_input = .false., &
255 force_paw = .false., &
256 non_paw_atoms = .false., &
257 nopaw_as_gpw = .false.
258 REAL(kind=
dp) :: alpha0_hard = 0.0_dp
259 REAL(kind=
dp) :: max_rad_local = 0.0_dp
266 REAL(kind=
dp) :: actual_time = 0.0_dp
267 REAL(kind=
dp),
DIMENSION(:),
POINTER :: polarisation => null()
268 INTEGER :: envelop_id = 0
269 REAL(kind=
dp),
DIMENSION(:),
POINTER :: envelop_r_vars => null()
270 INTEGER,
DIMENSION(:),
POINTER :: envelop_i_vars => null()
271 REAL(kind=
dp) :: strength = 0.0_dp
272 REAL(kind=
dp) :: phase_offset = 0.0_dp
273 REAL(kind=
dp) :: wavelength = 0.0_dp
274 REAL(kind=
dp),
DIMENSION(3) :: vec_pot_initial = 0.0_dp
279 END TYPE efield_p_type
284 TYPE period_efield_type
285 LOGICAL :: displacement_field = .false.
286 REAL(kind=
dp),
DIMENSION(3) :: polarisation = 0.0_dp
287 REAL(kind=
dp),
DIMENSION(3) :: d_filter = 0.0_dp
288 REAL(kind=
dp) :: strength = 0.0_dp
289 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:) :: strength_list
290 INTEGER :: start_frame = 0
291 INTEGER :: end_frame = -1
292 END TYPE period_efield_type
298 REAL(kind=
dp) :: strength = 0.0_dp
299 REAL(kind=
dp) ::
TARGET = 0.0_dp
300 INTEGER :: natoms = 0
301 INTEGER,
POINTER,
DIMENSION(:) :: atoms => null()
308 INTEGER :: ref_count = 0
309 REAL(kind=
dp) :: strength = 0.0_dp
310 REAL(kind=
dp) ::
TARGET = 0.0_dp
311 REAL(kind=
dp) :: ddapc_order_p = 0.0_dp
312 INTEGER :: functional_form = 0
313 INTEGER :: natoms = 0
314 INTEGER,
POINTER,
DIMENSION(:) :: atoms => null()
315 REAL(kind=
dp),
POINTER,
DIMENSION(:) :: coeff => null()
316 INTEGER :: density_type = 0
323 REAL(kind=
dp) :: strength = 0.0_dp
324 REAL(kind=
dp) ::
TARGET = 0.0_dp
325 REAL(kind=
dp) :: s2_order_p = 0.0_dp
326 INTEGER :: functional_form = 0
333 INTEGER,
DIMENSION(:),
ALLOCATABLE ::
list
334 END TYPE admm_block_type
337 REAL(kind=
dp) :: eps_filter = 0.0_dp
338 INTEGER :: admm_type = 0
339 INTEGER :: purification_method = 0
340 INTEGER :: method = 0
341 LOGICAL :: charge_constrain = .false.
342 INTEGER :: scaling_model = 0
343 INTEGER :: aux_exch_func = 0
344 LOGICAL :: aux_exch_func_param = .false.
345 REAL(kind=
dp),
DIMENSION(3) :: aux_x_param = 0.0_dp
346 TYPE(admm_block_type),
DIMENSION(:), &
347 ALLOCATABLE :: blocks
354 LOGICAL :: read_from_cube = .false.
355 LOGICAL :: maxwell_solver = .false.
356 LOGICAL :: static = .false.
357 REAL(kind=
dp) :: scaling_factor = 0.0_dp
364 LOGICAL :: log_test = .false.
365 INTEGER :: int_test = 0
366 REAL(kind=
dp) :: real_test = 0.0_dp
375 INTEGER :: method_id = 0
376 REAL(kind=
dp) :: eps_core_charge = 0.0_dp, &
377 eps_kg_orb = 0.0_dp, &
378 eps_pgf_orb = 0.0_dp, &
381 eps_rho_gspace = 0.0_dp, &
382 eps_rho_rspace = 0.0_dp, &
383 eps_filter_matrix = 0.0_dp, &
384 eps_gvg_rspace = 0.0_dp, &
385 progression_factor = 0.0_dp, &
386 relative_cutoff = 0.0_dp
387 LOGICAL :: do_almo_scf = .false.
388 LOGICAL :: do_ls_scf = .false.
389 LOGICAL :: do_kg = .false.
390 LOGICAL :: commensurate_mgrids = .false.
391 LOGICAL :: realspace_mgrids = .false.
392 LOGICAL :: gapw = .false., gapw_xc = .false., gpw = .false., pao = .false.
393 LOGICAL :: lrigpw = .false., rigpw = .false.
394 LOGICAL :: lri_optbas = .false.
395 LOGICAL :: ofgpw = .false.
396 LOGICAL :: dftb = .false.
397 LOGICAL :: xtb = .false.
398 LOGICAL :: semi_empirical = .false.
399 LOGICAL :: mulliken_restraint = .false.
400 LOGICAL :: ddapc_restraint = .false.
401 LOGICAL :: ddapc_restraint_is_spin = .false.
402 LOGICAL :: ddapc_explicit_potential = .false.
403 LOGICAL :: cdft = .false.
404 LOGICAL :: et_coupling_calc = .false.
405 LOGICAL :: s2_restraint = .false.
406 INTEGER :: do_ppl_method = 0
407 INTEGER :: wf_interpolation_method_nr = 0
408 INTEGER :: wf_extrapolation_order = 0
409 INTEGER :: periodicity = 0
410 REAL(kind=
dp) :: pairlist_radius = 0.0_dp
411 REAL(kind=
dp) :: cutoff = 0.0_dp
412 REAL(kind=
dp),
DIMENSION(:),
POINTER :: e_cutoff => null()
414 POINTER :: mulliken_restraint_control => null()
416 DIMENSION(:),
POINTER :: ddapc_restraint_control => null()
422 POINTER :: se_control => null()
424 TYPE(pw_grid_option) :: pw_grid_opt = pw_grid_option()
425 LOGICAL :: skip_load_balance_distributed = .false.
427 LOGICAL :: ref_embed_subsys = .false.
428 LOGICAL :: cluster_embed_subsys = .false.
429 LOGICAL :: high_level_embed_subsys = .false.
430 LOGICAL :: dfet_embedded = .false.
431 LOGICAL :: dmfet_embedded = .false.
438 LOGICAL :: sccs_activated = .false.
439 INTEGER :: derivative_method = 0, &
442 REAL(kind=
dp) :: alpha_solvent = 0.0_dp, &
444 beta_solvent = 0.0_dp, &
445 delta_rho = 0.0_dp, &
448 epsilon_solvent = 0.0_dp, &
449 gamma_solvent = 0.0_dp, &
462 LOGICAL :: do_ewald = .false.
463 LOGICAL :: do_exchange = .false.
464 REAL(kind=
dp) :: hfx_fraction = 0.0_dp
465 REAL(kind=
dp) :: eps_td_filter = 0.0_dp
466 REAL(kind=
dp) :: mn_alpha = 0.0_dp
467 REAL(kind=
dp) :: mn_beta = 0.0_dp
468 REAL(kind=
dp) :: coulomb_sr_cut = 0.0_dp
469 REAL(kind=
dp) :: coulomb_sr_eps = 0.0_dp
478 REAL(kind=
dp),
DIMENSION(:),
POINTER :: fermia => null()
479 REAL(kind=
dp),
DIMENSION(:, :),
POINTER :: fermib => null()
487 LOGICAL :: enabled = .false.
489 INTEGER :: nstates = 0
491 INTEGER :: niters = 0
497 INTEGER :: nprocs = 0
499 INTEGER :: kernel = 0
501 LOGICAL :: do_hfx = .false.
502 LOGICAL :: do_admm = .false.
504 LOGICAL :: do_hfxsr = .false.
505 LOGICAL :: hfxsr_re_int = .true.
506 INTEGER :: hfxsr_primbas = 0
507 LOGICAL :: do_hfxlr = .false.
508 REAL(kind=
dp) :: hfxlr_rcut = 0.0_dp, hfxlr_scale = 0.0_dp
509 LOGICAL :: do_exck = .false.
513 INTEGER :: oe_corr = 0
515 REAL(kind=
dp) :: ev_shift = 0.0_dp, eos_shift = 0.0_dp
517 REAL(kind=
dp) :: conv = 0.0_dp
519 REAL(kind=
dp) :: min_excitation_amplitude = 0.0_dp
522 REAL(kind=
dp) :: orthogonal_eps = 0.0_dp
524 LOGICAL :: is_restart = .false.
526 LOGICAL :: rks_triplets = .false.
528 LOGICAL :: do_lrigpw = .false.
530 LOGICAL :: do_smearing = .false.
532 INTEGER :: auto_basis_p_lri_aux = 1
534 LOGICAL :: admm_symm = .false.
536 LOGICAL :: admm_xc_correction = .false.
538 LOGICAL :: do_exciton_descriptors = .false.
539 LOGICAL :: do_directional_exciton_descriptors = .false.
544 INTEGER :: dipole_form = 0
546 INTEGER :: dipole_reference = 0
548 REAL(kind=
dp),
DIMENSION(:),
POINTER :: dipole_ref_point => null()
551 LOGICAL :: do_soc = .false.
556 INTEGER :: mgrid_ngrids = 0
558 LOGICAL :: mgrid_commensurate_mgrids = .false.
562 LOGICAL :: mgrid_is_explicit = .false.
564 LOGICAL :: mgrid_realspace_mgrids = .false.
566 LOGICAL :: mgrid_skip_load_balance = .false.
568 REAL(kind=
dp) :: mgrid_cutoff = 0.0_dp
571 REAL(kind=
dp) :: mgrid_progression_factor = 0.0_dp
573 REAL(kind=
dp) :: mgrid_relative_cutoff = 0.0_dp
576 REAL(kind=
dp),
DIMENSION(:),
POINTER :: mgrid_e_cutoff => null()
588 TYPE(period_efield_type),
POINTER :: period_efield => null()
597 TYPE(efield_p_type),
POINTER, &
598 DIMENSION(:) :: efield_fields => null()
600 DIMENSION(:) :: probe => null()
601 INTEGER :: nspins = 0, &
605 plus_u_method_id = 0, &
608 INTEGER :: sic_list_id = 0
609 INTEGER :: auto_basis_ri_aux = 1, &
610 auto_basis_aux_fit = 1, &
611 auto_basis_lri_aux = 1, &
612 auto_basis_p_lri_aux = 1, &
613 auto_basis_ri_hxc = 1, &
614 auto_basis_ri_xas = 1, &
615 auto_basis_ri_hfx = 1
616 REAL(kind=
dp) :: relax_multiplicity = 0.0_dp, &
617 sic_scaling_a = 0.0_dp, &
618 sic_scaling_b = 0.0_dp, &
619 pos_dir_surf_dip = 0.0_dp
620 LOGICAL :: do_xas_calculation = .false., &
621 do_xas_tdp_calculation = .false., &
622 drho_by_collocation = .false., &
623 use_kinetic_energy_density = .false., &
624 restricted = .false., &
629 apply_efield = .false., &
630 apply_efield_field = .false., &
631 apply_vector_potential = .false., &
632 apply_period_efield = .false., &
633 apply_external_potential = .false., &
634 eval_external_potential = .false., &
636 do_admm_dm = .false., &
637 do_admm_mo = .false., &
639 low_spin_roks = .false., &
640 apply_external_density = .false., &
641 read_external_density = .false., &
642 apply_external_vxc = .false., &
643 read_external_vxc = .false., &
644 correct_surf_dip = .false., &
645 surf_dip_correct_switch = .false., &
646 switch_surf_dip = .false., &
647 correct_el_density_dip = .false., &
649 apply_embed_pot = .false., &
650 apply_dmfet_pot = .false., &
654 CHARACTER(len=*),
PARAMETER,
PRIVATE :: modulen =
'cp_control_types'
697 SUBROUTINE mulliken_control_create(mulliken_restraint_control)
700 mulliken_restraint_control%strength = 0.1_dp
701 mulliken_restraint_control%target = 1.0_dp
702 mulliken_restraint_control%natoms = 0
703 NULLIFY (mulliken_restraint_control%atoms)
704 END SUBROUTINE mulliken_control_create
712 SUBROUTINE mulliken_control_release(mulliken_restraint_control)
715 IF (
ASSOCIATED(mulliken_restraint_control%atoms)) &
716 DEALLOCATE (mulliken_restraint_control%atoms)
717 mulliken_restraint_control%strength = 0.0_dp
718 mulliken_restraint_control%target = 0.0_dp
719 mulliken_restraint_control%natoms = 0
720 END SUBROUTINE mulliken_control_release
732 ddapc_restraint_control%strength = 0.1_dp
733 ddapc_restraint_control%ddapc_order_p = 0.0_dp
734 ddapc_restraint_control%functional_form = -1
735 ddapc_restraint_control%target = 1.0_dp
736 ddapc_restraint_control%natoms = 0
737 NULLIFY (ddapc_restraint_control%atoms)
738 NULLIFY (ddapc_restraint_control%coeff)
748 SUBROUTINE ddapc_control_release(ddapc_restraint_control)
751 IF (
ASSOCIATED(ddapc_restraint_control%atoms)) &
752 DEALLOCATE (ddapc_restraint_control%atoms)
753 IF (
ASSOCIATED(ddapc_restraint_control%coeff)) &
754 DEALLOCATE (ddapc_restraint_control%coeff)
755 ddapc_restraint_control%strength = 0.0_dp
756 ddapc_restraint_control%target = 0.0_dp
757 ddapc_restraint_control%natoms = 0
758 END SUBROUTINE ddapc_control_release
766 SUBROUTINE s2_control_create(s2_restraint_control)
769 s2_restraint_control%strength = 0.1_dp
770 s2_restraint_control%s2_order_p = 0.0_dp
771 s2_restraint_control%functional_form = -1
772 s2_restraint_control%target = 1.0_dp
773 END SUBROUTINE s2_control_create
781 SUBROUTINE s2_control_release(s2_restraint_control)
784 s2_restraint_control%strength = 0.0_dp
785 s2_restraint_control%target = 0.0_dp
786 END SUBROUTINE s2_control_release
798 NULLIFY (dft_control%xas_control)
799 NULLIFY (dft_control%qs_control)
800 NULLIFY (dft_control%tddfpt2_control)
801 NULLIFY (dft_control%efield_fields)
802 NULLIFY (dft_control%period_efield)
803 NULLIFY (dft_control%admm_control)
804 NULLIFY (dft_control%expot_control)
805 NULLIFY (dft_control%maxwell_control)
806 NULLIFY (dft_control%smeagol_control)
807 NULLIFY (dft_control%rtp_control)
808 NULLIFY (dft_control%sccs_control)
809 NULLIFY (dft_control%probe)
810 dft_control%do_sccs = .false.
811 dft_control%apply_embed_pot = .false.
812 dft_control%apply_dmfet_pot = .false.
813 dft_control%hairy_probes = .false.
814 CALL qs_control_create(dft_control%qs_control)
815 CALL tddfpt2_control_create(dft_control%tddfpt2_control)
831 CALL qs_control_release(dft_control%qs_control)
832 CALL tddfpt2_control_release(dft_control%tddfpt2_control)
833 IF (
ASSOCIATED(dft_control%xas_control))
THEN
835 DEALLOCATE (dft_control%xas_control)
838 CALL expot_control_release(dft_control%expot_control)
839 CALL maxwell_control_release(dft_control%maxwell_control)
841 CALL efield_fields_release(dft_control%efield_fields)
842 IF (
ASSOCIATED(dft_control%probe))
THEN
843 DO i = 1,
SIZE(dft_control%probe)
844 DEALLOCATE (dft_control%probe(i)%atom_ids)
846 DEALLOCATE (dft_control%probe)
848 IF (
ASSOCIATED(dft_control%sccs_control))
DEALLOCATE (dft_control%sccs_control)
849 IF (
ASSOCIATED(dft_control%period_efield))
THEN
850 DEALLOCATE (dft_control%period_efield)
852 IF (
ASSOCIATED(dft_control%rtp_control))
THEN
853 CALL proj_mo_list_release(dft_control%rtp_control%proj_mo_list)
854 DEALLOCATE (dft_control%rtp_control)
863 SUBROUTINE qs_control_create(qs_control)
866 cpassert(.NOT.
ASSOCIATED(qs_control))
867 ALLOCATE (qs_control)
869 NULLIFY (qs_control%e_cutoff)
870 NULLIFY (qs_control%gapw_control)
871 NULLIFY (qs_control%mulliken_restraint_control)
872 NULLIFY (qs_control%ddapc_restraint_control)
873 NULLIFY (qs_control%s2_restraint_control)
874 NULLIFY (qs_control%se_control)
875 NULLIFY (qs_control%dftb_control)
876 NULLIFY (qs_control%xtb_control)
877 NULLIFY (qs_control%cdft_control)
878 NULLIFY (qs_control%ddapc_restraint_control)
880 ALLOCATE (qs_control%mulliken_restraint_control)
881 CALL mulliken_control_create(qs_control%mulliken_restraint_control)
882 ALLOCATE (qs_control%s2_restraint_control)
883 CALL s2_control_create(qs_control%s2_restraint_control)
884 ALLOCATE (qs_control%gapw_control)
885 CALL se_control_create(qs_control%se_control)
886 CALL dftb_control_create(qs_control%dftb_control)
887 CALL xtb_control_create(qs_control%xtb_control)
888 ALLOCATE (qs_control%cdft_control)
890 END SUBROUTINE qs_control_create
896 SUBROUTINE qs_control_release(qs_control)
901 IF (
ASSOCIATED(qs_control))
THEN
902 CALL mulliken_control_release(qs_control%mulliken_restraint_control)
903 DEALLOCATE (qs_control%mulliken_restraint_control)
904 CALL s2_control_release(qs_control%s2_restraint_control)
905 DEALLOCATE (qs_control%s2_restraint_control)
906 CALL se_control_release(qs_control%se_control)
907 CALL dftb_control_release(qs_control%dftb_control)
908 CALL xtb_control_release(qs_control%xtb_control)
909 IF (
ASSOCIATED(qs_control%cdft_control))
THEN
911 DEALLOCATE (qs_control%cdft_control)
914 IF (
ASSOCIATED(qs_control%e_cutoff))
THEN
915 DEALLOCATE (qs_control%e_cutoff)
917 IF (
ASSOCIATED(qs_control%gapw_control))
THEN
918 DEALLOCATE (qs_control%gapw_control)
920 IF (
ASSOCIATED(qs_control%ddapc_restraint_control))
THEN
921 DO i = 1,
SIZE(qs_control%ddapc_restraint_control)
922 CALL ddapc_control_release(qs_control%ddapc_restraint_control(i))
924 DEALLOCATE (qs_control%ddapc_restraint_control)
926 DEALLOCATE (qs_control)
928 END SUBROUTINE qs_control_release
936 SUBROUTINE tddfpt2_control_create(tddfpt_control)
939 CHARACTER(len=*),
PARAMETER :: routinen =
'tddfpt2_control_create'
943 cpassert(.NOT.
ASSOCIATED(tddfpt_control))
944 CALL timeset(routinen, handle)
946 ALLOCATE (tddfpt_control)
947 tddfpt_control%do_soc = .false.
949 CALL timestop(handle)
950 END SUBROUTINE tddfpt2_control_create
958 SUBROUTINE tddfpt2_control_release(tddfpt_control)
961 CHARACTER(len=*),
PARAMETER :: routinen =
'tddfpt2_control_release'
965 CALL timeset(routinen, handle)
967 IF (
ASSOCIATED(tddfpt_control))
THEN
968 DEALLOCATE (tddfpt_control)
971 CALL timestop(handle)
972 END SUBROUTINE tddfpt2_control_release
978 SUBROUTINE proj_mo_list_release(proj_mo_list)
979 TYPE(proj_mo_p_type),
DIMENSION(:),
POINTER :: proj_mo_list
981 INTEGER :: i, mo_ref_nbr
983 IF (
ASSOCIATED(proj_mo_list))
THEN
984 DO i = 1,
SIZE(proj_mo_list)
985 IF (
ASSOCIATED(proj_mo_list(i)%proj_mo))
THEN
986 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%ref_mo_index)) &
987 DEALLOCATE (proj_mo_list(i)%proj_mo%ref_mo_index)
988 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%mo_ref))
THEN
989 DO mo_ref_nbr = 1,
SIZE(proj_mo_list(i)%proj_mo%mo_ref)
990 CALL cp_fm_release(proj_mo_list(i)%proj_mo%mo_ref(mo_ref_nbr))
992 DEALLOCATE (proj_mo_list(i)%proj_mo%mo_ref)
994 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%td_mo_index)) &
995 DEALLOCATE (proj_mo_list(i)%proj_mo%td_mo_index)
996 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%td_mo_occ)) &
997 DEALLOCATE (proj_mo_list(i)%proj_mo%td_mo_occ)
998 DEALLOCATE (proj_mo_list(i)%proj_mo)
1001 DEALLOCATE (proj_mo_list)
1003 END SUBROUTINE proj_mo_list_release
1009 SUBROUTINE efield_fields_release(efield_fields)
1010 TYPE(efield_p_type),
DIMENSION(:),
POINTER :: efield_fields
1014 IF (
ASSOCIATED(efield_fields))
THEN
1015 DO i = 1,
SIZE(efield_fields)
1016 IF (
ASSOCIATED(efield_fields(i)%efield))
THEN
1017 IF (
ASSOCIATED(efield_fields(i)%efield%envelop_r_vars))
THEN
1018 DEALLOCATE (efield_fields(i)%efield%envelop_r_vars)
1020 IF (
ASSOCIATED(efield_fields(i)%efield%envelop_i_vars))
THEN
1021 DEALLOCATE (efield_fields(i)%efield%envelop_i_vars)
1023 IF (
ASSOCIATED(efield_fields(i)%efield%polarisation)) &
1024 DEALLOCATE (efield_fields(i)%efield%polarisation)
1025 DEALLOCATE (efield_fields(i)%efield)
1028 DEALLOCATE (efield_fields)
1030 END SUBROUTINE efield_fields_release
1036 SUBROUTINE dftb_control_create(dftb_control)
1039 cpassert(.NOT.
ASSOCIATED(dftb_control))
1040 ALLOCATE (dftb_control)
1042 NULLIFY (dftb_control%sk_pair_list)
1043 END SUBROUTINE dftb_control_create
1049 SUBROUTINE dftb_control_release(dftb_control)
1052 IF (
ASSOCIATED(dftb_control))
THEN
1053 IF (
ASSOCIATED(dftb_control%sk_pair_list))
THEN
1054 DEALLOCATE (dftb_control%sk_pair_list)
1056 DEALLOCATE (dftb_control)
1058 END SUBROUTINE dftb_control_release
1064 SUBROUTINE xtb_control_create(xtb_control)
1067 cpassert(.NOT.
ASSOCIATED(xtb_control))
1068 ALLOCATE (xtb_control)
1070 NULLIFY (xtb_control%kab_param)
1071 NULLIFY (xtb_control%kab_vals)
1072 NULLIFY (xtb_control%kab_types)
1073 NULLIFY (xtb_control%nonbonded)
1074 NULLIFY (xtb_control%rcpair)
1076 END SUBROUTINE xtb_control_create
1082 SUBROUTINE xtb_control_release(xtb_control)
1085 IF (
ASSOCIATED(xtb_control))
THEN
1086 IF (
ASSOCIATED(xtb_control%kab_param))
THEN
1087 DEALLOCATE (xtb_control%kab_param)
1089 IF (
ASSOCIATED(xtb_control%kab_vals))
THEN
1090 DEALLOCATE (xtb_control%kab_vals)
1092 IF (
ASSOCIATED(xtb_control%kab_types))
THEN
1093 DEALLOCATE (xtb_control%kab_types)
1095 IF (
ASSOCIATED(xtb_control%rcpair))
THEN
1096 DEALLOCATE (xtb_control%rcpair)
1098 IF (
ASSOCIATED(xtb_control%nonbonded))
THEN
1101 DEALLOCATE (xtb_control)
1103 END SUBROUTINE xtb_control_release
1109 SUBROUTINE se_control_create(se_control)
1112 cpassert(.NOT.
ASSOCIATED(se_control))
1113 ALLOCATE (se_control)
1114 END SUBROUTINE se_control_create
1120 SUBROUTINE se_control_release(se_control)
1123 IF (
ASSOCIATED(se_control))
THEN
1124 DEALLOCATE (se_control)
1126 END SUBROUTINE se_control_release
1135 cpassert(.NOT.
ASSOCIATED(admm_control))
1136 ALLOCATE (admm_control)
1147 IF (
ASSOCIATED(admm_control))
THEN
1148 DEALLOCATE (admm_control)
1159 cpassert(.NOT.
ASSOCIATED(expot_control))
1160 ALLOCATE (expot_control)
1161 expot_control%read_from_cube = .false.
1162 expot_control%maxwell_solver = .false.
1163 expot_control%static = .true.
1164 expot_control%scaling_factor = 1.0_dp
1172 SUBROUTINE expot_control_release(expot_control)
1175 IF (
ASSOCIATED(expot_control))
THEN
1176 DEALLOCATE (expot_control)
1179 END SUBROUTINE expot_control_release
1188 cpassert(.NOT.
ASSOCIATED(maxwell_control))
1189 ALLOCATE (maxwell_control)
1197 SUBROUTINE maxwell_control_release(maxwell_control)
1200 IF (
ASSOCIATED(maxwell_control))
THEN
1201 DEALLOCATE (maxwell_control)
1204 END SUBROUTINE maxwell_control_release
Defines control structures, which contain the parameters and the settings for the DFT-based calculati...
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)
...
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
Defines control structures, which contain the parameters and the settings for the calculations.
subroutine, public xas_control_release(xas_control)
...
SMEAGOL-related input parameters.
A type that holds controlling information for a xas calculation.