(git:1f9fd2c)
Loading...
Searching...
No Matches
rt_propagation.F
Go to the documentation of this file.
1!--------------------------------------------------------------------------------------------------!
2! CP2K: A general program to perform molecular dynamics simulations !
3! Copyright 2000-2026 CP2K developers group <https://cp2k.org> !
4! !
5! SPDX-License-Identifier: GPL-2.0-or-later !
6!--------------------------------------------------------------------------------------------------!
7
8! **************************************************************************************************
9!> \brief Routines for the real time propagation.
10!> \author Florian Schiffmann (02.09)
11! **************************************************************************************************
12
14 USE bibliography, ONLY: andermatt2016,&
15 cite_reference
16 USE cell_types, ONLY: cell_type
19 USE cp_dbcsr_api, ONLY: dbcsr_copy,&
25 USE cp_fm_types, ONLY: cp_fm_set_all,&
35 cp_p_file,&
56 USE kinds, ONLY: default_path_length,&
57 dp
58 USE machine, ONLY: m_walltime
61 USE pw_env_types, ONLY: pw_env_type
71 USE qs_ks_types, ONLY: qs_ks_did_change,&
75 USE qs_mo_types, ONLY: get_mo_set,&
80 USE qs_rho_types, ONLY: qs_rho_set,&
88 print_ft,&
91 USE rt_propagation_types, ONLY: get_rtp,&
106#include "../base/base_uses.f90"
107
108 IMPLICIT NONE
109
110 PRIVATE
111
112 CHARACTER(len=*), PARAMETER, PRIVATE :: moduleN = 'rt_propagation'
113
114 PUBLIC :: rt_prop_setup
115
116CONTAINS
117
118! **************************************************************************************************
119!> \brief creates rtp_type, gets the initial state, either by reading MO's
120!> from file or calling SCF run
121!> \param force_env ...
122!> \author Florian Schiffmann (02.09)
123! **************************************************************************************************
124
125 SUBROUTINE rt_prop_setup(force_env)
126 TYPE(force_env_type), POINTER :: force_env
127
128 INTEGER :: aspc_order
129 LOGICAL :: magnetic, vel_reprs
130 TYPE(dft_control_type), POINTER :: dft_control
131 TYPE(global_environment_type), POINTER :: globenv
132 TYPE(qs_energy_type), POINTER :: energy
133 TYPE(qs_environment_type), POINTER :: qs_env
134 TYPE(rt_prop_type), POINTER :: rtp
135 TYPE(rtp_control_type), POINTER :: rtp_control
136 TYPE(section_vals_type), POINTER :: hfx_sections, input, ls_scf_section, md_section, &
137 motion_section, print_moments_section, rtp_print_section, rtp_section
138
139 NULLIFY (qs_env, rtp_control, dft_control)
140
141 CALL cite_reference(andermatt2016)
142
143 CALL force_env_get(force_env=force_env, qs_env=qs_env, globenv=globenv)
144 CALL get_qs_env(qs_env, dft_control=dft_control, energy=energy)
145 rtp_control => dft_control%rtp_control
146
147 ! Takes care that an initial wavefunction/density is available
148 ! Can either be by performing an scf loop or reading a restart
149 CALL rt_initial_guess(qs_env, force_env, rtp_control)
150
151 ! Initializes the extrapolation
152 NULLIFY (rtp)
153 CALL get_qs_env(qs_env=qs_env, rtp=rtp, input=input)
154 aspc_order = rtp_control%aspc_order
155 CALL rtp_history_create(rtp, aspc_order)
156
157 ! Reads the simulation parameters from the input
158 motion_section => section_vals_get_subs_vals(force_env%root_section, "MOTION")
159 md_section => section_vals_get_subs_vals(motion_section, "MD")
160 hfx_sections => section_vals_get_subs_vals(force_env%root_section, "FORCE_EVAL%DFT%XC%HF")
161 rtp_section => section_vals_get_subs_vals(force_env%root_section, "FORCE_EVAL%DFT%REAL_TIME_PROPAGATION")
162 print_moments_section => section_vals_get_subs_vals(force_env%root_section, "FORCE_EVAL%DFT%PRINT%MOMENTS")
163 CALL section_vals_val_get(md_section, "TIMESTEP", r_val=qs_env%rtp%dt)
164 CALL section_vals_val_get(md_section, "STEP_START_VAL", i_val=qs_env%rtp%i_start)
165 CALL section_vals_val_get(md_section, "STEPS", i_val=rtp%nsteps)
166 CALL section_vals_val_get(md_section, "MAX_STEPS", i_val=rtp%max_steps)
167
168 ls_scf_section => section_vals_get_subs_vals(input, "DFT%LS_SCF")
169 CALL section_vals_val_get(ls_scf_section, "EPS_FILTER", r_val=rtp%filter_eps)
170 IF (.NOT. qs_env%rtp%linear_scaling) rtp%filter_eps = 0.0_dp
171 IF (rtp_control%acc_ref < 1) rtp_control%acc_ref = 1
172 rtp%filter_eps_small = rtp%filter_eps/rtp_control%acc_ref
173 CALL section_vals_val_get(ls_scf_section, "EPS_LANCZOS", r_val=rtp%lanzcos_threshold)
174 CALL section_vals_val_get(ls_scf_section, "MAX_ITER_LANCZOS", i_val=rtp%lanzcos_max_iter)
175 CALL section_vals_val_get(ls_scf_section, "SIGN_SQRT_ORDER", i_val=rtp%newton_schulz_order)
176 CALL section_vals_get(hfx_sections, explicit=rtp%do_hfx)
177 CALL section_vals_val_get(print_moments_section, "MAGNETIC", l_val=magnetic)
178 CALL section_vals_val_get(print_moments_section, "VEL_REPRS", l_val=vel_reprs)
179
180 rtp%track_imag_density = (magnetic) .OR. (vel_reprs) .OR. (rtp_control%velocity_gauge) &
181 .OR. (rtp%do_hfx) .OR. (.NOT. rtp_control%fixed_ions)
182 rtp%propagate_complex_ks = rtp%do_hfx .OR. rtp_control%velocity_gauge
183
184 ! Marek : In case some print sections that apply so far only to RTBSE are present,
185 ! warn the user that the quantities will not be in fact printed out
186 rtp_print_section => section_vals_get_subs_vals(rtp_section, "PRINT")
187 CALL warn_section_unused(rtp_print_section, "DENSITY_MATRIX", &
188 "DENSITY_MATRIX printing not implemented for non-RTBSE code.")
189
190 CALL rt_init_complex_quantities(qs_env, imag_p=rtp%track_imag_density, &
191 imag_ks=rtp%propagate_complex_ks, imag_h=rtp_control%velocity_gauge)
192
193 IF (rtp_control%save_local_moments) CALL rt_init_local_moments(rtp, qs_env)
194
195 ! Hmm, not really like to initialize with the structure of S but I reckon it is
196 ! done everywhere like this
197 IF (rtp%do_hfx) CALL rtp_hfx_rebuild(qs_env)
198
199 ! Setup the MO projection environment if required
200 IF (rtp_control%is_proj_mo) CALL init_mo_projection(qs_env, rtp_control)
201
202 CALL init_propagation_run(qs_env)
203 IF (.NOT. rtp_control%fixed_ions) THEN
204 !derivativs of the overlap needed for EMD
205 CALL calc_s_derivs(qs_env)
206 ! a bit hidden, but computes SinvH and SinvB (calc_SinvH for CN,EM and ARNOLDI)
207 ! make_etrs_exp in case of ETRS in combination with TAYLOR and PADE
208 END IF
209 CALL init_propagators(qs_env)
210 IF (rtp_control%fixed_ions) THEN
211 CALL run_propagation(qs_env, force_env, globenv)
212 ELSE
213 rtp_control%initial_step = .true.
214 CALL force_env_calc_energy_force(force_env, calc_force=.true.)
215 rtp_control%initial_step = .false.
216 rtp%energy_old = energy%total
217 END IF
218
219 IF (rtp_control%save_local_moments) THEN
220 ! Call routines for outputs and deallocations of FT observables
221 CALL final_ft_output(qs_env)
222 END IF
223
224 IF (ASSOCIATED(rtp_control%print_pol_elements)) DEALLOCATE (rtp_control%print_pol_elements)
225
226 END SUBROUTINE rt_prop_setup
227
228! **************************************************************************************************
229!> \brief calculates the matrices needed in the first step of EMD/RTP
230!> \param qs_env ...
231!> \author Florian Schiffmann (02.09)
232! **************************************************************************************************
233
234 SUBROUTINE init_propagation_run(qs_env)
235 TYPE(qs_environment_type), POINTER :: qs_env
236
237 REAL(kind=dp), PARAMETER :: zero = 0.0_dp
238
239 INTEGER :: i, ispin, re
240 INTEGER, DIMENSION(2) :: nelectron_spin
241 TYPE(cp_fm_type), DIMENSION(:), POINTER :: mos_new, mos_old
242 TYPE(dbcsr_p_type), DIMENSION(:), POINTER :: matrix_ks, rho_new, rho_old
243 TYPE(dft_control_type), POINTER :: dft_control
244 TYPE(mo_set_type), DIMENSION(:), POINTER :: mos
245 TYPE(rt_prop_type), POINTER :: rtp
246 TYPE(rtp_control_type), POINTER :: rtp_control
247
248 NULLIFY (dft_control, rtp, rtp_control)
249
250 CALL cite_reference(andermatt2016)
251
252 CALL get_qs_env(qs_env, &
253 rtp=rtp, &
254 dft_control=dft_control)
255 rtp_control => dft_control%rtp_control
256
257 IF (rtp_control%initial_wfn == use_scf_wfn) THEN
258 IF (rtp_control%apply_delta_pulse .OR. rtp_control%apply_delta_pulse_mag) THEN
259 CALL apply_delta_pulse(qs_env, rtp, rtp_control)
260 ELSE
261 IF (.NOT. rtp%linear_scaling) THEN
262 CALL get_rtp(rtp=rtp, mos_old=mos_old)
263 CALL get_qs_env(qs_env, mos=mos)
264 DO i = 1, SIZE(mos)
265 CALL cp_fm_to_fm(mos(i)%mo_coeff, mos_old(2*i - 1))
266 CALL cp_fm_set_all(mos_old(2*i), zero, zero)
267 END DO
268 END IF
269 END IF
270 END IF
271
272 IF (.NOT. rtp%linear_scaling) THEN
273 CALL get_rtp(rtp=rtp, mos_old=mos_old, mos_new=mos_new)
274 DO i = 1, SIZE(mos_old)
275 CALL cp_fm_to_fm(mos_old(i), mos_new(i))
276 END DO
277 CALL calc_update_rho(qs_env)
278 ELSE
279 IF (rtp_control%initial_wfn == use_scf_wfn) THEN
280 CALL get_qs_env(qs_env, &
281 matrix_ks=matrix_ks, &
282 mos=mos, &
283 nelectron_spin=nelectron_spin)
284 IF (ASSOCIATED(mos)) THEN
285 !The wavefunction was minimized by an mo based algorith. P is therefore calculated from the mos
286 IF (ASSOCIATED(rtp%mos)) THEN
287 IF (ASSOCIATED(rtp%mos%old)) THEN
288 ! Delta kick was applied and the results is in rtp%mos%old
289 CALL rt_initialize_rho_from_mos(rtp, mos, mos_old=rtp%mos%old)
290 ELSE
291 CALL rt_initialize_rho_from_mos(rtp, mos)
292 END IF
293 ELSE
294 CALL rt_initialize_rho_from_mos(rtp, mos)
295 END IF
296 ELSE
297 !The wavefunction was minimized using a linear scaling method. The density matrix is therefore taken from the ls_scf_env.
298 CALL get_rtp(rtp=rtp, rho_old=rho_old, rho_new=rho_new)
299 DO ispin = 1, SIZE(rho_old)/2
300 re = 2*ispin - 1
301 CALL dbcsr_copy(rho_old(re)%matrix, qs_env%ls_scf_env%matrix_p(ispin))
302 CALL dbcsr_copy(rho_new(re)%matrix, qs_env%ls_scf_env%matrix_p(ispin))
303 END DO
304 END IF
305 CALL calc_update_rho_sparse(qs_env)
306 END IF
307 END IF
308 ! Modify KS matrix to include the additional terms in the velocity gauge
309 IF (rtp_control%velocity_gauge) THEN
310 ! As matrix_h and matrix_h_im are not updated by qs_ks_update_qs_env()
311 ! the non-gauge transformed non-local part has to be subtracted here
312 CALL velocity_gauge_ks_matrix(qs_env, subtract_nl_term=.true.)
313 END IF
314 CALL qs_ks_update_qs_env(qs_env, calculate_forces=.false.)
315
316 END SUBROUTINE init_propagation_run
317
318! **************************************************************************************************
319!> \brief performs the real RTP run, gets information from MD section
320!> uses MD as iteration level
321!> \param qs_env ...
322!> \param force_env ...
323!> \param globenv ...
324!> \author Florian Schiffmann (02.09)
325! **************************************************************************************************
326
327 SUBROUTINE run_propagation(qs_env, force_env, globenv)
328 TYPE(qs_environment_type), POINTER :: qs_env
329 TYPE(force_env_type), POINTER :: force_env
330 TYPE(global_environment_type), POINTER :: globenv
331
332 CHARACTER(len=*), PARAMETER :: routinen = 'run_propagation'
333
334 INTEGER :: aspc_order, handle, i_iter, i_step, &
335 max_iter, max_steps, output_unit, &
336 unit_nr
337 LOGICAL :: moments_read, should_stop
338 REAL(kind=dp) :: eps_ener, time_iter_start, &
339 time_iter_stop, used_time
340 TYPE(cp_logger_type), POINTER :: logger
341 TYPE(dbcsr_p_type), DIMENSION(:), POINTER :: rho_new
342 TYPE(dft_control_type), POINTER :: dft_control
343 TYPE(pw_env_type), POINTER :: pw_env
344 TYPE(qs_energy_type), POINTER :: energy
345 TYPE(rt_prop_type), POINTER :: rtp
346 TYPE(rtp_control_type), POINTER :: rtp_control
347 TYPE(section_vals_type), POINTER :: input, moments_section, rtp_section
348
349 should_stop = .false.
350 CALL timeset(routinen, handle)
351
352 CALL cite_reference(andermatt2016)
353
354 NULLIFY (logger, dft_control, energy, rtp, rtp_control, input, rtp_section)
355 logger => cp_get_default_logger()
356 IF (logger%para_env%is_source()) THEN
357 unit_nr = cp_logger_get_default_unit_nr(logger, local=.true.)
358 ELSE
359 unit_nr = -1
360 END IF
361
362 CALL get_qs_env(qs_env=qs_env, dft_control=dft_control, rtp=rtp, energy=energy, input=input)
363
364 rtp_control => dft_control%rtp_control
365 max_steps = min(rtp%nsteps, rtp%max_steps)
366 max_iter = rtp_control%max_iter
367 eps_ener = rtp_control%eps_ener
368
369 aspc_order = rtp_control%aspc_order
370
371 rtp%energy_old = energy%total
372 time_iter_start = m_walltime()
373 CALL cp_add_iter_level(logger%iter_info, "MD")
374 CALL cp_iterate(logger%iter_info, iter_nr=0)
375 IF (rtp%i_start >= max_steps) CALL cp_abort(__location__, &
376 "maximum step number smaller than initial step value")
377
378 rtp_section => section_vals_get_subs_vals(input, "DFT%REAL_TIME_PROPAGATION")
379 output_unit = cp_print_key_unit_nr(logger, rtp_section, "PRINT%PROGRAM_RUN_INFO", &
380 extension=".scfLog")
381 ! Add the zero iteration moments to the moment trace
382 IF (rtp_control%save_local_moments) THEN
383 CALL get_rtp(rtp, rho_new=rho_new)
384 moments_section => section_vals_get_subs_vals(rtp_section, "PRINT%MOMENTS")
385 ! TODO : Conditions on when not to read the files
386 CALL read_moments(moments_section, 0, rtp%i_start, rtp%moments, rtp%times, moments_read)
387 ! Recalculate the field at times in the trace/Read the field from the files
388 CALL recalculate_fields(rtp%fields, rtp%times, 0, rtp%i_start, dft_control)
389 IF (.NOT. moments_read) THEN
390 CALL calc_local_moment(rtp%local_moments, rho_new, rtp%local_moments_work, rtp%moments(:, :, 1))
391 qs_env%sim_time = real(rtp%i_start, dp)*rtp%dt
392 rtp%times(1) = qs_env%sim_time
393 CALL print_moments(moments_section, output_unit, rtp%moments(:, :, 1), &
394 qs_env%sim_time, rtp%track_imag_density)
395 END IF
396 END IF
397
398 DO i_step = rtp%i_start + 1, max_steps
399 IF (output_unit > 0) THEN
400 WRITE (output_unit, fmt="(/,(T2,A,T40,I6))") &
401 "Real time propagation step:", i_step
402 END IF
403 energy%efield_core = 0.0_dp
404 qs_env%sim_time = real(i_step, dp)*rtp%dt
405 CALL get_qs_env(qs_env, pw_env=pw_env)
406 pw_env%poisson_env%parameters%dbc_params%time = qs_env%sim_time
407 qs_env%sim_step = i_step
408 rtp%istep = i_step - rtp%i_start
409 CALL calculate_ecore_efield(qs_env, .false.)
410 IF (dft_control%apply_external_potential) THEN
411 IF (.NOT. dft_control%expot_control%static) THEN
412 dft_control%eval_external_potential = .true.
413 END IF
414 END IF
415 CALL external_c_potential(qs_env, calculate_forces=.false.)
416 CALL external_e_potential(qs_env)
417 CALL cp_iterate(logger%iter_info, last=(i_step == max_steps), iter_nr=i_step)
418 rtp%converged = .false.
419 DO i_iter = 1, max_iter
420 IF (i_step == rtp%i_start + 1 .AND. i_iter == 2 .AND. rtp_control%hfx_redistribute) &
421 CALL qs_ks_did_change(qs_env%ks_env, s_mstruct_changed=.true.)
422 rtp%iter = i_iter
423 CALL propagation_step(qs_env, rtp, rtp_control)
424 CALL qs_ks_update_qs_env(qs_env, calculate_forces=.false.)
425 rtp%energy_new = energy%total
426 IF (rtp%converged) EXIT
427 CALL rt_prop_output(qs_env, real_time_propagation, rtp%delta_iter)
428 END DO
429 IF (rtp%converged) THEN
430 CALL external_control(should_stop, "MD", globenv=globenv)
431 IF (should_stop) CALL cp_iterate(logger%iter_info, last=.true., iter_nr=i_step)
432 time_iter_stop = m_walltime()
433 used_time = time_iter_stop - time_iter_start
434 time_iter_start = time_iter_stop
435 CALL rt_prop_output(qs_env, real_time_propagation, delta_iter=rtp%delta_iter, used_time=used_time)
436 CALL rt_write_input_restart(force_env=force_env, qs_env=qs_env)
437 IF (modulo(i_step, dft_control%localize_each) == 0) THEN
438 CALL rtp_localize(qs_env, rtp)
439 END IF
440 IF (should_stop) EXIT
441 ELSE
442 EXIT
443 END IF
444 END DO
445 CALL cp_rm_iter_level(logger%iter_info, "MD")
446
447 IF (.NOT. rtp%converged) &
448 CALL cp_abort(__location__, "propagation did not converge, "// &
449 "either increase MAX_ITER or use a smaller TIMESTEP")
450
451 CALL timestop(handle)
452
453 END SUBROUTINE run_propagation
454
455! **************************************************************************************************
456!> \brief overwrites some values in the input file such that the .restart
457!> file will contain the appropriate information
458!> \param md_env ...
459!> \param qs_env ...
460!> \param force_env ...
461!> \author Florian Schiffmann (02.09)
462! **************************************************************************************************
463
464 SUBROUTINE rt_write_input_restart(md_env, qs_env, force_env)
465 TYPE(md_environment_type), OPTIONAL, POINTER :: md_env
466 TYPE(qs_environment_type), OPTIONAL, POINTER :: qs_env
467 TYPE(force_env_type), POINTER :: force_env
468
469 CHARACTER(len=default_path_length) :: file_name
470 REAL(kind=dp), DIMENSION(:), POINTER :: tmp_vals
471 TYPE(cp_logger_type), POINTER :: logger
472 TYPE(dft_control_type), POINTER :: dft_control
473 TYPE(section_vals_type), POINTER :: dft_section, efield_section, &
474 motion_section, print_key, &
475 root_section, rt_section
476
477 CALL get_qs_env(qs_env=qs_env, dft_control=dft_control)
478 root_section => force_env%root_section
479 motion_section => section_vals_get_subs_vals(root_section, "MOTION")
480 dft_section => section_vals_get_subs_vals(root_section, "FORCE_EVAL%DFT")
481 rt_section => section_vals_get_subs_vals(root_section, "FORCE_EVAL%DFT%REAL_TIME_PROPAGATION")
482
483 CALL section_vals_val_set(rt_section, "INITIAL_WFN", i_val=use_rt_restart)
484 CALL section_vals_val_set(rt_section, "APPLY_DELTA_PULSE", l_val=.false.)
485 CALL section_vals_val_set(rt_section, "APPLY_DELTA_PULSE_MAG", l_val=.false.)
486 CALL section_vals_val_set(rt_section, "APPLY_WFN_MIX_INIT_RESTART", l_val=.false.)
487
488 logger => cp_get_default_logger()
489
490 ! to continue propagating the TD wavefunction we need to read from the new .rtpwfn
491 IF (btest(cp_print_key_should_output(logger%iter_info, &
492 rt_section, "PRINT%RESTART"), cp_p_file)) THEN
493 print_key => section_vals_get_subs_vals(rt_section, "PRINT%RESTART")
494 file_name = cp_print_key_generate_filename(logger, print_key, &
495 extension=".rtpwfn", my_local=.false.)
496 CALL section_vals_val_set(dft_section, "WFN_RESTART_FILE_NAME", c_val=trim(file_name))
497 END IF
498
499 ! coming from RTP
500 IF (.NOT. PRESENT(md_env)) THEN
501 CALL section_vals_val_set(motion_section, "MD%STEP_START_VAL", i_val=force_env%qs_env%sim_step)
502 END IF
503
504 IF (dft_control%apply_vector_potential) THEN
505 efield_section => section_vals_get_subs_vals(root_section, "FORCE_EVAL%DFT%EFIELD")
506 NULLIFY (tmp_vals)
507 ALLOCATE (tmp_vals(3))
508 tmp_vals = dft_control%efield_fields(1)%efield%vec_pot_initial
509 CALL section_vals_val_set(efield_section, "VEC_POT_INITIAL", &
510 r_vals_ptr=tmp_vals, &
511 i_rep_section=1)
512 END IF
513
514 CALL write_restart(md_env=md_env, root_section=root_section)
515
516 END SUBROUTINE rt_write_input_restart
517
518! **************************************************************************************************
519!> \brief Creates the initial electronic states and allocates the necessary
520!> matrices
521!> \param qs_env ...
522!> \param force_env ...
523!> \param rtp_control ...
524!> \author Florian Schiffmann (02.09)
525! **************************************************************************************************
526
527 SUBROUTINE rt_initial_guess(qs_env, force_env, rtp_control)
528 TYPE(qs_environment_type), POINTER :: qs_env
529 TYPE(force_env_type), POINTER :: force_env
530 TYPE(rtp_control_type), POINTER :: rtp_control
531
532 INTEGER :: homo, ispin
533 LOGICAL :: energy_consistency
534 TYPE(cp_fm_type), POINTER :: mo_coeff
535 TYPE(dbcsr_p_type), DIMENSION(:), POINTER :: matrix_s
536 TYPE(dft_control_type), POINTER :: dft_control
537
538 NULLIFY (matrix_s, dft_control)
539 CALL get_qs_env(qs_env, dft_control=dft_control)
540 cpassert(ASSOCIATED(qs_env))
541
542 SELECT CASE (rtp_control%initial_wfn)
543 CASE (use_scf_wfn)
544 qs_env%sim_time = 0.0_dp
545 qs_env%sim_step = 0
546 energy_consistency = .true.
547 !in the linear scaling case we need a correct kohn-sham matrix, which we cannot get with consistent energies
548 IF (rtp_control%linear_scaling) energy_consistency = .false.
549 CALL force_env_calc_energy_force(force_env, calc_force=.false., &
550 consistent_energies=energy_consistency)
551 qs_env%run_rtp = .true.
552 ALLOCATE (qs_env%rtp)
553 CALL get_qs_env(qs_env, matrix_s=matrix_s)
554 IF (dft_control%do_admm) THEN
555 CALL hfx_admm_init(qs_env)
556 CALL rt_prop_create(qs_env%rtp, qs_env%mos, qs_env%mpools, dft_control, matrix_s(1)%matrix, &
557 rtp_control%linear_scaling, qs_env%admm_env%mos_aux_fit)
558 ELSE
559 CALL rt_prop_create(qs_env%rtp, qs_env%mos, qs_env%mpools, dft_control, matrix_s(1)%matrix, &
560 rtp_control%linear_scaling)
561 END IF
562
564 CALL qs_energies_init(qs_env, .false.)
565 IF (.NOT. rtp_control%linear_scaling .OR. rtp_control%initial_wfn == use_restart_wfn) THEN
566 DO ispin = 1, SIZE(qs_env%mos)
567 CALL get_mo_set(qs_env%mos(ispin), mo_coeff=mo_coeff, homo=homo)
568 IF (.NOT. ASSOCIATED(mo_coeff)) THEN
569 CALL init_mo_set(qs_env%mos(ispin), &
570 qs_env%mpools%ao_mo_fm_pools(ispin)%pool, &
571 name="qs_env%mo"//trim(adjustl(cp_to_string(ispin))))
572 END IF
573 END DO
574 IF (dft_control%do_admm) CALL hfx_admm_init(qs_env)
575 END IF
576 ALLOCATE (qs_env%rtp)
577 CALL get_qs_env(qs_env, matrix_s=matrix_s)
578 CALL rt_prop_create(qs_env%rtp, qs_env%mos, qs_env%mpools, dft_control, matrix_s(1)%matrix, &
579 rtp_control%linear_scaling, qs_env%admm_env%mos_aux_fit)
580 CALL get_restart_wfn(qs_env)
581 cpassert(ASSOCIATED(qs_env))
582
583 qs_env%run_rtp = .true.
584 END SELECT
585
586 END SUBROUTINE rt_initial_guess
587
588! **************************************************************************************************
589!> \brief ...
590!> \param qs_env ...
591!> \param imag_p ...
592!> \param imag_ks ...
593!> \param imag_h ...
594! **************************************************************************************************
595 SUBROUTINE rt_init_complex_quantities(qs_env, imag_p, imag_ks, imag_h)
596 TYPE(qs_environment_type), POINTER :: qs_env
597 LOGICAL, INTENT(in) :: imag_p, imag_ks, imag_h
598
599 TYPE(dft_control_type), POINTER :: dft_control
600 TYPE(qs_ks_env_type), POINTER :: ks_env
601 TYPE(qs_rho_type), POINTER :: rho
602 TYPE(rt_prop_type), POINTER :: rtp
603
604 NULLIFY (ks_env, rho, dft_control)
605
606 CALL get_qs_env(qs_env, &
607 dft_control=dft_control, &
608 ks_env=ks_env, &
609 rho=rho, &
610 rtp=rtp)
611
612 ! rho
613 CALL qs_rho_set(rho, complex_rho_ao=imag_p)
614 IF (imag_p) CALL allocate_rho_ao_imag_from_real(rho, qs_env)
615
616 ! ks
617 CALL set_ks_env(ks_env, complex_ks=imag_ks)
618 IF (imag_ks) THEN
619 CALL qs_ks_allocate_basics(qs_env, is_complex=imag_ks)
620 IF (.NOT. dft_control%rtp_control%fixed_ions) &
621 CALL rtp_create_sinvh_imag(rtp, dft_control%nspins)
622 END IF
623
624 ! h
625 IF (imag_h) CALL qs_matrix_h_allocate_imag_from_real(qs_env)
626
627 END SUBROUTINE rt_init_complex_quantities
628
629! **************************************************************************************************
630!> \brief Allocates and fills the local moment matrices (only available for linear scaling)
631!> \param rtp Real time propagtion properties - local moment matrices are stored there
632!> \param qs_env QS environment necessary for moment matrix calculation
633! **************************************************************************************************
634 SUBROUTINE rt_init_local_moments(rtp, qs_env)
635 TYPE(rt_prop_type), POINTER :: rtp
636 TYPE(qs_environment_type), POINTER :: qs_env
637
638 INTEGER :: k, nspin, output_unit
639 REAL(kind=dp), DIMENSION(3) :: reference_point
640 TYPE(cp_logger_type), POINTER :: logger
641 TYPE(dbcsr_p_type), DIMENSION(:), POINTER :: matrix_s, rho_old
642 TYPE(dft_control_type), POINTER :: dft_control
643 TYPE(rtp_control_type), POINTER :: rtc
644 TYPE(section_vals_type), POINTER :: input, moments_section
645
646 logger => cp_get_default_logger()
647 output_unit = cp_logger_get_default_io_unit(logger)
648
649 CALL get_qs_env(qs_env, dft_control=dft_control, matrix_s=matrix_s, input=input)
650 rtc => dft_control%rtp_control
651 moments_section => section_vals_get_subs_vals(input, &
652 "DFT%REAL_TIME_PROPAGATION%PRINT%MOMENTS")
653
654 ! Construct the local moments matrix - copy from matrix_s structure
655 ! NOTE : construction where blocks are allocated by neighbour lists does not seem to work,
656 ! so doing a copy instead of:
657 ! CALL dbcsr_create(rtp%local_moments(k)%matrix, template=matrix_s(1)%matrix, &
658 ! name="Local moment")
659 ! CALL cp_dbcsr_alloc_block_from_nbl(rtp%local_moments(k)%matrix, sab_all)
660 NULLIFY (rtp%local_moments)
661 ALLOCATE (rtp%local_moments(3))
662 DO k = 1, 3
663 NULLIFY (rtp%local_moments(k)%matrix)
664 ALLOCATE (rtp%local_moments(k)%matrix)
665 CALL dbcsr_create(rtp%local_moments(k)%matrix, template=matrix_s(1)%matrix, name="Local moment")
666 CALL dbcsr_copy(rtp%local_moments(k)%matrix, matrix_s(1)%matrix)
667 CALL dbcsr_set(rtp%local_moments(k)%matrix, 0.0_dp)
668 END DO
669 ! Workspace allocation
670 NULLIFY (rtp%local_moments_work)
671 ALLOCATE (rtp%local_moments_work)
672 CALL dbcsr_create(rtp%local_moments_work, template=rtp%local_moments(1)%matrix, name="tmp")
673 CALL dbcsr_copy(rtp%local_moments_work, rtp%local_moments(1)%matrix)
674
675 CALL get_reference_point(rpoint=reference_point, qs_env=qs_env, &
676 reference=rtc%moment_trace_ref_type, ref_point=rtc%moment_trace_user_ref_point)
677
678 CALL build_local_moment_matrix(qs_env, rtp%local_moments, 1, reference_point)
679
680 ! Allocate the moments trace and output start moments
681 CALL get_rtp(rtp, rho_old=rho_old)
682 nspin = SIZE(rho_old)/2
683 ALLOCATE (rtp%moments(SIZE(rho_old)/2, 3, rtp%nsteps + 1), source=cmplx(0.0, 0.0, kind=dp))
684 NULLIFY (rtp%times)
685 ALLOCATE (rtp%times(rtp%nsteps + 1))
686 NULLIFY (rtp%fields)
687 ALLOCATE (rtp%fields(3, rtp%nsteps + 1), source=cmplx(0.0, 0.0, kind=dp))
688
689 END SUBROUTINE rt_init_local_moments
690
691! **************************************************************************************************
692!> \brief Allocates and fills the local moment matrices (only available for linear scaling)
693!> \param qs_env QS environment necessary for moment matrix calculation
694! **************************************************************************************************
695 SUBROUTINE final_ft_output(qs_env)
696 TYPE(qs_environment_type), POINTER :: qs_env
697
698 INTEGER :: k, unit_nr
699 TYPE(cell_type), POINTER :: cell
700 TYPE(cp_logger_type), POINTER :: logger
701 TYPE(dft_control_type), POINTER :: dft_control
702 TYPE(rt_prop_type), POINTER :: rtp
703 TYPE(section_vals_type), POINTER :: input, rtp_section
704
705 CALL get_qs_env(qs_env, cell=cell, rtp=rtp, input=input, dft_control=dft_control)
706 rtp_section => section_vals_get_subs_vals(input, "DFT%REAL_TIME_PROPAGATION")
707 logger => cp_get_default_logger()
708 unit_nr = cp_logger_get_default_io_unit(logger)
709 CALL print_ft(rtp_section, rtp%moments, rtp%times, rtp%fields, dft_control%rtp_control, &
710 info_opt=unit_nr, cell=cell)
711 ! Deallocating the local moments matrices and array
712 DO k = 1, 3
713 CALL dbcsr_release(rtp%local_moments(k)%matrix)
714 DEALLOCATE (rtp%local_moments(k)%matrix)
715 END DO
716 DEALLOCATE (rtp%local_moments)
717 CALL dbcsr_release(rtp%local_moments_work)
718 DEALLOCATE (rtp%local_moments_work)
719 DEALLOCATE (rtp%moments)
720 DEALLOCATE (rtp%times)
721 DEALLOCATE (rtp%fields)
722 END SUBROUTINE final_ft_output
723
724END MODULE rt_propagation
static GRID_HOST_DEVICE int modulo(int a, int m)
Equivalent of Fortran's MODULO, which always return a positive number. https://gcc....
collects all references to literature in CP2K as new algorithms / method are included from literature...
integer, save, public andermatt2016
Handles all functions related to the CELL.
Definition cell_types.F:15
Defines control structures, which contain the parameters and the settings for the DFT-based calculati...
subroutine, public dbcsr_copy(matrix_b, matrix_a, name, keep_sparsity, keep_imaginary)
...
subroutine, public dbcsr_set(matrix, alpha)
...
subroutine, public dbcsr_release(matrix)
...
Routines to handle the external control of CP2K.
subroutine, public external_control(should_stop, flag, globenv, target_time, start_time, force_check)
External manipulations during a run : when the <PROJECT_NAME>.EXIT_$runtype command is sent the progr...
represent a full matrix distributed on many processors
Definition cp_fm_types.F:15
subroutine, public cp_fm_set_all(matrix, alpha, beta)
set all elements of a matrix to the same value, and optionally the diagonal to a different one
various routines to log and control the output. The idea is that decisions about where to log should ...
recursive integer function, public cp_logger_get_default_unit_nr(logger, local, skip_not_ionode)
asks the default unit number of the given logger. try to use cp_logger_get_unit_nr
integer function, public cp_logger_get_default_io_unit(logger)
returns the unit nr for the ionode (-1 on all other processors) skips as well checks if the procs cal...
type(cp_logger_type) function, pointer, public cp_get_default_logger()
returns the default logger
routines to handle the output, The idea is to remove the decision of wheter to output and what to out...
integer function, public cp_print_key_unit_nr(logger, basis_section, print_key_path, extension, middle_name, local, log_filename, ignore_should_output, file_form, file_position, file_action, file_status, do_backup, on_file, is_new_file, mpi_io, fout)
...
character(len=default_path_length) function, public cp_print_key_generate_filename(logger, print_key, middle_name, extension, my_local)
Utility function that returns a unit number to write the print key. Might open a file with a unique f...
integer, parameter, public cp_p_file
subroutine, public cp_iterate(iteration_info, last, iter_nr, increment, iter_nr_out)
adds one to the actual iteration
subroutine, public cp_rm_iter_level(iteration_info, level_name, n_rlevel_att)
Removes an iteration level.
integer function, public cp_print_key_should_output(iteration_info, basis_section, print_key_path, used_print_key, first_time)
returns what should be done with the given property if btest(res,cp_p_store) then the property should...
subroutine, public cp_add_iter_level(iteration_info, level_name, n_rlevel_new)
Adds an iteration level.
all routins needed for a nonperiodic electric field
subroutine, public calculate_ecore_efield(qs_env, calculate_forces)
Computes the force and the energy due to a efield on the cores Note: In the velocity gauge,...
Interface for the force calculations.
recursive subroutine, public force_env_calc_energy_force(force_env, calc_force, consistent_energies, skip_external_control, eval_energy_forces, require_consistent_energy_force, linres, calc_stress_tensor)
Interface routine for force and energy calculations.
Interface for the force calculations.
recursive subroutine, public force_env_get(force_env, in_use, fist_env, qs_env, meta_env, fp_env, subsys, para_env, potential_energy, additional_potential, kinetic_energy, harmonic_shell, kinetic_shell, cell, sub_force_env, qmmm_env, qmmmx_env, eip_env, pwdft_env, globenv, input, force_env_section, method_name_id, root_section, mixed_env, nnp_env, embed_env, ipi_env)
returns various attributes about the force environment
Define type storing the global information of a run. Keep the amount of stored data small....
Utilities for hfx and admm methods.
subroutine, public hfx_admm_init(qs_env, calculate_forces, ext_xc_section)
...
collects all constants needed in input so that they can be used without circular dependencies
integer, parameter, public use_restart_wfn
integer, parameter, public use_scf_wfn
integer, parameter, public use_rt_restart
integer, parameter, public real_time_propagation
Set of routines to dump the restart file of CP2K.
subroutine, public write_restart(md_env, force_env, root_section, coords, vels, pint_env, helium_env)
checks if a restart needs to be written and does so, updating all necessary fields in the input file....
objects that represent the structure of input sections and the data contained in an input section
subroutine, public section_vals_val_set(section_vals, keyword_name, i_rep_section, i_rep_val, val, l_val, i_val, r_val, c_val, l_vals_ptr, i_vals_ptr, r_vals_ptr, c_vals_ptr)
sets the requested value
recursive type(section_vals_type) function, pointer, public section_vals_get_subs_vals(section_vals, subsection_name, i_rep_section, can_return_null)
returns the values of the requested subsection
subroutine, public section_vals_get(section_vals, ref_count, n_repetition, n_subs_vals_rep, section, explicit)
returns various attributes about the section_vals
subroutine, public section_vals_val_get(section_vals, keyword_name, i_rep_section, i_rep_val, n_rep_val, val, l_val, i_val, r_val, c_val, l_vals, i_vals, r_vals, c_vals, explicit)
returns the requested value
Defines the basic variable types.
Definition kinds.F:23
integer, parameter, public dp
Definition kinds.F:34
integer, parameter, public default_path_length
Definition kinds.F:58
Machine interface based on Fortran 2003 and POSIX.
Definition machine.F:17
real(kind=dp) function, public m_walltime()
returns time from a real-time clock, protected against rolling early/easily
Definition machine.F:141
Calculates the moment integrals <a|r^m|b>
subroutine, public get_reference_point(rpoint, drpoint, qs_env, fist_env, reference, ref_point, ifirst, ilast)
...
container for various plainwaves related things
Calculation of the core Hamiltonian integral matrix <a|H|b> over Cartesian Gaussian-type functions.
subroutine, public qs_matrix_h_allocate_imag_from_real(qs_env)
(Re-)allocates matrix_h_im from matrix_h
Utility subroutine for qs energy calculation.
subroutine, public qs_energies_init(qs_env, calc_forces)
Refactoring of qs_energies_scf. Driver routine for the initial setup and calculations for a qs energy...
subroutine, public get_qs_env(qs_env, atomic_kind_set, qs_kind_set, cell, super_cell, cell_ref, use_ref_cell, kpoints, dft_control, mos, sab_orb, sab_all, qmmm, qmmm_periodic, mimic, sac_ae, sac_ppl, sac_lri, sap_ppnl, sab_vdw, sab_scp, sap_oce, sab_lrc, sab_se, sab_xtbe, sab_tbe, sab_core, sab_xb, sab_xtb_pp, sab_xtb_nonbond, sab_almo, sab_kp, sab_kp_nosym, sab_cneo, particle_set, energy, force, matrix_h, matrix_h_im, matrix_ks, matrix_ks_im, matrix_vxc, run_rtp, rtp, matrix_h_kp, matrix_h_im_kp, matrix_ks_kp, matrix_ks_im_kp, matrix_vxc_kp, kinetic_kp, matrix_s_kp, matrix_w_kp, matrix_s_ri_aux_kp, matrix_s, matrix_s_ri_aux, matrix_w, matrix_p_mp2, matrix_p_mp2_admm, rho, rho_xc, pw_env, ewald_env, ewald_pw, active_space, mpools, input, para_env, blacs_env, scf_control, rel_control, kinetic, qs_charges, vppl, xcint_weights, rho_core, rho_nlcc, rho_nlcc_g, ks_env, ks_qmmm_env, wf_history, scf_env, local_particles, local_molecules, distribution_2d, dbcsr_dist, molecule_kind_set, molecule_set, subsys, cp_subsys, oce, local_rho_set, rho_atom_set, task_list, task_list_soft, rho0_atom_set, rho0_mpole, rhoz_set, rhoz_cneo_set, ecoul_1c, rho0_s_rs, rho0_s_gs, rhoz_cneo_s_rs, rhoz_cneo_s_gs, do_kpoints, has_unit_metric, requires_mo_derivs, mo_derivs, mo_loc_history, nkind, natom, nelectron_total, nelectron_spin, efield, neighbor_list_id, linres_control, xas_env, virial, cp_ddapc_env, cp_ddapc_ewald, outer_scf_history, outer_scf_ihistory, x_data, et_coupling, dftb_potential, results, se_taper, se_store_int_env, se_nddo_mpole, se_nonbond_env, admm_env, lri_env, lri_density, exstate_env, ec_env, harris_env, dispersion_env, gcp_env, vee, rho_external, external_vxc, mask, mp2_env, bs_env, kg_env, wanniercentres, atprop, ls_scf_env, do_transport, transport_env, v_hartree_rspace, s_mstruct_changed, rho_changed, potential_changed, forces_up_to_date, mscfg_env, almo_scf_env, gradient_history, variable_history, embed_pot, spin_embed_pot, polar_env, mos_last_converged, eeq, rhs, do_rixs, tb_tblite)
Get the QUICKSTEP environment.
Routines to handle an external electrostatic field The external field can be generic and is provided ...
subroutine, public external_c_potential(qs_env, calculate_forces)
Computes the force and the energy due to the external potential on the cores.
subroutine, public external_e_potential(qs_env)
Computes the external potential on the grid.
routines that build the Kohn-Sham matrix (i.e calculate the coulomb and xc parts
subroutine, public qs_ks_update_qs_env(qs_env, calculate_forces, just_energy, print_active)
updates the Kohn Sham matrix of the given qs_env (facility method)
subroutine, public qs_ks_allocate_basics(qs_env, is_complex)
Allocate ks_matrix if necessary, take current overlap matrix as template.
subroutine, public qs_ks_did_change(ks_env, s_mstruct_changed, rho_changed, potential_changed, full_reset)
tells that some of the things relevant to the ks calculation did change. has to be called when change...
subroutine, public set_ks_env(ks_env, v_hartree_rspace, s_mstruct_changed, rho_changed, exc_accint, potential_changed, forces_up_to_date, complex_ks, matrix_h, matrix_h_im, matrix_ks, matrix_ks_im, matrix_vxc, kinetic, matrix_s, matrix_s_ri_aux, matrix_w, matrix_p_mp2, matrix_p_mp2_admm, matrix_h_kp, matrix_h_im_kp, matrix_ks_kp, matrix_vxc_kp, kinetic_kp, matrix_s_kp, matrix_w_kp, matrix_s_ri_aux_kp, matrix_ks_im_kp, vppl, xcint_weights, rho_core, rho_nlcc, rho_nlcc_g, vee, neighbor_list_id, kpoints, sab_orb, sab_all, sac_ae, sac_ppl, sac_lri, sap_ppnl, sap_oce, sab_lrc, sab_se, sab_xtbe, sab_tbe, sab_core, sab_xb, sab_xtb_pp, sab_xtb_nonbond, sab_vdw, sab_scp, sab_almo, sab_kp, sab_kp_nosym, sab_cneo, task_list, task_list_soft, subsys, dft_control, dbcsr_dist, distribution_2d, pw_env, para_env, blacs_env)
...
Definition and initialisation of the mo data type.
Definition qs_mo_io.F:21
subroutine, public wfn_restart_file_name(filename, exist, section, logger, kp, xas, rtp)
...
Definition qs_mo_io.F:460
Definition and initialisation of the mo data type.
Definition qs_mo_types.F:22
subroutine, public init_mo_set(mo_set, fm_pool, fm_ref, fm_struct, name, counter)
initializes an allocated mo_set. eigenvalues, mo_coeff, occupation_numbers are valid only after this ...
subroutine, public get_mo_set(mo_set, maxocc, homo, lfomo, nao, nelectron, n_el_f, nmo, eigenvalues, occupation_numbers, mo_coeff, mo_coeff_b, uniform_occupation, kts, mu, flexible_electron_count)
Get the components of a MO set data structure.
Calculates the moment integrals <a|r^m|b> and <a|r x d/dr|b>
Definition qs_moments.F:14
subroutine, public build_local_moment_matrix(qs_env, moments, nmoments, ref_point, ref_points, basis_type)
...
Definition qs_moments.F:593
methods of the rho structure (defined in qs_rho_types)
subroutine, public allocate_rho_ao_imag_from_real(rho, qs_env)
(Re-)allocates rho_ao_im from real part rho_ao
superstucture that hold various representations of the density and keeps track of which ones are vali...
subroutine, public qs_rho_set(rho_struct, rho_ao, rho_ao_im, rho_ao_kp, rho_ao_im_kp, rho_r, drho_r, rho_g, drho_g, tau_r, tau_g, rho_r_valid, drho_r_valid, rho_g_valid, drho_g_valid, tau_r_valid, tau_g_valid, tot_rho_r, tot_rho_g, rho_r_sccs, soft_valid, complex_rho_ao)
...
Routines to apply a delta pulse for RTP and EMD.
subroutine, public apply_delta_pulse(qs_env, rtp, rtp_control)
Interface to call the delta pulse depending on the type of calculation.
Utility functions that are needed for RTP/EMD in combination with HF or hybrid functionals (needs to ...
subroutine, public rtp_hfx_rebuild(qs_env)
rebuilds the structures of P and KS (imaginary) in case S changed
Function related to MO projection in RTP calculations.
subroutine, public init_mo_projection(qs_env, rtp_control)
Initialize the mo projection objects for time dependent run.
Routines for propagating the orbitals.
subroutine, public rtp_localize(qs_env, rtp)
Computes Maximally localised Wannier functions and print properties according to FORCE_EVALDFTLOCALIZ...
subroutine, public propagation_step(qs_env, rtp, rtp_control)
performs a single propagation step a(t+Dt)=U(t+Dt,t)*a(0) and calculates the new exponential
Routine for the real time propagation output.
subroutine, public print_ft(rtp_section, moments, times, fields, rtc, info_opt, cell)
Calculate and print the Fourier transforms + polarizabilites from moment trace.
subroutine, public rt_prop_output(qs_env, run_type, delta_iter, used_time)
...
subroutine, public print_moments(moments_section, info_unit, moments, time, imag_opt, append_opt)
Print the dipole moments into a file.
subroutine, public calc_local_moment(moment_matrices, density_matrices, work, moment, imag_opt)
Calculate the values of real/imaginary parts of moments in all directions.
Types and set_get for real time propagation depending on runtype and diagonalization method different...
subroutine, public rt_prop_create(rtp, mos, mpools, dft_control, template, linear_scaling, mos_aux)
...
subroutine, public rtp_create_sinvh_imag(rtp, nspins)
Initialize SinvH_imag for rtp.
subroutine, public rtp_history_create(rtp, aspc_order)
...
subroutine, public get_rtp(rtp, exp_h_old, exp_h_new, h_last_iter, rho_old, rho_next, rho_new, mos, mos_new, mos_old, mos_next, s_inv, s_half, s_minus_half, b_mat, c_mat, propagator_matrix, mixing, mixing_factor, s_der, dt, nsteps, sinvh, sinvh_imag, sinvb, admm_mos)
...
Routines needed for EMD.
subroutine, public calc_update_rho_sparse(qs_env)
Copies the density matrix back into the qs_envrhorho_ao.
subroutine, public recalculate_fields(fields, times, orig_start, i_start, dft_control)
Recalculates the field for index range given by orig_start and i_start, with times taken from the tim...
subroutine, public calc_s_derivs(qs_env)
Calculates dS/dR respectily the velocity weighted derivatves only needed for ehrenfest MD.
subroutine, public read_moments(moments_section, orig_start, current_start, moments, times, mom_read)
Attempt to read the moments from a previously written file.
subroutine, public calc_update_rho(qs_env)
calculates the density from the complex MOs and passes the density to qs_env.
subroutine, public warn_section_unused(section, subsection_name, error_message)
Warn about unused sections of the print section - only implemented for some of the methods.
subroutine, public get_restart_wfn(qs_env)
reads the restart file. At the moment only SCF (means only real)
Routines to perform the RTP in the velocity gauge.
subroutine, public velocity_gauge_ks_matrix(qs_env, subtract_nl_term)
...
Routines for the real time propagation.
subroutine, public rt_prop_setup(force_env)
creates rtp_type, gets the initial state, either by reading MO's from file or calling SCF run
Routines for that prepare rtp and EMD.
subroutine, public init_propagators(qs_env)
prepares the initial matrices for the propagators
subroutine, public rt_initialize_rho_from_mos(rtp, mos, mos_old)
Computes the density matrix from the mos Update: Initialized the density matrix from complex mos (for...
Type defining parameters related to the simulation cell.
Definition cell_types.F:60
represent a full matrix
type of a logger, at the moment it contains just a print level starting at which level it should be l...
wrapper to abstract the force evaluation of the various methods
contains the initially parsed file and the initial parallel environment
contained for different pw related things
calculation environment to calculate the ks matrix, holds all the needed vars. assumes that the core ...
keeps the density in various representations, keeping track of which ones are valid.