36#include "./base/base_uses.f90"
46 REAL(kind=
dp) :: alpha = 0.0_dp
47 REAL(kind=
dp) :: mu = 0.0_dp
48 REAL(kind=
dp) :: t = 0.0_dp
49 REAL(kind=
dp) :: eps_hp = 0.0_dp
50 INTEGER :: natoms = 0, &
53 INTEGER,
DIMENSION(:),
POINTER :: atom_ids => null()
60 LOGICAL :: spherical = .false.
61 LOGICAL :: fullspace = .false.
62 INTEGER,
DIMENSION(2) :: distribution_layout = 0
63 INTEGER :: blocked = 0
64 END TYPE pw_grid_option
70 INTEGER,
DIMENSION(:),
ALLOCATABLE :: ref_mo_index
71 INTEGER :: ref_mo_spin = 1
72 INTEGER :: ref_nlumo = 0
73 LOGICAL :: sum_on_all_ref = .false.
74 INTEGER,
DIMENSION(:),
ALLOCATABLE :: td_mo_index
75 REAL(
dp),
DIMENSION(:),
ALLOCATABLE :: td_mo_occ
76 INTEGER :: td_mo_spin = 1
77 LOGICAL :: sum_on_all_td = .false.
78 CHARACTER(LEN=default_path_length) :: ref_mo_file_name =
""
79 LOGICAL :: propagate_ref = .false.
86 END TYPE proj_mo_p_type
92 LOGICAL :: converged = .false.
93 REAL(kind=
dp) :: eps_ener = 0.0_dp
94 INTEGER :: max_iter = 0
95 INTEGER :: mat_exp = 0
96 INTEGER :: propagator = 0
97 LOGICAL :: fixed_ions = .false.
100 INTEGER :: initial_wfn = 0
101 REAL(
dp) :: eps_exp = 0.0_dp
102 LOGICAL :: initial_step = .false.
103 LOGICAL :: hfx_redistribute = .false.
104 INTEGER :: aspc_order = 0
105 INTEGER :: sc_check_start = 0
106 LOGICAL :: apply_wfn_mix_init_restart = .false.
107 LOGICAL :: apply_delta_pulse = .false.
108 LOGICAL :: apply_delta_pulse_mag = .false.
109 LOGICAL :: periodic = .false.
110 LOGICAL :: linear_scaling = .false.
111 LOGICAL :: write_restart = .false.
112 INTEGER :: mcweeny_max_iter = 0
113 INTEGER :: acc_ref = 0
114 REAL(
dp) :: mcweeny_eps = 0.0_dp
115 INTEGER,
DIMENSION(3) :: delta_pulse_direction = 0
116 REAL(kind=
dp) :: delta_pulse_scale = 0.0_dp
117 LOGICAL :: velocity_gauge = .false.
118 REAL(kind=
dp),
DIMENSION(3) :: field = 0.0_dp
119 REAL(kind=
dp),
DIMENSION(3) :: vec_pot = 0.0_dp
120 LOGICAL :: nl_gauge_transform = .false.
121 LOGICAL :: is_proj_mo = .false.
122 TYPE(proj_mo_p_type),
DIMENSION(:), &
123 POINTER :: proj_mo_list => null()
125 LOGICAL :: save_local_moments = .false.
127 REAL(
dp),
DIMENSION(:),
POINTER :: moment_trace_user_ref_point => null()
128 REAL(
dp) :: ft_damping = -1.0_dp
129 REAL(
dp) :: ft_t0 = 0.0_dp
136 INTEGER,
DIMENSION(:, :),
POINTER :: print_pol_elements => null()
137 LOGICAL :: pade_requested = .false.
138 REAL(
dp) :: pade_e_min = 0.0_dp
139 REAL(
dp) :: pade_e_step = 0.02_dp
140 REAL(
dp) :: pade_e_max = 100.0_dp
141 REAL(
dp) :: pade_fit_e_min = 0.0_dp
142 REAL(
dp) :: pade_fit_e_max = 300.0_dp
149 LOGICAL :: self_consistent = .false.
150 LOGICAL :: orthogonal_basis = .false.
151 LOGICAL :: dispersion = .false.
152 INTEGER :: dispersion_type = 0
153 LOGICAL :: dftb3_diagonal = .false.
154 LOGICAL :: hb_sr_damp = .false.
155 REAL(kind=
dp) :: hb_sr_para = 0.0_dp
156 REAL(kind=
dp) :: eps_disp = 0.0_dp
157 REAL(kind=
dp) :: epscn = 0.0_dp
158 REAL(kind=
dp) :: exp_pre = 0.0_dp
159 REAL(kind=
dp) :: scaling = 0.0_dp
160 REAL(kind=
dp) :: rcdisp = 0.0_dp
161 REAL(kind=
dp),
DIMENSION(3) :: sd3 = 0.0_dp
162 REAL(kind=
dp),
DIMENSION(4) :: sd3bj = 0.0_dp
163 LOGICAL :: do_ewald = .false.
164 CHARACTER(LEN=default_path_length) :: sk_file_path =
""
165 CHARACTER(LEN=default_path_length) :: sk_file_list =
""
166 CHARACTER(LEN=default_string_length), &
167 DIMENSION(:, :),
POINTER :: sk_pair_list => null()
168 CHARACTER(LEN=default_path_length) :: uff_force_field =
""
169 CHARACTER(LEN=default_path_length) :: dispersion_parameter_file =
""
177 INTEGER :: gfn_type = 1
179 LOGICAL :: do_ewald = .false.
180 LOGICAL :: do_tblite = .false.
183 INTEGER :: h_sto_ng = 0
184 INTEGER :: tblite_method = 0
186 INTEGER :: vdw_type = -1
187 CHARACTER(LEN=default_path_length) :: parameter_file_path =
""
188 CHARACTER(LEN=default_path_length) :: parameter_file_name =
""
190 CHARACTER(LEN=default_path_length) :: dispersion_parameter_file =
""
191 REAL(kind=
dp) :: epscn = 0.0_dp
192 REAL(kind=
dp) :: rcdisp = 0.0_dp
193 REAL(kind=
dp) :: s6 = 0.0_dp, s8 = 0.0_dp
194 REAL(kind=
dp) :: a1 = 0.0_dp, a2 = 0.0_dp
196 REAL(kind=
dp) :: ks = 0.0_dp, kp = 0.0_dp, kd = 0.0_dp, ksp = 0.0_dp, k2sh = 0.0_dp
197 REAL(kind=
dp) :: kg = 0.0_dp, kf = 0.0_dp
198 REAL(kind=
dp) :: kcns = 0.0_dp, kcnp = 0.0_dp, kcnd = 0.0_dp
199 REAL(kind=
dp) :: ken = 0.0_dp
200 REAL(kind=
dp) :: ksen = 0.0_dp, kpen = 0.0_dp, kden = 0.0_dp
201 REAL(kind=
dp) :: ben = 0.0_dp
202 REAL(kind=
dp) :: kxr = 0.0_dp, kx2 = 0.0_dp
203 REAL(kind=
dp) :: enscale = 0.0_dp
205 LOGICAL :: xb_interaction = .false.
206 LOGICAL :: do_nonbonded = .false.
207 LOGICAL :: coulomb_interaction = .false.
208 LOGICAL :: coulomb_lr = .false.
209 LOGICAL :: tb3_interaction = .false.
210 LOGICAL :: check_atomic_charges = .false.
211 LOGICAL :: var_dipole = .false.
213 REAL(kind=
dp) :: xb_radius = 0.0_dp
214 REAL(kind=
dp) :: coulomb_sr_cut = 0.0_dp
215 REAL(kind=
dp) :: coulomb_sr_eps = 0.0_dp
217 CHARACTER(LEN=default_string_length), &
218 DIMENSION(:, :),
POINTER :: kab_param => null()
219 INTEGER,
DIMENSION(:, :),
POINTER :: kab_types => null()
220 INTEGER :: kab_nval = 0
221 REAL,
DIMENSION(:),
POINTER :: kab_vals => null()
224 REAL(kind=
dp) :: eps_pair = 0.0_dp
225 REAL(kind=
dp),
DIMENSION(:, :), &
226 POINTER :: rcpair => null()
229 REAL(kind=
dp) :: ksrb = 0.0_dp, esrb = 0.0_dp, gscal = 0.0_dp
230 REAL(kind=
dp) :: c1srb = 0.0_dp, c2srb = 0.0_dp, shift = 0.0_dp
233 INTEGER :: enshift_type = 1
241 LOGICAL :: orthogonal_basis = .false.
242 LOGICAL :: analytical_gradients = .false.
243 LOGICAL :: force_kdsod_ex = .false.
244 LOGICAL :: do_ewald = .false., do_ewald_r3 = .false., do_ewald_gks = .false.
245 INTEGER :: integral_screening = 0, periodic_type = 0
246 INTEGER :: max_multipole = 0
247 INTEGER :: ga_ncells = 0
248 REAL(kind=
dp) :: delta = 0.0_dp
250 LOGICAL :: dispersion = .false.
251 REAL(kind=
dp) :: rcdisp = 0.0_dp
252 REAL(kind=
dp) :: epscn = 0.0_dp
253 REAL(kind=
dp),
DIMENSION(3) :: sd3 = 0.0_dp
254 CHARACTER(LEN=default_path_length) :: dispersion_parameter_file =
""
256 REAL(kind=
dp) :: cutoff_lrc = 0.0_dp, taper_lrc = 0.0_dp, range_lrc = 0.0_dp
257 REAL(kind=
dp) :: cutoff_cou = 0.0_dp, taper_cou = 0.0_dp, range_cou = 0.0_dp
258 REAL(kind=
dp) :: cutoff_exc = 0.0_dp, taper_exc = 0.0_dp, range_exc = 0.0_dp
259 REAL(kind=
dp) :: taper_scr = 0.0_dp, range_scr = 0.0_dp
266 INTEGER :: basis_1c = 0
267 REAL(kind=
dp) :: eps_fit = 0.0_dp, &
269 eps_vrho0 = 0.0_dp, &
272 INTEGER :: ladd_rho0 = 0, &
276 LOGICAL :: accurate_xcint = .false.
277 REAL(kind=
dp) :: aweights = 0.0_dp
278 REAL(kind=
dp),
DIMENSION(:),
POINTER :: aw => null()
279 LOGICAL :: alpha0_hard_from_input = .false., &
280 force_paw = .false., &
281 non_paw_atoms = .false., &
282 nopaw_as_gpw = .false.
283 REAL(kind=
dp) :: alpha0_hard = 0.0_dp
284 REAL(kind=
dp) :: max_rad_local = 0.0_dp
291 REAL(kind=
dp) :: actual_time = 0.0_dp
292 REAL(kind=
dp),
DIMENSION(:),
POINTER :: polarisation => null()
293 INTEGER :: envelop_id = 0
294 REAL(kind=
dp),
DIMENSION(:),
POINTER :: envelop_r_vars => null()
295 INTEGER,
DIMENSION(:),
POINTER :: envelop_i_vars => null()
296 REAL(kind=
dp) :: strength = 0.0_dp
297 REAL(kind=
dp) :: phase_offset = 0.0_dp
298 REAL(kind=
dp) :: wavelength = 0.0_dp
299 REAL(kind=
dp),
DIMENSION(3) :: vec_pot_initial = 0.0_dp
304 END TYPE efield_p_type
309 TYPE period_efield_type
310 LOGICAL :: displacement_field = .false.
311 REAL(kind=
dp),
DIMENSION(3) :: polarisation = 0.0_dp
312 REAL(kind=
dp),
DIMENSION(3) :: d_filter = 0.0_dp
313 REAL(kind=
dp) :: strength = 0.0_dp
314 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:) :: strength_list
315 INTEGER :: start_frame = 0
316 INTEGER :: end_frame = -1
317 END TYPE period_efield_type
323 REAL(kind=
dp) :: strength = 0.0_dp
324 REAL(kind=
dp) ::
TARGET = 0.0_dp
325 INTEGER :: natoms = 0
326 INTEGER,
POINTER,
DIMENSION(:) :: atoms => null()
333 INTEGER :: ref_count = 0
334 REAL(kind=
dp) :: strength = 0.0_dp
335 REAL(kind=
dp) ::
TARGET = 0.0_dp
336 REAL(kind=
dp) :: ddapc_order_p = 0.0_dp
337 INTEGER :: functional_form = 0
338 INTEGER :: natoms = 0
339 INTEGER,
POINTER,
DIMENSION(:) :: atoms => null()
340 REAL(kind=
dp),
POINTER,
DIMENSION(:) :: coeff => null()
341 INTEGER :: density_type = 0
348 REAL(kind=
dp) :: strength = 0.0_dp
349 REAL(kind=
dp) ::
TARGET = 0.0_dp
350 REAL(kind=
dp) :: s2_order_p = 0.0_dp
351 INTEGER :: functional_form = 0
358 INTEGER,
DIMENSION(:),
ALLOCATABLE ::
list
359 END TYPE admm_block_type
362 REAL(kind=
dp) :: eps_filter = 0.0_dp
363 INTEGER :: admm_type = 0
364 INTEGER :: purification_method = 0
365 INTEGER :: method = 0
366 LOGICAL :: charge_constrain = .false.
367 INTEGER :: scaling_model = 0
368 INTEGER :: aux_exch_func = 0
369 LOGICAL :: aux_exch_func_param = .false.
370 REAL(kind=
dp),
DIMENSION(3) :: aux_x_param = 0.0_dp
371 TYPE(admm_block_type),
DIMENSION(:), &
372 ALLOCATABLE :: blocks
379 LOGICAL :: read_from_cube = .false.
380 LOGICAL :: maxwell_solver = .false.
381 LOGICAL :: static = .false.
382 REAL(kind=
dp) :: scaling_factor = 0.0_dp
389 LOGICAL :: log_test = .false.
390 INTEGER :: int_test = 0
391 REAL(kind=
dp) :: real_test = 0.0_dp
400 INTEGER :: method_id = 0
401 REAL(kind=
dp) :: eps_core_charge = 0.0_dp, &
402 eps_kg_orb = 0.0_dp, &
403 eps_pgf_orb = 0.0_dp, &
406 eps_rho_gspace = 0.0_dp, &
407 eps_rho_rspace = 0.0_dp, &
408 eps_filter_matrix = 0.0_dp, &
409 eps_gvg_rspace = 0.0_dp, &
410 progression_factor = 0.0_dp, &
411 relative_cutoff = 0.0_dp
412 LOGICAL :: do_almo_scf = .false.
413 LOGICAL :: do_ls_scf = .false.
414 LOGICAL :: do_kg = .false.
415 LOGICAL :: commensurate_mgrids = .false.
416 LOGICAL :: realspace_mgrids = .false.
417 LOGICAL :: gapw = .false., gapw_xc = .false., gpw = .false., pao = .false.
418 LOGICAL :: lrigpw = .false., rigpw = .false.
419 LOGICAL :: lri_optbas = .false.
420 LOGICAL :: ofgpw = .false.
421 LOGICAL :: dftb = .false.
422 LOGICAL :: xtb = .false.
423 LOGICAL :: semi_empirical = .false.
424 LOGICAL :: mulliken_restraint = .false.
425 LOGICAL :: ddapc_restraint = .false.
426 LOGICAL :: ddapc_restraint_is_spin = .false.
427 LOGICAL :: ddapc_explicit_potential = .false.
428 LOGICAL :: cdft = .false.
429 LOGICAL :: et_coupling_calc = .false.
430 LOGICAL :: s2_restraint = .false.
431 INTEGER :: do_ppl_method = 0
432 INTEGER :: wf_interpolation_method_nr = 0
433 INTEGER :: wf_extrapolation_order = 0
434 INTEGER :: periodicity = 0
435 REAL(kind=
dp) :: pairlist_radius = 0.0_dp
436 REAL(kind=
dp) :: cutoff = 0.0_dp
437 REAL(kind=
dp),
DIMENSION(:),
POINTER :: e_cutoff => null()
439 POINTER :: mulliken_restraint_control => null()
441 DIMENSION(:),
POINTER :: ddapc_restraint_control => null()
447 POINTER :: se_control => null()
449 TYPE(pw_grid_option) :: pw_grid_opt = pw_grid_option()
450 LOGICAL :: skip_load_balance_distributed = .false.
452 LOGICAL :: ref_embed_subsys = .false.
453 LOGICAL :: cluster_embed_subsys = .false.
454 LOGICAL :: high_level_embed_subsys = .false.
455 LOGICAL :: dfet_embedded = .false.
456 LOGICAL :: dmfet_embedded = .false.
463 LOGICAL :: sccs_activated = .false.
464 INTEGER :: derivative_method = 0, &
467 REAL(kind=
dp) :: alpha_solvent = 0.0_dp, &
469 beta_solvent = 0.0_dp, &
470 delta_rho = 0.0_dp, &
473 epsilon_solvent = 0.0_dp, &
474 gamma_solvent = 0.0_dp, &
487 LOGICAL :: do_ewald = .false.
488 LOGICAL :: do_exchange = .false.
489 REAL(kind=
dp) :: hfx_fraction = 0.0_dp
490 REAL(kind=
dp) :: eps_td_filter = 0.0_dp
491 REAL(kind=
dp) :: mn_alpha = 0.0_dp
492 REAL(kind=
dp) :: mn_beta = 0.0_dp
493 REAL(kind=
dp) :: coulomb_sr_cut = 0.0_dp
494 REAL(kind=
dp) :: coulomb_sr_eps = 0.0_dp
503 REAL(kind=
dp),
DIMENSION(:),
POINTER :: fermia => null()
504 REAL(kind=
dp),
DIMENSION(:, :),
POINTER :: fermib => null()
512 LOGICAL :: enabled = .false.
514 INTEGER :: nstates = 0
516 INTEGER :: niters = 0
522 INTEGER :: nprocs = 0
524 INTEGER :: kernel = 0
526 INTEGER :: spinflip = 0
528 LOGICAL :: do_hfx = .false.
529 LOGICAL :: do_admm = .false.
531 LOGICAL :: do_hfxsr = .false.
532 LOGICAL :: hfxsr_re_int = .true.
533 INTEGER :: hfxsr_primbas = 0
534 LOGICAL :: do_hfxlr = .false.
535 REAL(kind=
dp) :: hfxlr_rcut = 0.0_dp, hfxlr_scale = 0.0_dp
536 LOGICAL :: do_exck = .false.
540 INTEGER :: oe_corr = 0
542 REAL(kind=
dp) :: ev_shift = 0.0_dp, eos_shift = 0.0_dp
544 INTEGER,
DIMENSION(2) :: nactive = -1
546 REAL(kind=
dp) :: conv = 0.0_dp
548 REAL(kind=
dp) :: min_excitation_amplitude = 0.0_dp
551 REAL(kind=
dp) :: orthogonal_eps = 0.0_dp
553 LOGICAL :: is_restart = .false.
555 LOGICAL :: rks_triplets = .false.
557 LOGICAL :: do_lrigpw = .false.
559 LOGICAL :: do_smearing = .false.
561 LOGICAL :: do_bse = .false.
563 INTEGER :: auto_basis_p_lri_aux = 1
565 LOGICAL :: admm_symm = .false.
567 LOGICAL :: admm_xc_correction = .false.
569 LOGICAL :: do_exciton_descriptors = .false.
570 LOGICAL :: do_directional_exciton_descriptors = .false.
575 INTEGER :: dipole_form = 0
577 INTEGER :: dipole_reference = 0
579 REAL(kind=
dp),
DIMENSION(:),
POINTER :: dipole_ref_point => null()
582 LOGICAL :: do_soc = .false.
587 INTEGER :: mgrid_ngrids = 0
589 LOGICAL :: mgrid_commensurate_mgrids = .false.
593 LOGICAL :: mgrid_is_explicit = .false.
595 LOGICAL :: mgrid_realspace_mgrids = .false.
597 LOGICAL :: mgrid_skip_load_balance = .false.
599 REAL(kind=
dp) :: mgrid_cutoff = 0.0_dp
602 REAL(kind=
dp) :: mgrid_progression_factor = 0.0_dp
604 REAL(kind=
dp) :: mgrid_relative_cutoff = 0.0_dp
607 REAL(kind=
dp),
DIMENSION(:),
POINTER :: mgrid_e_cutoff => null()
617 LOGICAL :: enabled = .false.
618 INTEGER :: core_states = 0
619 INTEGER :: valence_states = 0
633 TYPE(period_efield_type),
POINTER :: period_efield => null()
643 TYPE(efield_p_type),
POINTER, &
644 DIMENSION(:) :: efield_fields => null()
646 DIMENSION(:) :: probe => null()
647 INTEGER :: nspins = 0, &
651 plus_u_method_id = 0, &
654 INTEGER :: sic_list_id = 0
655 INTEGER :: auto_basis_ri_aux = 1, &
656 auto_basis_aux_fit = 1, &
657 auto_basis_lri_aux = 1, &
658 auto_basis_p_lri_aux = 1, &
659 auto_basis_ri_hxc = 1, &
660 auto_basis_ri_xas = 1, &
661 auto_basis_ri_hfx = 1
662 REAL(kind=
dp) :: relax_multiplicity = 0.0_dp, &
663 sic_scaling_a = 0.0_dp, &
664 sic_scaling_b = 0.0_dp, &
665 pos_dir_surf_dip = 0.0_dp
666 LOGICAL :: do_xas_calculation = .false., &
667 do_xas_tdp_calculation = .false., &
668 drho_by_collocation = .false., &
669 use_kinetic_energy_density = .false., &
670 restricted = .false., &
675 apply_efield = .false., &
676 apply_efield_field = .false., &
677 apply_vector_potential = .false., &
678 apply_period_efield = .false., &
679 apply_external_potential = .false., &
680 eval_external_potential = .false., &
682 do_admm_dm = .false., &
683 do_admm_mo = .false., &
685 low_spin_roks = .false., &
686 apply_external_density = .false., &
687 read_external_density = .false., &
688 apply_external_vxc = .false., &
689 read_external_vxc = .false., &
690 correct_surf_dip = .false., &
691 surf_dip_correct_switch = .false., &
692 switch_surf_dip = .false., &
693 correct_el_density_dip = .false., &
695 apply_embed_pot = .false., &
696 apply_dmfet_pot = .false., &
700 CHARACTER(len=*),
PARAMETER,
PRIVATE :: modulen =
'cp_control_types'
746 SUBROUTINE mulliken_control_create(mulliken_restraint_control)
749 mulliken_restraint_control%strength = 0.1_dp
750 mulliken_restraint_control%target = 1.0_dp
751 mulliken_restraint_control%natoms = 0
752 NULLIFY (mulliken_restraint_control%atoms)
753 END SUBROUTINE mulliken_control_create
761 SUBROUTINE mulliken_control_release(mulliken_restraint_control)
764 IF (
ASSOCIATED(mulliken_restraint_control%atoms)) &
765 DEALLOCATE (mulliken_restraint_control%atoms)
766 mulliken_restraint_control%strength = 0.0_dp
767 mulliken_restraint_control%target = 0.0_dp
768 mulliken_restraint_control%natoms = 0
769 END SUBROUTINE mulliken_control_release
781 ddapc_restraint_control%strength = 0.1_dp
782 ddapc_restraint_control%ddapc_order_p = 0.0_dp
783 ddapc_restraint_control%functional_form = -1
784 ddapc_restraint_control%target = 1.0_dp
785 ddapc_restraint_control%natoms = 0
786 NULLIFY (ddapc_restraint_control%atoms)
787 NULLIFY (ddapc_restraint_control%coeff)
797 SUBROUTINE ddapc_control_release(ddapc_restraint_control)
800 IF (
ASSOCIATED(ddapc_restraint_control%atoms)) &
801 DEALLOCATE (ddapc_restraint_control%atoms)
802 IF (
ASSOCIATED(ddapc_restraint_control%coeff)) &
803 DEALLOCATE (ddapc_restraint_control%coeff)
804 ddapc_restraint_control%strength = 0.0_dp
805 ddapc_restraint_control%target = 0.0_dp
806 ddapc_restraint_control%natoms = 0
807 END SUBROUTINE ddapc_control_release
815 SUBROUTINE s2_control_create(s2_restraint_control)
818 s2_restraint_control%strength = 0.1_dp
819 s2_restraint_control%s2_order_p = 0.0_dp
820 s2_restraint_control%functional_form = -1
821 s2_restraint_control%target = 1.0_dp
822 END SUBROUTINE s2_control_create
830 SUBROUTINE s2_control_release(s2_restraint_control)
833 s2_restraint_control%strength = 0.0_dp
834 s2_restraint_control%target = 0.0_dp
835 END SUBROUTINE s2_control_release
847 NULLIFY (dft_control%xas_control)
848 NULLIFY (dft_control%qs_control)
849 NULLIFY (dft_control%tddfpt2_control)
850 NULLIFY (dft_control%rixs_control)
851 NULLIFY (dft_control%efield_fields)
852 NULLIFY (dft_control%period_efield)
853 NULLIFY (dft_control%admm_control)
854 NULLIFY (dft_control%expot_control)
855 NULLIFY (dft_control%maxwell_control)
856 NULLIFY (dft_control%smeagol_control)
857 NULLIFY (dft_control%rtp_control)
858 NULLIFY (dft_control%sccs_control)
859 NULLIFY (dft_control%probe)
860 dft_control%do_sccs = .false.
861 dft_control%apply_embed_pot = .false.
862 dft_control%apply_dmfet_pot = .false.
863 dft_control%hairy_probes = .false.
864 CALL qs_control_create(dft_control%qs_control)
865 CALL tddfpt2_control_create(dft_control%tddfpt2_control)
882 CALL qs_control_release(dft_control%qs_control)
883 CALL tddfpt2_control_release(dft_control%tddfpt2_control)
885 IF (
ASSOCIATED(dft_control%xas_control))
THEN
887 DEALLOCATE (dft_control%xas_control)
890 CALL expot_control_release(dft_control%expot_control)
891 CALL maxwell_control_release(dft_control%maxwell_control)
893 CALL efield_fields_release(dft_control%efield_fields)
894 IF (
ASSOCIATED(dft_control%probe))
THEN
895 DO i = 1,
SIZE(dft_control%probe)
896 DEALLOCATE (dft_control%probe(i)%atom_ids)
898 DEALLOCATE (dft_control%probe)
900 IF (
ASSOCIATED(dft_control%sccs_control))
DEALLOCATE (dft_control%sccs_control)
901 IF (
ASSOCIATED(dft_control%period_efield))
THEN
902 DEALLOCATE (dft_control%period_efield)
904 IF (
ASSOCIATED(dft_control%rtp_control))
THEN
905 CALL proj_mo_list_release(dft_control%rtp_control%proj_mo_list)
906 DEALLOCATE (dft_control%rtp_control)
915 SUBROUTINE qs_control_create(qs_control)
918 cpassert(.NOT.
ASSOCIATED(qs_control))
919 ALLOCATE (qs_control)
921 NULLIFY (qs_control%e_cutoff)
922 NULLIFY (qs_control%gapw_control)
923 NULLIFY (qs_control%mulliken_restraint_control)
924 NULLIFY (qs_control%ddapc_restraint_control)
925 NULLIFY (qs_control%s2_restraint_control)
926 NULLIFY (qs_control%se_control)
927 NULLIFY (qs_control%dftb_control)
928 NULLIFY (qs_control%xtb_control)
929 NULLIFY (qs_control%cdft_control)
930 NULLIFY (qs_control%ddapc_restraint_control)
932 ALLOCATE (qs_control%mulliken_restraint_control)
933 CALL mulliken_control_create(qs_control%mulliken_restraint_control)
934 ALLOCATE (qs_control%s2_restraint_control)
935 CALL s2_control_create(qs_control%s2_restraint_control)
936 ALLOCATE (qs_control%gapw_control)
937 CALL se_control_create(qs_control%se_control)
938 CALL dftb_control_create(qs_control%dftb_control)
939 CALL xtb_control_create(qs_control%xtb_control)
940 ALLOCATE (qs_control%cdft_control)
942 END SUBROUTINE qs_control_create
948 SUBROUTINE qs_control_release(qs_control)
953 IF (
ASSOCIATED(qs_control))
THEN
954 CALL mulliken_control_release(qs_control%mulliken_restraint_control)
955 DEALLOCATE (qs_control%mulliken_restraint_control)
956 CALL s2_control_release(qs_control%s2_restraint_control)
957 DEALLOCATE (qs_control%s2_restraint_control)
958 CALL se_control_release(qs_control%se_control)
959 CALL dftb_control_release(qs_control%dftb_control)
960 CALL xtb_control_release(qs_control%xtb_control)
961 IF (
ASSOCIATED(qs_control%cdft_control))
THEN
963 DEALLOCATE (qs_control%cdft_control)
966 IF (
ASSOCIATED(qs_control%e_cutoff))
THEN
967 DEALLOCATE (qs_control%e_cutoff)
969 IF (
ASSOCIATED(qs_control%gapw_control))
THEN
970 IF (
ASSOCIATED(qs_control%gapw_control%aw))
THEN
971 DEALLOCATE (qs_control%gapw_control%aw)
973 DEALLOCATE (qs_control%gapw_control)
975 IF (
ASSOCIATED(qs_control%ddapc_restraint_control))
THEN
976 DO i = 1,
SIZE(qs_control%ddapc_restraint_control)
977 CALL ddapc_control_release(qs_control%ddapc_restraint_control(i))
979 DEALLOCATE (qs_control%ddapc_restraint_control)
981 DEALLOCATE (qs_control)
983 END SUBROUTINE qs_control_release
991 SUBROUTINE tddfpt2_control_create(tddfpt_control)
994 CHARACTER(len=*),
PARAMETER :: routinen =
'tddfpt2_control_create'
998 cpassert(.NOT.
ASSOCIATED(tddfpt_control))
999 CALL timeset(routinen, handle)
1001 ALLOCATE (tddfpt_control)
1002 tddfpt_control%do_soc = .false.
1004 CALL timestop(handle)
1005 END SUBROUTINE tddfpt2_control_create
1013 SUBROUTINE tddfpt2_control_release(tddfpt_control)
1016 CHARACTER(len=*),
PARAMETER :: routinen =
'tddfpt2_control_release'
1020 CALL timeset(routinen, handle)
1022 IF (
ASSOCIATED(tddfpt_control))
THEN
1023 DEALLOCATE (tddfpt_control)
1026 CALL timestop(handle)
1027 END SUBROUTINE tddfpt2_control_release
1036 cpassert(.NOT.
ASSOCIATED(rixs_control))
1037 ALLOCATE (rixs_control)
1039 NULLIFY (rixs_control%tddfpt2_control)
1040 CALL tddfpt2_control_create(rixs_control%tddfpt2_control)
1041 NULLIFY (rixs_control%xas_tdp_control)
1053 IF (
ASSOCIATED(rixs_control))
THEN
1054 CALL tddfpt2_control_release(rixs_control%tddfpt2_control)
1057 DEALLOCATE (rixs_control)
1066 SUBROUTINE proj_mo_list_release(proj_mo_list)
1067 TYPE(proj_mo_p_type),
DIMENSION(:),
POINTER :: proj_mo_list
1069 INTEGER :: i, mo_ref_nbr
1071 IF (
ASSOCIATED(proj_mo_list))
THEN
1072 DO i = 1,
SIZE(proj_mo_list)
1073 IF (
ASSOCIATED(proj_mo_list(i)%proj_mo))
THEN
1074 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%ref_mo_index)) &
1075 DEALLOCATE (proj_mo_list(i)%proj_mo%ref_mo_index)
1076 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%mo_ref))
THEN
1077 DO mo_ref_nbr = 1,
SIZE(proj_mo_list(i)%proj_mo%mo_ref)
1078 CALL cp_fm_release(proj_mo_list(i)%proj_mo%mo_ref(mo_ref_nbr))
1080 DEALLOCATE (proj_mo_list(i)%proj_mo%mo_ref)
1082 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%td_mo_index)) &
1083 DEALLOCATE (proj_mo_list(i)%proj_mo%td_mo_index)
1084 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%td_mo_occ)) &
1085 DEALLOCATE (proj_mo_list(i)%proj_mo%td_mo_occ)
1086 DEALLOCATE (proj_mo_list(i)%proj_mo)
1089 DEALLOCATE (proj_mo_list)
1091 END SUBROUTINE proj_mo_list_release
1097 SUBROUTINE efield_fields_release(efield_fields)
1098 TYPE(efield_p_type),
DIMENSION(:),
POINTER :: efield_fields
1102 IF (
ASSOCIATED(efield_fields))
THEN
1103 DO i = 1,
SIZE(efield_fields)
1104 IF (
ASSOCIATED(efield_fields(i)%efield))
THEN
1105 IF (
ASSOCIATED(efield_fields(i)%efield%envelop_r_vars))
THEN
1106 DEALLOCATE (efield_fields(i)%efield%envelop_r_vars)
1108 IF (
ASSOCIATED(efield_fields(i)%efield%envelop_i_vars))
THEN
1109 DEALLOCATE (efield_fields(i)%efield%envelop_i_vars)
1111 IF (
ASSOCIATED(efield_fields(i)%efield%polarisation)) &
1112 DEALLOCATE (efield_fields(i)%efield%polarisation)
1113 DEALLOCATE (efield_fields(i)%efield)
1116 DEALLOCATE (efield_fields)
1118 END SUBROUTINE efield_fields_release
1124 SUBROUTINE dftb_control_create(dftb_control)
1127 cpassert(.NOT.
ASSOCIATED(dftb_control))
1128 ALLOCATE (dftb_control)
1130 NULLIFY (dftb_control%sk_pair_list)
1131 END SUBROUTINE dftb_control_create
1137 SUBROUTINE dftb_control_release(dftb_control)
1140 IF (
ASSOCIATED(dftb_control))
THEN
1141 IF (
ASSOCIATED(dftb_control%sk_pair_list))
THEN
1142 DEALLOCATE (dftb_control%sk_pair_list)
1144 DEALLOCATE (dftb_control)
1146 END SUBROUTINE dftb_control_release
1152 SUBROUTINE xtb_control_create(xtb_control)
1155 cpassert(.NOT.
ASSOCIATED(xtb_control))
1156 ALLOCATE (xtb_control)
1158 NULLIFY (xtb_control%kab_param)
1159 NULLIFY (xtb_control%kab_vals)
1160 NULLIFY (xtb_control%kab_types)
1161 NULLIFY (xtb_control%nonbonded)
1162 NULLIFY (xtb_control%rcpair)
1164 END SUBROUTINE xtb_control_create
1170 SUBROUTINE xtb_control_release(xtb_control)
1173 IF (
ASSOCIATED(xtb_control))
THEN
1174 IF (
ASSOCIATED(xtb_control%kab_param))
THEN
1175 DEALLOCATE (xtb_control%kab_param)
1177 IF (
ASSOCIATED(xtb_control%kab_vals))
THEN
1178 DEALLOCATE (xtb_control%kab_vals)
1180 IF (
ASSOCIATED(xtb_control%kab_types))
THEN
1181 DEALLOCATE (xtb_control%kab_types)
1183 IF (
ASSOCIATED(xtb_control%rcpair))
THEN
1184 DEALLOCATE (xtb_control%rcpair)
1186 IF (
ASSOCIATED(xtb_control%nonbonded))
THEN
1189 DEALLOCATE (xtb_control)
1191 END SUBROUTINE xtb_control_release
1197 SUBROUTINE se_control_create(se_control)
1200 cpassert(.NOT.
ASSOCIATED(se_control))
1201 ALLOCATE (se_control)
1202 END SUBROUTINE se_control_create
1208 SUBROUTINE se_control_release(se_control)
1211 IF (
ASSOCIATED(se_control))
THEN
1212 DEALLOCATE (se_control)
1214 END SUBROUTINE se_control_release
1223 cpassert(.NOT.
ASSOCIATED(admm_control))
1224 ALLOCATE (admm_control)
1235 IF (
ASSOCIATED(admm_control))
THEN
1236 DEALLOCATE (admm_control)
1247 cpassert(.NOT.
ASSOCIATED(expot_control))
1248 ALLOCATE (expot_control)
1249 expot_control%read_from_cube = .false.
1250 expot_control%maxwell_solver = .false.
1251 expot_control%static = .true.
1252 expot_control%scaling_factor = 1.0_dp
1260 SUBROUTINE expot_control_release(expot_control)
1263 IF (
ASSOCIATED(expot_control))
THEN
1264 DEALLOCATE (expot_control)
1267 END SUBROUTINE expot_control_release
1276 cpassert(.NOT.
ASSOCIATED(maxwell_control))
1277 ALLOCATE (maxwell_control)
1285 SUBROUTINE maxwell_control_release(maxwell_control)
1288 IF (
ASSOCIATED(maxwell_control))
THEN
1289 DEALLOCATE (maxwell_control)
1292 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
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.