32#include "./base/base_uses.f90"
42 LOGICAL :: spherical = .false.
43 LOGICAL :: fullspace = .false.
44 INTEGER,
DIMENSION(2) :: distribution_layout = 0
45 INTEGER :: blocked = 0
46 END TYPE pw_grid_option
52 INTEGER,
DIMENSION(:),
ALLOCATABLE :: ref_mo_index
53 INTEGER :: ref_mo_spin = 1
54 INTEGER :: ref_nlumo = 0
55 LOGICAL :: sum_on_all_ref = .false.
56 INTEGER,
DIMENSION(:),
ALLOCATABLE :: td_mo_index
57 REAL(
dp),
DIMENSION(:),
ALLOCATABLE :: td_mo_occ
58 INTEGER :: td_mo_spin = 1
59 LOGICAL :: sum_on_all_td = .false.
60 CHARACTER(LEN=default_path_length) :: ref_mo_file_name =
""
61 LOGICAL :: propagate_ref = .false.
68 END TYPE proj_mo_p_type
74 LOGICAL :: converged = .false.
75 REAL(kind=
dp) :: eps_ener = 0.0_dp
76 INTEGER :: max_iter = 0
77 INTEGER :: mat_exp = 0
78 INTEGER :: propagator = 0
79 LOGICAL :: fixed_ions = .false.
82 INTEGER :: initial_wfn = 0
83 REAL(
dp) :: eps_exp = 0.0_dp
84 LOGICAL :: initial_step = .false.
85 LOGICAL :: hfx_redistribute = .false.
86 INTEGER :: aspc_order = 0
87 INTEGER :: sc_check_start = 0
88 LOGICAL :: apply_wfn_mix_init_restart = .false.
89 LOGICAL :: apply_delta_pulse = .false.
90 LOGICAL :: apply_delta_pulse_mag = .false.
91 LOGICAL :: periodic = .false.
92 LOGICAL :: linear_scaling = .false.
93 LOGICAL :: write_restart = .false.
94 INTEGER :: mcweeny_max_iter = 0
95 INTEGER :: acc_ref = 0
96 REAL(
dp) :: mcweeny_eps = 0.0_dp
97 INTEGER,
DIMENSION(3) :: delta_pulse_direction = 0
98 REAL(kind=
dp) :: delta_pulse_scale = 0.0_dp
99 LOGICAL :: velocity_gauge = .false.
100 REAL(kind=
dp),
DIMENSION(3) :: field = 0.0_dp
101 REAL(kind=
dp),
DIMENSION(3) :: vec_pot = 0.0_dp
102 LOGICAL :: nl_gauge_transform = .false.
103 LOGICAL :: is_proj_mo = .false.
104 TYPE(proj_mo_p_type),
DIMENSION(:), &
105 POINTER :: proj_mo_list => null()
112 LOGICAL :: self_consistent = .false.
113 LOGICAL :: orthogonal_basis = .false.
114 LOGICAL :: dispersion = .false.
115 INTEGER :: dispersion_type = 0
116 LOGICAL :: dftb3_diagonal = .false.
117 LOGICAL :: hb_sr_damp = .false.
118 REAL(kind=
dp) :: hb_sr_para = 0.0_dp
119 REAL(kind=
dp) :: eps_disp = 0.0_dp
120 REAL(kind=
dp) :: epscn = 0.0_dp
121 REAL(kind=
dp) :: exp_pre = 0.0_dp
122 REAL(kind=
dp) :: scaling = 0.0_dp
123 REAL(kind=
dp) :: rcdisp = 0.0_dp
124 REAL(kind=
dp),
DIMENSION(3) :: sd3 = 0.0_dp
125 REAL(kind=
dp),
DIMENSION(4) :: sd3bj = 0.0_dp
126 LOGICAL :: do_ewald = .false.
127 CHARACTER(LEN=default_path_length) :: sk_file_path =
""
128 CHARACTER(LEN=default_path_length) :: sk_file_list =
""
129 CHARACTER(LEN=default_string_length), &
130 DIMENSION(:, :),
POINTER :: sk_pair_list => null()
131 CHARACTER(LEN=default_path_length) :: uff_force_field =
""
132 CHARACTER(LEN=default_path_length) :: dispersion_parameter_file =
""
140 INTEGER :: gfn_type = 1
142 LOGICAL :: do_ewald = .false.
145 INTEGER :: h_sto_ng = 0
147 INTEGER :: vdw_type = -1
148 CHARACTER(LEN=default_path_length) :: parameter_file_path =
""
149 CHARACTER(LEN=default_path_length) :: parameter_file_name =
""
151 CHARACTER(LEN=default_path_length) :: dispersion_parameter_file =
""
152 REAL(kind=
dp) :: epscn = 0.0_dp
153 REAL(kind=
dp) :: rcdisp = 0.0_dp
154 REAL(kind=
dp) :: s6 = 0.0_dp, s8 = 0.0_dp
155 REAL(kind=
dp) :: a1 = 0.0_dp, a2 = 0.0_dp
157 REAL(kind=
dp) :: ks = 0.0_dp, kp = 0.0_dp, kd = 0.0_dp, ksp = 0.0_dp, k2sh = 0.0_dp
158 REAL(kind=
dp) :: kg = 0.0_dp, kf = 0.0_dp
159 REAL(kind=
dp) :: kcns = 0.0_dp, kcnp = 0.0_dp, kcnd = 0.0_dp
160 REAL(kind=
dp) :: ken = 0.0_dp
161 REAL(kind=
dp) :: ksen = 0.0_dp, kpen = 0.0_dp, kden = 0.0_dp
162 REAL(kind=
dp) :: ben = 0.0_dp
163 REAL(kind=
dp) :: kxr = 0.0_dp, kx2 = 0.0_dp
164 REAL(kind=
dp) :: enscale = 0.0_dp
166 LOGICAL :: xb_interaction = .false.
167 LOGICAL :: do_nonbonded = .false.
168 LOGICAL :: coulomb_interaction = .false.
169 LOGICAL :: coulomb_lr = .false.
170 LOGICAL :: tb3_interaction = .false.
171 LOGICAL :: check_atomic_charges = .false.
172 LOGICAL :: var_dipole = .false.
174 REAL(kind=
dp) :: xb_radius = 0.0_dp
175 REAL(kind=
dp) :: coulomb_sr_cut = 0.0_dp
176 REAL(kind=
dp) :: coulomb_sr_eps = 0.0_dp
178 CHARACTER(LEN=default_string_length), &
179 DIMENSION(:, :),
POINTER :: kab_param => null()
180 INTEGER,
DIMENSION(:, :),
POINTER :: kab_types => null()
181 INTEGER :: kab_nval = 0
182 REAL,
DIMENSION(:),
POINTER :: kab_vals => null()
185 REAL(kind=
dp) :: eps_pair = 0.0_dp
186 REAL(kind=
dp),
DIMENSION(:, :), &
187 POINTER :: rcpair => null()
190 REAL(kind=
dp) :: ksrb = 0.0_dp, esrb = 0.0_dp, gscal = 0.0_dp
191 REAL(kind=
dp) :: c1srb = 0.0_dp, c2srb = 0.0_dp, shift = 0.0_dp
194 INTEGER :: enshift_type = 1
202 LOGICAL :: orthogonal_basis = .false.
203 LOGICAL :: analytical_gradients = .false.
204 LOGICAL :: force_kdsod_ex = .false.
205 LOGICAL :: do_ewald = .false., do_ewald_r3 = .false., do_ewald_gks = .false.
206 INTEGER :: integral_screening = 0, periodic_type = 0
207 INTEGER :: max_multipole = 0
208 INTEGER :: ga_ncells = 0
209 REAL(kind=
dp) :: delta = 0.0_dp
211 LOGICAL :: dispersion = .false.
212 REAL(kind=
dp) :: rcdisp = 0.0_dp
213 REAL(kind=
dp) :: epscn = 0.0_dp
214 REAL(kind=
dp),
DIMENSION(3) :: sd3 = 0.0_dp
215 CHARACTER(LEN=default_path_length) :: dispersion_parameter_file =
""
217 REAL(kind=
dp) :: cutoff_lrc = 0.0_dp, taper_lrc = 0.0_dp, range_lrc = 0.0_dp
218 REAL(kind=
dp) :: cutoff_cou = 0.0_dp, taper_cou = 0.0_dp, range_cou = 0.0_dp
219 REAL(kind=
dp) :: cutoff_exc = 0.0_dp, taper_exc = 0.0_dp, range_exc = 0.0_dp
220 REAL(kind=
dp) :: taper_scr = 0.0_dp, range_scr = 0.0_dp
227 INTEGER :: basis_1c = 0
228 REAL(kind=
dp) :: eps_fit = 0.0_dp, &
230 eps_vrho0 = 0.0_dp, &
233 INTEGER :: ladd_rho0 = 0, &
237 LOGICAL :: lrho1_eq_lrho0 = .false.
238 LOGICAL :: alpha0_hard_from_input = .false., &
239 force_paw = .false., &
240 non_paw_atoms = .false., &
241 nopaw_as_gpw = .false.
242 REAL(kind=
dp) :: alpha0_hard = 0.0_dp
243 REAL(kind=
dp) :: max_rad_local = 0.0_dp
250 REAL(kind=
dp) :: actual_time = 0.0_dp
251 REAL(kind=
dp),
DIMENSION(:),
POINTER :: polarisation => null()
252 INTEGER :: envelop_id = 0
253 REAL(kind=
dp),
DIMENSION(:),
POINTER :: envelop_r_vars => null()
254 INTEGER,
DIMENSION(:),
POINTER :: envelop_i_vars => null()
255 REAL(kind=
dp) :: strength = 0.0_dp
256 REAL(kind=
dp) :: phase_offset = 0.0_dp
257 REAL(kind=
dp) :: wavelength = 0.0_dp
258 REAL(kind=
dp),
DIMENSION(3) :: vec_pot_initial = 0.0_dp
263 END TYPE efield_p_type
268 TYPE period_efield_type
269 LOGICAL :: displacement_field = .false.
270 REAL(kind=
dp),
DIMENSION(3) :: polarisation = 0.0_dp
271 REAL(kind=
dp),
DIMENSION(3) :: d_filter = 0.0_dp
272 REAL(kind=
dp) :: strength = 0.0_dp
273 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:) :: strength_list
274 INTEGER :: start_frame = 0
275 INTEGER :: end_frame = -1
276 END TYPE period_efield_type
282 REAL(kind=
dp) :: strength = 0.0_dp
283 REAL(kind=
dp) ::
TARGET = 0.0_dp
284 INTEGER :: natoms = 0
285 INTEGER,
POINTER,
DIMENSION(:) :: atoms => null()
292 INTEGER :: ref_count = 0
293 REAL(kind=
dp) :: strength = 0.0_dp
294 REAL(kind=
dp) ::
TARGET = 0.0_dp
295 REAL(kind=
dp) :: ddapc_order_p = 0.0_dp
296 INTEGER :: functional_form = 0
297 INTEGER :: natoms = 0
298 INTEGER,
POINTER,
DIMENSION(:) :: atoms => null()
299 REAL(kind=
dp),
POINTER,
DIMENSION(:) :: coeff => null()
300 INTEGER :: density_type = 0
307 REAL(kind=
dp) :: strength = 0.0_dp
308 REAL(kind=
dp) ::
TARGET = 0.0_dp
309 REAL(kind=
dp) :: s2_order_p = 0.0_dp
310 INTEGER :: functional_form = 0
317 INTEGER,
DIMENSION(:),
ALLOCATABLE ::
list
318 END TYPE admm_block_type
321 REAL(kind=
dp) :: eps_filter = 0.0_dp
322 INTEGER :: admm_type = 0
323 INTEGER :: purification_method = 0
324 INTEGER :: method = 0
325 LOGICAL :: charge_constrain = .false.
326 INTEGER :: scaling_model = 0
327 INTEGER :: aux_exch_func = 0
328 LOGICAL :: aux_exch_func_param = .false.
329 REAL(kind=
dp),
DIMENSION(3) :: aux_x_param = 0.0_dp
330 TYPE(admm_block_type),
DIMENSION(:), &
331 ALLOCATABLE :: blocks
338 LOGICAL :: read_from_cube = .false.
339 LOGICAL :: maxwell_solver = .false.
340 LOGICAL :: static = .false.
341 REAL(kind=
dp) :: scaling_factor = 0.0_dp
348 LOGICAL :: log_test = .false.
349 INTEGER :: int_test = 0
350 REAL(kind=
dp) :: real_test = 0.0_dp
359 INTEGER :: method_id = 0
360 REAL(kind=
dp) :: eps_core_charge = 0.0_dp, &
361 eps_kg_orb = 0.0_dp, &
362 eps_pgf_orb = 0.0_dp, &
365 eps_rho_gspace = 0.0_dp, &
366 eps_rho_rspace = 0.0_dp, &
367 eps_filter_matrix = 0.0_dp, &
368 eps_gvg_rspace = 0.0_dp, &
369 progression_factor = 0.0_dp, &
370 relative_cutoff = 0.0_dp
371 LOGICAL :: do_almo_scf = .false.
372 LOGICAL :: do_ls_scf = .false.
373 LOGICAL :: do_kg = .false.
374 LOGICAL :: commensurate_mgrids = .false.
375 LOGICAL :: realspace_mgrids = .false.
376 LOGICAL :: gapw = .false., gapw_xc = .false., gpw = .false., pao = .false.
377 LOGICAL :: lrigpw = .false., rigpw = .false.
378 LOGICAL :: lri_optbas = .false.
379 LOGICAL :: ofgpw = .false.
380 LOGICAL :: dftb = .false.
381 LOGICAL :: xtb = .false.
382 LOGICAL :: semi_empirical = .false.
383 LOGICAL :: mulliken_restraint = .false.
384 LOGICAL :: ddapc_restraint = .false.
385 LOGICAL :: ddapc_restraint_is_spin = .false.
386 LOGICAL :: ddapc_explicit_potential = .false.
387 LOGICAL :: cdft = .false.
388 LOGICAL :: et_coupling_calc = .false.
389 LOGICAL :: s2_restraint = .false.
390 INTEGER :: do_ppl_method = 0
391 INTEGER :: wf_interpolation_method_nr = 0
392 INTEGER :: wf_extrapolation_order = 0
393 INTEGER :: periodicity = 0
394 REAL(kind=
dp) :: pairlist_radius = 0.0_dp
395 REAL(kind=
dp) :: cutoff = 0.0_dp
396 REAL(kind=
dp),
DIMENSION(:),
POINTER :: e_cutoff => null()
398 POINTER :: mulliken_restraint_control => null()
400 DIMENSION(:),
POINTER :: ddapc_restraint_control => null()
406 POINTER :: se_control => null()
408 TYPE(pw_grid_option) :: pw_grid_opt = pw_grid_option()
409 LOGICAL :: skip_load_balance_distributed = .false.
411 LOGICAL :: ref_embed_subsys = .false.
412 LOGICAL :: cluster_embed_subsys = .false.
413 LOGICAL :: high_level_embed_subsys = .false.
414 LOGICAL :: dfet_embedded = .false.
415 LOGICAL :: dmfet_embedded = .false.
422 LOGICAL :: sccs_activated = .false.
423 INTEGER :: derivative_method = 0, &
426 REAL(kind=
dp) :: alpha_solvent = 0.0_dp, &
428 beta_solvent = 0.0_dp, &
429 delta_rho = 0.0_dp, &
432 epsilon_solvent = 0.0_dp, &
433 gamma_solvent = 0.0_dp, &
446 LOGICAL :: do_ewald = .false.
447 LOGICAL :: do_exchange = .false.
448 REAL(kind=
dp) :: hfx_fraction = 0.0_dp
449 REAL(kind=
dp) :: eps_td_filter = 0.0_dp
450 REAL(kind=
dp) :: mn_alpha = 0.0_dp
451 REAL(kind=
dp) :: mn_beta = 0.0_dp
452 REAL(kind=
dp) :: coulomb_sr_cut = 0.0_dp
453 REAL(kind=
dp) :: coulomb_sr_eps = 0.0_dp
462 REAL(kind=
dp),
DIMENSION(:),
POINTER :: fermia => null()
463 REAL(kind=
dp),
DIMENSION(:, :),
POINTER :: fermib => null()
471 LOGICAL :: enabled = .false.
473 INTEGER :: nstates = 0
475 INTEGER :: niters = 0
481 INTEGER :: nprocs = 0
483 INTEGER :: kernel = 0
485 LOGICAL :: do_hfx = .false.
486 LOGICAL :: do_admm = .false.
488 LOGICAL :: do_hfxsr = .false.
489 LOGICAL :: hfxsr_re_int = .true.
490 INTEGER :: hfxsr_primbas = 0
491 LOGICAL :: do_hfxlr = .false.
492 REAL(kind=
dp) :: hfxlr_rcut = 0.0_dp, hfxlr_scale = 0.0_dp
493 LOGICAL :: do_exck = .false.
497 INTEGER :: oe_corr = 0
499 REAL(kind=
dp) :: ev_shift = 0.0_dp, eos_shift = 0.0_dp
501 REAL(kind=
dp) :: conv = 0.0_dp
503 REAL(kind=
dp) :: min_excitation_amplitude = 0.0_dp
506 REAL(kind=
dp) :: orthogonal_eps = 0.0_dp
508 LOGICAL :: is_restart = .false.
510 LOGICAL :: rks_triplets = .false.
512 LOGICAL :: do_lrigpw = .false.
514 LOGICAL :: do_smearing = .false.
516 INTEGER :: auto_basis_p_lri_aux = 1
518 LOGICAL :: admm_symm = .false.
520 LOGICAL :: admm_xc_correction = .false.
522 LOGICAL :: do_exciton_descriptors = .false.
523 LOGICAL :: do_directional_exciton_descriptors = .false.
528 INTEGER :: dipole_form = 0
530 INTEGER :: dipole_reference = 0
532 REAL(kind=
dp),
DIMENSION(:),
POINTER :: dipole_ref_point => null()
535 LOGICAL :: do_soc = .false.
540 INTEGER :: mgrid_ngrids = 0
542 LOGICAL :: mgrid_commensurate_mgrids = .false.
546 LOGICAL :: mgrid_is_explicit = .false.
548 LOGICAL :: mgrid_realspace_mgrids = .false.
550 LOGICAL :: mgrid_skip_load_balance = .false.
552 REAL(kind=
dp) :: mgrid_cutoff = 0.0_dp
555 REAL(kind=
dp) :: mgrid_progression_factor = 0.0_dp
557 REAL(kind=
dp) :: mgrid_relative_cutoff = 0.0_dp
560 REAL(kind=
dp),
DIMENSION(:),
POINTER :: mgrid_e_cutoff => null()
572 TYPE(period_efield_type),
POINTER :: period_efield => null()
581 TYPE(efield_p_type),
POINTER, &
582 DIMENSION(:) :: efield_fields => null()
583 INTEGER :: nspins = 0, &
587 plus_u_method_id = 0, &
590 INTEGER :: sic_list_id = 0
591 INTEGER :: auto_basis_ri_aux = 1, &
592 auto_basis_aux_fit = 1, &
593 auto_basis_lri_aux = 1, &
594 auto_basis_p_lri_aux = 1, &
595 auto_basis_ri_hxc = 1, &
596 auto_basis_ri_xas = 1, &
597 auto_basis_ri_hfx = 1
598 REAL(kind=
dp) :: relax_multiplicity = 0.0_dp, &
599 sic_scaling_a = 0.0_dp, &
600 sic_scaling_b = 0.0_dp, &
601 pos_dir_surf_dip = 0.0_dp
602 LOGICAL :: do_xas_calculation = .false., &
603 do_xas_tdp_calculation = .false., &
604 drho_by_collocation = .false., &
605 use_kinetic_energy_density = .false., &
606 restricted = .false., &
611 apply_efield = .false., &
612 apply_efield_field = .false., &
613 apply_vector_potential = .false., &
614 apply_period_efield = .false., &
615 apply_external_potential = .false., &
616 eval_external_potential = .false., &
618 do_admm_dm = .false., &
619 do_admm_mo = .false., &
621 low_spin_roks = .false., &
622 apply_external_density = .false., &
623 read_external_density = .false., &
624 apply_external_vxc = .false., &
625 read_external_vxc = .false., &
626 correct_surf_dip = .false., &
627 surf_dip_correct_switch = .false., &
628 switch_surf_dip = .false., &
629 correct_el_density_dip = .false., &
631 apply_embed_pot = .false., &
632 apply_dmfet_pot = .false.
635 CHARACTER(len=*),
PARAMETER,
PRIVATE :: modulen =
'cp_control_types'
677 SUBROUTINE mulliken_control_create(mulliken_restraint_control)
680 mulliken_restraint_control%strength = 0.1_dp
681 mulliken_restraint_control%target = 1.0_dp
682 mulliken_restraint_control%natoms = 0
683 NULLIFY (mulliken_restraint_control%atoms)
684 END SUBROUTINE mulliken_control_create
692 SUBROUTINE mulliken_control_release(mulliken_restraint_control)
695 IF (
ASSOCIATED(mulliken_restraint_control%atoms)) &
696 DEALLOCATE (mulliken_restraint_control%atoms)
697 mulliken_restraint_control%strength = 0.0_dp
698 mulliken_restraint_control%target = 0.0_dp
699 mulliken_restraint_control%natoms = 0
700 END SUBROUTINE mulliken_control_release
712 ddapc_restraint_control%strength = 0.1_dp
713 ddapc_restraint_control%ddapc_order_p = 0.0_dp
714 ddapc_restraint_control%functional_form = -1
715 ddapc_restraint_control%target = 1.0_dp
716 ddapc_restraint_control%natoms = 0
717 NULLIFY (ddapc_restraint_control%atoms)
718 NULLIFY (ddapc_restraint_control%coeff)
728 SUBROUTINE ddapc_control_release(ddapc_restraint_control)
731 IF (
ASSOCIATED(ddapc_restraint_control%atoms)) &
732 DEALLOCATE (ddapc_restraint_control%atoms)
733 IF (
ASSOCIATED(ddapc_restraint_control%coeff)) &
734 DEALLOCATE (ddapc_restraint_control%coeff)
735 ddapc_restraint_control%strength = 0.0_dp
736 ddapc_restraint_control%target = 0.0_dp
737 ddapc_restraint_control%natoms = 0
738 END SUBROUTINE ddapc_control_release
746 SUBROUTINE s2_control_create(s2_restraint_control)
749 s2_restraint_control%strength = 0.1_dp
750 s2_restraint_control%s2_order_p = 0.0_dp
751 s2_restraint_control%functional_form = -1
752 s2_restraint_control%target = 1.0_dp
753 END SUBROUTINE s2_control_create
761 SUBROUTINE s2_control_release(s2_restraint_control)
764 s2_restraint_control%strength = 0.0_dp
765 s2_restraint_control%target = 0.0_dp
766 END SUBROUTINE s2_control_release
778 NULLIFY (dft_control%xas_control)
779 NULLIFY (dft_control%qs_control)
780 NULLIFY (dft_control%tddfpt2_control)
781 NULLIFY (dft_control%efield_fields)
782 NULLIFY (dft_control%period_efield)
783 NULLIFY (dft_control%admm_control)
784 NULLIFY (dft_control%expot_control)
785 NULLIFY (dft_control%maxwell_control)
786 NULLIFY (dft_control%smeagol_control)
787 NULLIFY (dft_control%rtp_control)
788 NULLIFY (dft_control%sccs_control)
789 dft_control%do_sccs = .false.
790 dft_control%apply_embed_pot = .false.
791 dft_control%apply_dmfet_pot = .false.
792 CALL qs_control_create(dft_control%qs_control)
793 CALL tddfpt2_control_create(dft_control%tddfpt2_control)
807 CALL qs_control_release(dft_control%qs_control)
808 CALL tddfpt2_control_release(dft_control%tddfpt2_control)
809 IF (
ASSOCIATED(dft_control%xas_control))
THEN
811 DEALLOCATE (dft_control%xas_control)
814 CALL expot_control_release(dft_control%expot_control)
815 CALL maxwell_control_release(dft_control%maxwell_control)
817 CALL efield_fields_release(dft_control%efield_fields)
818 IF (
ASSOCIATED(dft_control%sccs_control))
DEALLOCATE (dft_control%sccs_control)
819 IF (
ASSOCIATED(dft_control%period_efield))
THEN
820 DEALLOCATE (dft_control%period_efield)
822 IF (
ASSOCIATED(dft_control%rtp_control))
THEN
823 CALL proj_mo_list_release(dft_control%rtp_control%proj_mo_list)
824 DEALLOCATE (dft_control%rtp_control)
833 SUBROUTINE qs_control_create(qs_control)
836 cpassert(.NOT.
ASSOCIATED(qs_control))
837 ALLOCATE (qs_control)
839 NULLIFY (qs_control%e_cutoff)
840 NULLIFY (qs_control%gapw_control)
841 NULLIFY (qs_control%mulliken_restraint_control)
842 NULLIFY (qs_control%ddapc_restraint_control)
843 NULLIFY (qs_control%s2_restraint_control)
844 NULLIFY (qs_control%se_control)
845 NULLIFY (qs_control%dftb_control)
846 NULLIFY (qs_control%xtb_control)
847 NULLIFY (qs_control%cdft_control)
848 NULLIFY (qs_control%ddapc_restraint_control)
850 ALLOCATE (qs_control%mulliken_restraint_control)
851 CALL mulliken_control_create(qs_control%mulliken_restraint_control)
852 ALLOCATE (qs_control%s2_restraint_control)
853 CALL s2_control_create(qs_control%s2_restraint_control)
854 ALLOCATE (qs_control%gapw_control)
855 CALL se_control_create(qs_control%se_control)
856 CALL dftb_control_create(qs_control%dftb_control)
857 CALL xtb_control_create(qs_control%xtb_control)
858 ALLOCATE (qs_control%cdft_control)
860 END SUBROUTINE qs_control_create
866 SUBROUTINE qs_control_release(qs_control)
871 IF (
ASSOCIATED(qs_control))
THEN
872 CALL mulliken_control_release(qs_control%mulliken_restraint_control)
873 DEALLOCATE (qs_control%mulliken_restraint_control)
874 CALL s2_control_release(qs_control%s2_restraint_control)
875 DEALLOCATE (qs_control%s2_restraint_control)
876 CALL se_control_release(qs_control%se_control)
877 CALL dftb_control_release(qs_control%dftb_control)
878 CALL xtb_control_release(qs_control%xtb_control)
879 IF (
ASSOCIATED(qs_control%cdft_control))
THEN
881 DEALLOCATE (qs_control%cdft_control)
884 IF (
ASSOCIATED(qs_control%e_cutoff))
THEN
885 DEALLOCATE (qs_control%e_cutoff)
887 IF (
ASSOCIATED(qs_control%gapw_control))
THEN
888 DEALLOCATE (qs_control%gapw_control)
890 IF (
ASSOCIATED(qs_control%ddapc_restraint_control))
THEN
891 DO i = 1,
SIZE(qs_control%ddapc_restraint_control)
892 CALL ddapc_control_release(qs_control%ddapc_restraint_control(i))
894 DEALLOCATE (qs_control%ddapc_restraint_control)
896 DEALLOCATE (qs_control)
898 END SUBROUTINE qs_control_release
906 SUBROUTINE tddfpt2_control_create(tddfpt_control)
909 CHARACTER(len=*),
PARAMETER :: routinen =
'tddfpt2_control_create'
913 cpassert(.NOT.
ASSOCIATED(tddfpt_control))
914 CALL timeset(routinen, handle)
916 ALLOCATE (tddfpt_control)
917 tddfpt_control%do_soc = .false.
919 CALL timestop(handle)
920 END SUBROUTINE tddfpt2_control_create
928 SUBROUTINE tddfpt2_control_release(tddfpt_control)
931 CHARACTER(len=*),
PARAMETER :: routinen =
'tddfpt2_control_release'
935 CALL timeset(routinen, handle)
937 IF (
ASSOCIATED(tddfpt_control))
THEN
938 DEALLOCATE (tddfpt_control)
941 CALL timestop(handle)
942 END SUBROUTINE tddfpt2_control_release
948 SUBROUTINE proj_mo_list_release(proj_mo_list)
949 TYPE(proj_mo_p_type),
DIMENSION(:),
POINTER :: proj_mo_list
951 INTEGER :: i, mo_ref_nbr
953 IF (
ASSOCIATED(proj_mo_list))
THEN
954 DO i = 1,
SIZE(proj_mo_list)
955 IF (
ASSOCIATED(proj_mo_list(i)%proj_mo))
THEN
956 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%ref_mo_index)) &
957 DEALLOCATE (proj_mo_list(i)%proj_mo%ref_mo_index)
958 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%mo_ref))
THEN
959 DO mo_ref_nbr = 1,
SIZE(proj_mo_list(i)%proj_mo%mo_ref)
960 CALL cp_fm_release(proj_mo_list(i)%proj_mo%mo_ref(mo_ref_nbr))
962 DEALLOCATE (proj_mo_list(i)%proj_mo%mo_ref)
964 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%td_mo_index)) &
965 DEALLOCATE (proj_mo_list(i)%proj_mo%td_mo_index)
966 IF (
ALLOCATED(proj_mo_list(i)%proj_mo%td_mo_occ)) &
967 DEALLOCATE (proj_mo_list(i)%proj_mo%td_mo_occ)
968 DEALLOCATE (proj_mo_list(i)%proj_mo)
971 DEALLOCATE (proj_mo_list)
973 END SUBROUTINE proj_mo_list_release
979 SUBROUTINE efield_fields_release(efield_fields)
980 TYPE(efield_p_type),
DIMENSION(:),
POINTER :: efield_fields
984 IF (
ASSOCIATED(efield_fields))
THEN
985 DO i = 1,
SIZE(efield_fields)
986 IF (
ASSOCIATED(efield_fields(i)%efield))
THEN
987 IF (
ASSOCIATED(efield_fields(i)%efield%envelop_r_vars))
THEN
988 DEALLOCATE (efield_fields(i)%efield%envelop_r_vars)
990 IF (
ASSOCIATED(efield_fields(i)%efield%envelop_i_vars))
THEN
991 DEALLOCATE (efield_fields(i)%efield%envelop_i_vars)
993 IF (
ASSOCIATED(efield_fields(i)%efield%polarisation)) &
994 DEALLOCATE (efield_fields(i)%efield%polarisation)
995 DEALLOCATE (efield_fields(i)%efield)
998 DEALLOCATE (efield_fields)
1000 END SUBROUTINE efield_fields_release
1006 SUBROUTINE dftb_control_create(dftb_control)
1009 cpassert(.NOT.
ASSOCIATED(dftb_control))
1010 ALLOCATE (dftb_control)
1012 NULLIFY (dftb_control%sk_pair_list)
1013 END SUBROUTINE dftb_control_create
1019 SUBROUTINE dftb_control_release(dftb_control)
1022 IF (
ASSOCIATED(dftb_control))
THEN
1023 IF (
ASSOCIATED(dftb_control%sk_pair_list))
THEN
1024 DEALLOCATE (dftb_control%sk_pair_list)
1026 DEALLOCATE (dftb_control)
1028 END SUBROUTINE dftb_control_release
1034 SUBROUTINE xtb_control_create(xtb_control)
1037 cpassert(.NOT.
ASSOCIATED(xtb_control))
1038 ALLOCATE (xtb_control)
1040 NULLIFY (xtb_control%kab_param)
1041 NULLIFY (xtb_control%kab_vals)
1042 NULLIFY (xtb_control%kab_types)
1043 NULLIFY (xtb_control%nonbonded)
1044 NULLIFY (xtb_control%rcpair)
1046 END SUBROUTINE xtb_control_create
1052 SUBROUTINE xtb_control_release(xtb_control)
1055 IF (
ASSOCIATED(xtb_control))
THEN
1056 IF (
ASSOCIATED(xtb_control%kab_param))
THEN
1057 DEALLOCATE (xtb_control%kab_param)
1059 IF (
ASSOCIATED(xtb_control%kab_vals))
THEN
1060 DEALLOCATE (xtb_control%kab_vals)
1062 IF (
ASSOCIATED(xtb_control%kab_types))
THEN
1063 DEALLOCATE (xtb_control%kab_types)
1065 IF (
ASSOCIATED(xtb_control%rcpair))
THEN
1066 DEALLOCATE (xtb_control%rcpair)
1068 IF (
ASSOCIATED(xtb_control%nonbonded))
THEN
1071 DEALLOCATE (xtb_control)
1073 END SUBROUTINE xtb_control_release
1079 SUBROUTINE se_control_create(se_control)
1082 cpassert(.NOT.
ASSOCIATED(se_control))
1083 ALLOCATE (se_control)
1084 END SUBROUTINE se_control_create
1090 SUBROUTINE se_control_release(se_control)
1093 IF (
ASSOCIATED(se_control))
THEN
1094 DEALLOCATE (se_control)
1096 END SUBROUTINE se_control_release
1105 cpassert(.NOT.
ASSOCIATED(admm_control))
1106 ALLOCATE (admm_control)
1117 IF (
ASSOCIATED(admm_control))
THEN
1118 DEALLOCATE (admm_control)
1129 cpassert(.NOT.
ASSOCIATED(expot_control))
1130 ALLOCATE (expot_control)
1131 expot_control%read_from_cube = .false.
1132 expot_control%maxwell_solver = .false.
1133 expot_control%static = .true.
1134 expot_control%scaling_factor = 1.0_dp
1142 SUBROUTINE expot_control_release(expot_control)
1145 IF (
ASSOCIATED(expot_control))
THEN
1146 DEALLOCATE (expot_control)
1149 END SUBROUTINE expot_control_release
1158 cpassert(.NOT.
ASSOCIATED(maxwell_control))
1159 ALLOCATE (maxwell_control)
1167 SUBROUTINE maxwell_control_release(maxwell_control)
1170 IF (
ASSOCIATED(maxwell_control))
THEN
1171 DEALLOCATE (maxwell_control)
1174 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.