149 REAL(kind=
dp) :: eps_pao = 0.0_dp
150 REAL(kind=
dp) :: cg_reset_limit = 0.1_dp
151 REAL(kind=
dp) :: mixing = 0.0_dp
152 REAL(kind=
dp) :: regularization = 0.0_dp
153 REAL(kind=
dp) :: penalty_dist = 0.0_dp
154 REAL(kind=
dp) :: penalty_strength = 0.0_dp
155 REAL(kind=
dp) :: check_unitary_tol = 0.0_dp
156 REAL(kind=
dp) :: check_grad_tol = 0.0_dp
157 REAL(kind=
dp) :: num_grad_eps = 0.0_dp
158 REAL(kind=
dp) :: eps_pgf = 0.0_dp
159 REAL(kind=
dp) :: linpot_precon_delta = 0.0_dp
160 REAL(kind=
dp) :: linpot_init_delta = 0.0_dp
161 REAL(kind=
dp) :: linpot_regu_delta = 0.0_dp
162 REAL(kind=
dp) :: linpot_regu_strength = 0.0_dp
163 INTEGER :: num_grad_order = -1
164 INTEGER :: max_pao = -1
165 INTEGER :: max_cycles = -1
166 INTEGER :: write_cycles = -1
167 INTEGER :: parameterization = -1
168 INTEGER :: optimizer = -1
169 INTEGER :: cg_init_steps = -1
170 LOGICAL :: precondition = .false.
171 LOGICAL :: ignore_convergence_failure = .false.
172 CHARACTER(LEN=default_path_length) :: preopt_dm_file =
""
173 CHARACTER(LEN=default_path_length) :: restart_file =
""
174 TYPE(filename_type),
DIMENSION(:),
ALLOCATABLE :: ml_training_set
176 INTEGER :: ml_method = -1
177 INTEGER :: ml_prior = -1
178 INTEGER :: ml_descriptor = -1
179 REAL(kind=
dp) :: ml_tolerance = 0.0_dp
180 REAL(kind=
dp) :: gp_noise_var = 0.0_dp
181 REAL(kind=
dp) :: gp_scale = 0.0_dp
185 INTEGER :: iw_atoms = -1
186 INTEGER :: iw_gap = -1
187 INTEGER :: iw_fockev = -1
188 INTEGER :: iw_opt = -1
189 INTEGER :: iw_mlvar = -1
190 INTEGER :: iw_mldata = -1
193 INTEGER :: istep = -1
194 REAL(kind=
dp) :: energy_prev = 0.0_dp
195 REAL(kind=
dp) :: step_start_time = 0.0_dp
196 REAL(kind=
dp) :: norm_g = 0.0_dp
198 LOGICAL :: matrix_x_ready = .false.
199 LOGICAL :: matrix_p_ready = .false.
200 LOGICAL :: constants_ready = .false.
201 LOGICAL :: need_initial_scf = .false.
224 DIMENSION(:) :: ml_training_matrices
227 DIMENSION(:) :: models
241 CHARACTER(len=*),
PARAMETER :: routinen =
'pao_finalize'
245 CALL timeset(routinen, handle)
255 DEALLOCATE (pao%ml_training_set)
256 IF (
ALLOCATED(pao%ml_training_matrices)) &
257 DEALLOCATE (pao%ml_training_matrices)
259 IF (
ALLOCATED(pao%models))
THEN
260 DO i = 1,
SIZE(pao%models)
261 IF (pao%models(i)%version > 0)
THEN
264 CALL omp_destroy_lock(pao%models(i)%lock)
266 DEALLOCATE (pao%models)
273 CALL timestop(handle)