(git:495eafe)
Loading...
Searching...
No Matches
cp2k_runs.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! **************************************************************************************************
10 USE atom, ONLY: atom_code
11 USE bibliography, ONLY: iannuzzi2026,&
12 cite_reference,&
14 USE bsse, ONLY: do_bsse_calculation
15 USE cell_opt, ONLY: cp_cell_opt
17 USE cp2k_info, ONLY: compile_date,&
22 USE cp_dbcsr_api, ONLY: dbcsr_finalize_lib,&
23 dbcsr_init_lib,&
24 dbcsr_print_config,&
25 dbcsr_print_statistics
27 USE cp_files, ONLY: close_file,&
41 USE cp_units, ONLY: cp_unit_set_create,&
46 USE environment, ONLY: cp2k_finalize,&
47 cp2k_init,&
48 cp2k_read,&
52 f77_default_para_env => default_para_env,&
56 USE farming_methods, ONLY: do_deadlock,&
58 do_wait,&
69 USE geo_opt, ONLY: cp_geo_opt
75 USE input_constants, ONLY: &
88 USE input_section_types, ONLY: &
92 USE ipi_driver, ONLY: run_driver
93 USE kinds, ONLY: default_path_length,&
95 dp,&
96 int_8
97 USE library_tests, ONLY: lib_test
98 USE machine, ONLY: default_output_unit,&
99 m_chdir,&
100 m_flush,&
101 m_getcwd,&
102 m_memory,&
105 USE mc_run, ONLY: do_mon_car
106 USE md_run, ONLY: qs_mol_dyn
107 USE message_passing, ONLY: mp_any_source,&
111 USE mimic_loop, ONLY: do_mimic_loop
112 USE mscfg_methods, ONLY: do_mol_loop,&
114 USE neb_methods, ONLY: neb
115 USE negf_methods, ONLY: do_negf
121 USE pint_methods, ONLY: do_pint_run
125 USE rt_bse, ONLY: run_propagation_bse
127 USE swarm, ONLY: run_swarm
128 USE tamc_run, ONLY: qs_tamc
129 USE tmc_setup, ONLY: do_analyze_files,&
130 do_tmc
132#include "../base/base_uses.f90"
133
134 IMPLICIT NONE
135
136 PRIVATE
137
138 PUBLIC :: write_xml_file, run_input
139
140 CHARACTER(len=*), PARAMETER, PRIVATE :: moduleN = 'cp2k_runs'
141
142CONTAINS
143
144! **************************************************************************************************
145!> \brief performs an instance of a cp2k run
146!> \param input_declaration ...
147!> \param input_file_name name of the file to be opened for input
148!> \param output_unit unit to which output should be written
149!> \param mpi_comm ...
150!> \param initial_variables key-value list of initial preprocessor variables
151!> \author Joost VandeVondele
152!> \note
153!> para_env should be a valid communicator
154!> output_unit should be writeable by at least the lowest rank of the mpi group
155!>
156!> recursive because a given run_type might need to be able to perform
157!> another cp2k_run as part of its job (e.g. farming, classical equilibration, ...)
158!>
159!> the idea is that a cp2k instance should be able to run with just three
160!> arguments, i.e. a given input file, output unit, mpi communicator.
161!> giving these three to cp2k_run should produce a valid run.
162!> the only task of the PROGRAM cp2k is to create valid instances of the
163!> above arguments. Ideally, anything that is called afterwards should be
164!> able to run simultaneously / multithreaded / sequential / parallel / ...
165!> and able to fail safe
166! **************************************************************************************************
167 RECURSIVE SUBROUTINE cp2k_run(input_declaration, input_file_name, output_unit, mpi_comm, initial_variables)
168 TYPE(section_type), POINTER :: input_declaration
169 CHARACTER(LEN=*), INTENT(IN) :: input_file_name
170 INTEGER, INTENT(IN) :: output_unit
171
172 CLASS(mp_comm_type) :: mpi_comm
173 CHARACTER(len=default_path_length), &
174 DIMENSION(:, :), INTENT(IN) :: initial_variables
175
176 INTEGER :: f_env_handle, grid_backend, ierr, &
177 iter_level, method_name_id, &
178 new_env_id, prog_name_id, run_type_id
179#if defined(__DBCSR_ACC)
180 INTEGER, TARGET :: offload_chosen_device
181#endif
182 INTEGER, POINTER :: active_device_id
183 INTEGER(KIND=int_8) :: m_memory_max_mpi
184 LOGICAL :: echo_input, grid_apply_cutoff, &
185 grid_validate, I_was_ionode
186 TYPE(cp_logger_type), POINTER :: logger, sublogger
187 TYPE(mp_para_env_type), POINTER :: para_env
188 TYPE(dft_control_type), POINTER :: dft_control
189 TYPE(f_env_type), POINTER :: f_env
190 TYPE(force_env_type), POINTER :: force_env
191 TYPE(global_environment_type), POINTER :: globenv
192 TYPE(section_vals_type), POINTER :: glob_section, input_file, root_section
193
194 NULLIFY (para_env, f_env, dft_control, active_device_id)
195 ALLOCATE (para_env)
196 para_env = mpi_comm
197
198#if defined(__DBCSR_ACC)
199 IF (offload_get_device_count() > 0) THEN
200 offload_chosen_device = offload_get_chosen_device()
201 active_device_id => offload_chosen_device
202 END IF
203#endif
204 CALL dbcsr_init_lib(mpi_comm%get_handle(), io_unit=output_unit, &
205 accdrv_active_device_id=active_device_id)
206
207 NULLIFY (globenv, force_env)
208
211
212 ! Parse the input
213 input_file => read_input(input_declaration, input_file_name, &
214 initial_variables=initial_variables, &
215 para_env=para_env)
216
217 CALL para_env%sync()
218
219 logger => cp_get_default_logger()
220
221 glob_section => section_vals_get_subs_vals(input_file, "GLOBAL")
222 CALL section_vals_val_get(glob_section, "ECHO_INPUT", l_val=echo_input)
223 IF (echo_input .AND. (output_unit > 0)) THEN
224 CALL section_vals_write(input_file, &
225 unit_nr=output_unit, &
226 hide_root=.true., &
227 hide_defaults=.false.)
228 END IF
229
230 CALL check_cp2k_input(input_declaration, input_file, para_env=para_env, output_unit=output_unit)
231 root_section => input_file
232 CALL section_vals_val_get(input_file, "GLOBAL%PROGRAM_NAME", &
233 i_val=prog_name_id)
234 CALL section_vals_val_get(input_file, "GLOBAL%RUN_TYPE", &
235 i_val=run_type_id)
236 CALL section_vals_val_get(root_section, "FORCE_EVAL%METHOD", i_val=method_name_id)
237
238 IF (prog_name_id /= do_cp2k) THEN
239 ! initial setup (cp2k does in in the creation of the force_env)
240 CALL globenv_create(globenv)
241 CALL section_vals_retain(input_file)
242 CALL cp2k_init(para_env, output_unit, globenv, input_file_name=input_file_name)
243 CALL cp2k_read(root_section, para_env, globenv)
244 CALL cp2k_setup(root_section, para_env, globenv)
245 END IF
246
247 CALL cp_dbcsr_config(root_section)
248 IF (output_unit > 0 .AND. &
250 CALL dbcsr_print_config(unit_nr=output_unit)
251 WRITE (unit=output_unit, fmt='()')
252 END IF
253
254 ! Configure the grid library.
255 CALL section_vals_val_get(root_section, "GLOBAL%GRID%BACKEND", i_val=grid_backend)
256 CALL section_vals_val_get(root_section, "GLOBAL%GRID%VALIDATE", l_val=grid_validate)
257 CALL section_vals_val_get(root_section, "GLOBAL%GRID%APPLY_CUTOFF", l_val=grid_apply_cutoff)
258
259 CALL grid_library_set_config(backend=grid_backend, &
260 validate=grid_validate, &
261 apply_cutoff=grid_apply_cutoff)
262
263 SELECT CASE (prog_name_id)
264 CASE (do_atom)
265 globenv%run_type_id = none_run
266 CALL atom_code(root_section)
267 CASE (do_optimize_input)
268 CALL run_optimize_input(input_declaration, root_section, para_env)
269 CASE (do_swarm)
270 CALL run_swarm(input_declaration, root_section, para_env, globenv, input_file_name)
271 CASE (do_farming) ! TODO: refactor cp2k's startup code
272 CALL dbcsr_finalize_lib()
273 CALL farming_run(input_declaration, root_section, para_env, initial_variables)
274 CALL dbcsr_init_lib(mpi_comm%get_handle(), io_unit=output_unit, &
275 accdrv_active_device_id=active_device_id)
276 CASE (do_opt_basis)
277 CALL run_optimize_basis(input_declaration, root_section, para_env)
278 globenv%run_type_id = none_run
279 CASE (do_cp2k)
280 CALL create_force_env(new_env_id, &
281 input_declaration=input_declaration, &
282 input_path=input_file_name, &
283 output_path="__STD_OUT__", mpi_comm=para_env, &
284 output_unit=output_unit, &
285 owns_out_unit=.false., &
286 input=input_file, ierr=ierr)
287 cpassert(ierr == 0)
288 CALL f_env_add_defaults(new_env_id, f_env, handle=f_env_handle)
289 force_env => f_env%force_env
290 CALL force_env_get(force_env, globenv=globenv)
291 CASE (do_test)
292 CALL lib_test(root_section, para_env, globenv)
293 CASE (do_tree_mc) ! TMC entry point
294 CALL do_tmc(input_declaration, root_section, para_env, globenv)
295 CASE (do_tree_mc_ana)
296 CALL do_analyze_files(input_declaration, root_section, para_env)
297 CASE default
298 cpabort("")
299 END SELECT
300 CALL section_vals_release(input_file)
301
302 SELECT CASE (globenv%run_type_id)
303 CASE (pint_run)
304 CALL do_pint_run(para_env, root_section, input_declaration, globenv)
305 CASE (none_run, tree_mc_run)
306 ! do nothing
307 CASE (driver_run)
308 CALL run_driver(force_env, globenv)
310 IF (method_name_id /= do_qs .AND. &
311 method_name_id /= do_sirius .AND. &
312 method_name_id /= do_qmmm .AND. &
313 method_name_id /= do_mixed .AND. &
314 method_name_id /= do_nnp .AND. &
315 method_name_id /= do_embed .AND. &
316 method_name_id /= do_fist .AND. &
317 method_name_id /= do_ipi) &
318 cpabort("Energy/Force run not available for all methods ")
319
320 sublogger => cp_get_default_logger()
321 CALL cp_add_iter_level(sublogger%iter_info, "JUST_ENERGY", &
322 n_rlevel_new=iter_level)
323
324 ! loop over molecules to generate a molecular guess
325 ! this procedure is initiated here to avoid passing globenv deep down
326 ! the subroutine stack
327 IF (do_mol_loop(force_env=force_env)) &
328 CALL loop_over_molecules(globenv, force_env)
329
330 SELECT CASE (globenv%run_type_id)
331 CASE (energy_run)
332 CALL force_env_calc_energy_force(force_env, calc_force=.false.)
333 CASE (energy_force_run)
334 CALL force_env_calc_energy_force(force_env, calc_force=.true.)
335 CASE default
336 cpabort("")
337 END SELECT
338 CALL cp_rm_iter_level(sublogger%iter_info, level_name="JUST_ENERGY", n_rlevel_att=iter_level)
339 CASE (mol_dyn_run)
340 CALL qs_mol_dyn(force_env, globenv)
341 CASE (geo_opt_run)
342 CALL cp_geo_opt(force_env, globenv)
343 CASE (cell_opt_run)
344 CALL cp_cell_opt(force_env, globenv)
345 CASE (mon_car_run)
346 CALL do_mon_car(force_env, globenv, input_declaration, input_file_name)
347 CASE (do_tamc)
348 CALL qs_tamc(force_env, globenv)
350 IF (method_name_id /= do_qs) &
351 cpabort("Real time propagation needs METHOD QS. ")
352 CALL get_qs_env(force_env%qs_env, dft_control=dft_control)
353 dft_control%rtp_control%fixed_ions = .true.
354 SELECT CASE (dft_control%rtp_control%rtp_method)
355 CASE (rtp_method_bse)
356 ! Run the TD-BSE method
357 CALL run_propagation_bse(force_env%qs_env, force_env)
358 CASE default
359 ! Run the TDDFT method
360 CALL rt_prop_setup(force_env)
361 END SELECT
362 CASE (ehrenfest)
363 IF (method_name_id /= do_qs) &
364 cpabort("Ehrenfest dynamics needs METHOD QS ")
365 CALL get_qs_env(force_env%qs_env, dft_control=dft_control)
366 dft_control%rtp_control%fixed_ions = .false.
367 CALL qs_mol_dyn(force_env, globenv)
368 CASE (bsse_run)
369 CALL do_bsse_calculation(force_env, globenv)
371 IF (method_name_id /= do_qs .AND. &
372 method_name_id /= do_qmmm) &
373 cpabort("Property calculations by Linear Response only within the QS or QMMM program ")
374 ! The Ground State is needed, it can be read from Restart
375 CALL force_env_calc_energy_force(force_env, calc_force=.false., linres=.true.)
376 CALL linres_calculation(force_env)
377 CASE (debug_run)
378 SELECT CASE (method_name_id)
379 CASE (do_qs, do_qmmm, do_fist)
380 CALL cp2k_debug_energy_and_forces(force_env)
381 CASE DEFAULT
382 cpabort("Debug run available only with QS, FIST, and QMMM program ")
383 END SELECT
384 CASE (vib_anal)
385 CALL vb_anal(root_section, input_declaration, para_env, globenv)
386 CASE (do_band)
387 CALL neb(root_section, input_declaration, para_env, globenv)
388 CASE (negf_run)
389 CALL do_negf(force_env)
390 CASE (mimic_run)
391 CALL do_mimic_loop(force_env)
392 CASE default
393 cpabort("")
394 END SELECT
395
396 ! Sample peak memory
397 CALL m_memory()
398
399 CALL dbcsr_print_statistics()
400 CALL dbm_library_print_stats(mpi_comm=mpi_comm, output_unit=output_unit)
401 CALL grid_library_print_stats(mpi_comm=mpi_comm, output_unit=output_unit)
402 CALL offload_mempool_stats_print(mpi_comm=mpi_comm, output_unit=output_unit)
403
404 m_memory_max_mpi = m_memory_max
405 CALL mpi_comm%max(m_memory_max_mpi)
406 IF (output_unit > 0) THEN
407 WRITE (output_unit, *)
408 WRITE (output_unit, '(T2,"MEMORY| Estimated peak process memory [MiB]",T73,I8)') &
409 (m_memory_max_mpi + (1024*1024) - 1)/(1024*1024)
410 END IF
411
412 IF (prog_name_id == do_cp2k) THEN
413 f_env%force_env => force_env ! for mc
414 IF (ASSOCIATED(force_env%globenv)) THEN
415 IF (.NOT. ASSOCIATED(force_env%globenv, globenv)) THEN
416 CALL globenv_release(force_env%globenv) !mc
417 END IF
418 END IF
419 force_env%globenv => globenv !mc
420 CALL f_env_rm_defaults(f_env, ierr=ierr, &
421 handle=f_env_handle)
422 cpassert(ierr == 0)
423 CALL destroy_force_env(new_env_id, ierr=ierr)
424 cpassert(ierr == 0)
425 ELSE
426 i_was_ionode = para_env%is_source()
427 CALL cp2k_finalize(root_section, para_env, globenv)
428 cpassert(globenv%ref_count == 1)
429 CALL section_vals_release(root_section)
430 CALL globenv_release(globenv)
431 END IF
432
433 CALL dbcsr_finalize_lib()
434
435 CALL mp_para_env_release(para_env)
436
437 END SUBROUTINE cp2k_run
438
439! **************************************************************************************************
440!> \brief performs a farming run that performs several independent cp2k_runs
441!> \param input_declaration ...
442!> \param root_section ...
443!> \param para_env ...
444!> \param initial_variables ...
445!> \author Joost VandeVondele
446!> \note
447!> needs to be part of this module as the cp2k_run -> farming_run -> cp2k_run
448!> calling style creates a hard circular dependency
449! **************************************************************************************************
450 RECURSIVE SUBROUTINE farming_run(input_declaration, root_section, para_env, initial_variables)
451 TYPE(section_type), POINTER :: input_declaration
452 TYPE(section_vals_type), POINTER :: root_section
453 TYPE(mp_para_env_type), POINTER :: para_env
454 CHARACTER(len=default_path_length), DIMENSION(:, :), INTENT(IN) :: initial_variables
455
456 CHARACTER(len=*), PARAMETER :: routineN = 'farming_run'
457 INTEGER, PARAMETER :: minion_status_done = -3, &
458 minion_status_wait = -4
459
460 CHARACTER(len=7) :: label
461 CHARACTER(LEN=default_path_length) :: output_file
462 CHARACTER(LEN=default_string_length) :: str
463 INTEGER :: dest, handle, i, i_job_to_restart, ierr, ijob, ijob_current, &
464 ijob_end, ijob_start, iunit, n_jobs_to_run, new_output_unit, &
465 new_rank, ngroups, num_minions, output_unit, primus_minion, &
466 minion_rank, source, tag, todo
467 INTEGER, DIMENSION(:), POINTER :: group_distribution, &
468 captain_minion_partition, &
469 minion_distribution, &
470 minion_status
471 LOGICAL :: found, captain, minion
472 REAL(KIND=dp) :: t1, t2
473 REAL(KIND=dp), ALLOCATABLE, DIMENSION(:) :: waittime
474 TYPE(cp_logger_type), POINTER :: logger
475 TYPE(cp_parser_type), POINTER :: my_parser
476 TYPE(cp_unit_set_type) :: default_units
477 TYPE(farming_env_type), POINTER :: farming_env
478 TYPE(section_type), POINTER :: g_section
479 TYPE(section_vals_type), POINTER :: g_data
480 TYPE(mp_comm_type) :: minion_group, new_group
481
482 ! the primus of all minions, talks to the captain on topics concerning all minions
483 CALL timeset(routinen, handle)
484 NULLIFY (my_parser, g_section, g_data)
485
486 logger => cp_get_default_logger()
487 output_unit = cp_print_key_unit_nr(logger, root_section, "FARMING%PROGRAM_RUN_INFO", &
488 extension=".log")
489
490 IF (output_unit > 0) WRITE (output_unit, fmt="(T2,A)") "FARMING| Hi, welcome on this farm!"
491
492 ALLOCATE (farming_env)
493 CALL init_farming_env(farming_env)
494 ! remember where we started
495 CALL m_getcwd(farming_env%cwd)
496 CALL farming_parse_input(farming_env, root_section, para_env)
497
498 ! the full mpi group is first split in a minion group and a captain group, the latter being at most 1 process
499 minion = .true.
500 captain = .false.
501 IF (farming_env%captain_minion) THEN
502 IF (output_unit > 0) WRITE (output_unit, fmt="(T2,A)") "FARMING| Using a Captain-Minion setup"
503
504 ALLOCATE (captain_minion_partition(0:1))
505 captain_minion_partition = [1, para_env%num_pe - 1]
506 ALLOCATE (group_distribution(0:para_env%num_pe - 1))
507
508 CALL minion_group%from_split(para_env, ngroups, group_distribution, &
509 n_subgroups=2, group_partition=captain_minion_partition)
510 DEALLOCATE (captain_minion_partition)
511 DEALLOCATE (group_distribution)
512 num_minions = minion_group%num_pe
513 minion_rank = minion_group%mepos
514
515 IF (para_env%mepos == 0) THEN
516 minion = .false.
517 captain = .true.
518 ! on the captain node, num_minions corresponds to the size of the captain group
519 cpassert(num_minions == 1)
520 num_minions = para_env%num_pe - 1
521 minion_rank = -1
522 END IF
523 cpassert(num_minions == para_env%num_pe - 1)
524 ELSE
525 ! all processes are minions
526 IF (output_unit > 0) WRITE (output_unit, fmt="(T2,A)") "FARMING| Using a Minion-only setup"
527 CALL minion_group%from_dup(para_env)
528 num_minions = minion_group%num_pe
529 minion_rank = minion_group%mepos
530 END IF
531 IF (output_unit > 0) WRITE (output_unit, fmt="(T2,A,I0)") "FARMING| Number of Minions ", num_minions
532
533 ! keep track of which para_env rank is which minion/captain
534 ALLOCATE (minion_distribution(0:para_env%num_pe - 1))
535 minion_distribution = 0
536 minion_distribution(para_env%mepos) = minion_rank
537 CALL para_env%sum(minion_distribution)
538 ! we do have a primus inter pares
539 primus_minion = 0
540 DO i = 1, para_env%num_pe - 1
541 IF (minion_distribution(i) == 0) primus_minion = i
542 END DO
543
544 ! split the current communicator for the minions
545 ! in a new_group, new_size and new_rank according to the number of groups required according to the input
546 ALLOCATE (group_distribution(0:num_minions - 1))
547 group_distribution = -1
548 IF (minion) THEN
549 IF (farming_env%group_size_wish_set) THEN
550 farming_env%group_size_wish = min(farming_env%group_size_wish, para_env%num_pe)
551 CALL new_group%from_split(minion_group, ngroups, group_distribution, &
552 subgroup_min_size=farming_env%group_size_wish, stride=farming_env%stride)
553 ELSE IF (farming_env%ngroup_wish_set) THEN
554 IF (ASSOCIATED(farming_env%group_partition)) THEN
555 CALL new_group%from_split(minion_group, ngroups, group_distribution, &
556 n_subgroups=farming_env%ngroup_wish, &
557 group_partition=farming_env%group_partition, stride=farming_env%stride)
558 ELSE
559 CALL new_group%from_split(minion_group, ngroups, group_distribution, &
560 n_subgroups=farming_env%ngroup_wish, stride=farming_env%stride)
561 END IF
562 ELSE
563 cpabort("must set either group_size_wish or ngroup_wish")
564 END IF
565 new_rank = new_group%mepos
566 END IF
567
568 ! transfer the info about the minion group distribution to the captain
569 IF (farming_env%captain_minion) THEN
570 IF (para_env%mepos == primus_minion) THEN
571 tag = 1
572 CALL para_env%send(group_distribution, 0, tag)
573 tag = 2
574 CALL para_env%send(ngroups, 0, tag)
575 END IF
576 IF (para_env%mepos == 0) THEN
577 tag = 1
578 CALL para_env%recv(group_distribution, primus_minion, tag)
579 tag = 2
580 CALL para_env%recv(ngroups, primus_minion, tag)
581 END IF
582 END IF
583
584 ! write info on group distribution
585 IF (output_unit > 0) THEN
586 WRITE (output_unit, fmt="(T2,A,T71,I10)") "FARMING| Number of created MPI (Minion) groups:", ngroups
587 WRITE (output_unit, fmt="(T2,A)", advance="NO") "FARMING| MPI (Minion) process to group correspondence:"
588 DO i = 0, num_minions - 1
589 IF (modulo(i, 4) == 0) WRITE (output_unit, *)
590 WRITE (output_unit, fmt='(A3,I6,A3,I6,A1)', advance="NO") &
591 " (", i, " : ", group_distribution(i), ")"
592 END DO
593 WRITE (output_unit, *)
594 CALL m_flush(output_unit)
595 END IF
596
597 ! protect about too many jobs being run in single go. Not more jobs are allowed than the number in the input file
598 ! and determine the future restart point
599 IF (farming_env%cycle) THEN
600 n_jobs_to_run = farming_env%max_steps*ngroups
601 i_job_to_restart = modulo(farming_env%restart_n + n_jobs_to_run - 1, farming_env%njobs) + 1
602 ELSE
603 n_jobs_to_run = min(farming_env%njobs, farming_env%max_steps*ngroups)
604 n_jobs_to_run = min(n_jobs_to_run, farming_env%njobs - farming_env%restart_n + 1)
605 i_job_to_restart = n_jobs_to_run + farming_env%restart_n
606 END IF
607
608 ! and write the restart now, that's the point where the next job starts, even if this one is running
609 iunit = cp_print_key_unit_nr(logger, root_section, "FARMING%RESTART", &
610 extension=".restart")
611 IF (iunit > 0) THEN
612 WRITE (iunit, *) i_job_to_restart
613 END IF
614 CALL cp_print_key_finished_output(iunit, logger, root_section, "FARMING%RESTART")
615
616 ! this is the job range to be executed.
617 ijob_start = farming_env%restart_n
618 ijob_end = ijob_start + n_jobs_to_run - 1
619 IF (output_unit > 0 .AND. ijob_end - ijob_start < 0) THEN
620 WRITE (output_unit, fmt="(T2,A)") "FARMING| --- WARNING --- NO JOBS NEED EXECUTION ? "
621 WRITE (output_unit, fmt="(T2,A)") "FARMING| is the cycle keyword required ?"
622 WRITE (output_unit, fmt="(T2,A)") "FARMING| or is a stray RESTART file present ?"
623 WRITE (output_unit, fmt="(T2,A)") "FARMING| or is the group_size requested smaller than the number of CPUs?"
624 END IF
625
626 ! actual executions of the jobs in two different modes
627 IF (farming_env%captain_minion) THEN
628 IF (minion) THEN
629 ! keep on doing work until captain has decided otherwise
630 todo = do_wait
631 DO
632 IF (new_rank == 0) THEN
633 ! the head minion tells the captain he's done or ready to start
634 ! the message tells what has been done lately
635 tag = 1
636 dest = 0
637 CALL para_env%send(todo, dest, tag)
638
639 ! gets the new todo item
640 tag = 2
641 source = 0
642 CALL para_env%recv(todo, source, tag)
643
644 ! and informs his peer minions
645 CALL new_group%bcast(todo, 0)
646 ELSE
647 CALL new_group%bcast(todo, 0)
648 END IF
649
650 ! if the todo is do_nothing we are flagged to quit. Otherwise it is the job number
651 SELECT CASE (todo)
652 CASE (do_wait, do_deadlock)
653 ! go for a next round, but we first wait a bit
654 t1 = m_walltime()
655 DO
656 t2 = m_walltime()
657 IF (t2 - t1 > farming_env%wait_time) EXIT
658 END DO
659 CASE (do_nothing)
660 EXIT
661 CASE (1:)
662 CALL execute_job(todo)
663 END SELECT
664 END DO
665 ELSE ! captain
666 ALLOCATE (minion_status(0:ngroups - 1))
667 minion_status = minion_status_wait
668 ijob_current = ijob_start - 1
669
670 DO
671 IF (all(minion_status == minion_status_done)) EXIT
672
673 ! who's the next minion waiting for work
674 tag = 1
675 source = mp_any_source
676 CALL para_env%recv(todo, source, tag) ! updates source
677 IF (todo > 0) THEN
678 farming_env%Job(todo)%status = job_finished
679 IF (output_unit > 0) THEN
680 WRITE (output_unit, fmt=*) "Job finished: ", todo
681 CALL m_flush(output_unit)
682 END IF
683 END IF
684
685 ! get the next job in line, this could be do_nothing, if we're finished
686 CALL get_next_job(farming_env, ijob_start, ijob_end, ijob_current, todo)
687 dest = source
688 tag = 2
689 CALL para_env%send(todo, dest, tag)
690
691 IF (todo > 0) THEN
692 farming_env%Job(todo)%status = job_running
693 IF (output_unit > 0) THEN
694 WRITE (output_unit, fmt=*) "Job: ", todo, " Dir: ", trim(farming_env%Job(todo)%cwd), &
695 " assigned to group ", group_distribution(minion_distribution(dest))
696 CALL m_flush(output_unit)
697 END IF
698 ELSE
699 IF (todo == do_nothing) THEN
700 minion_status(group_distribution(minion_distribution(dest))) = minion_status_done
701 IF (output_unit > 0) THEN
702 WRITE (output_unit, fmt=*) "group done: ", group_distribution(minion_distribution(dest))
703 CALL m_flush(output_unit)
704 END IF
705 END IF
706 IF (todo == do_deadlock) THEN
707 IF (output_unit > 0) THEN
708 WRITE (output_unit, fmt=*) ""
709 WRITE (output_unit, fmt=*) "FARMING JOB DEADLOCKED ... CIRCULAR DEPENDENCIES"
710 WRITE (output_unit, fmt=*) ""
711 CALL m_flush(output_unit)
712 END IF
713 cpassert(todo /= do_deadlock)
714 END IF
715 END IF
716
717 END DO
718
719 DEALLOCATE (minion_status)
720
721 END IF
722 ELSE
723 ! this is the non-captain-minion mode way of executing the jobs
724 ! the i-th job in the input is always executed by the MODULO(i-1,ngroups)-th group
725 ! (needed for cyclic runs, we don't want two groups working on the same job)
726 IF (output_unit > 0) THEN
727 IF (ijob_end - ijob_start >= 0) THEN
728 WRITE (output_unit, fmt="(T2,A)") "FARMING| List of jobs : "
729 DO ijob = ijob_start, ijob_end
730 i = modulo(ijob - 1, farming_env%njobs) + 1
731 WRITE (output_unit, fmt=*) "Job: ", i, " Dir: ", trim(farming_env%Job(i)%cwd), " Input: ", &
732 trim(farming_env%Job(i)%input), " MPI group:", modulo(i - 1, ngroups)
733 END DO
734 END IF
735 CALL m_flush(output_unit)
736 END IF
737
738 DO ijob = ijob_start, ijob_end
739 i = modulo(ijob - 1, farming_env%njobs) + 1
740 ! this farms out the jobs
741 IF (modulo(i - 1, ngroups) == group_distribution(minion_rank)) THEN
742 IF (output_unit > 0) THEN
743 WRITE (output_unit, fmt="(T2,A,I5.5,A)", advance="NO") " Running Job ", i, &
744 " in "//trim(farming_env%Job(i)%cwd)//"."
745 CALL m_flush(output_unit)
746 END IF
747 CALL execute_job(i)
748 IF (output_unit > 0) THEN
749 WRITE (output_unit, fmt="(A)") " Done, output in "//trim(output_file)
750 CALL m_flush(output_unit)
751 END IF
752 END IF
753 END DO
754 END IF
755
756 ! keep information about how long each process has to wait
757 ! i.e. the load imbalance
758 t1 = m_walltime()
759 CALL para_env%sync()
760 t2 = m_walltime()
761 ALLOCATE (waittime(0:para_env%num_pe - 1))
762 waittime = 0.0_dp
763 waittime(para_env%mepos) = t2 - t1
764 CALL para_env%sum(waittime)
765 IF (output_unit > 0) THEN
766 WRITE (output_unit, '(T2,A)') "Process idle times [s] at the end of the run"
767 DO i = 0, para_env%num_pe - 1
768 WRITE (output_unit, fmt='(A2,I6,A3,F8.3,A1)', advance="NO") &
769 " (", i, " : ", waittime(i), ")"
770 IF (mod(i + 1, 4) == 0) WRITE (output_unit, '(A)') ""
771 END DO
772 CALL m_flush(output_unit)
773 END IF
774 DEALLOCATE (waittime)
775
776 ! give back the communicators of the split groups
777 IF (minion) CALL new_group%free()
778 CALL minion_group%free()
779
780 ! and message passing deallocate structures
781 DEALLOCATE (group_distribution)
782 DEALLOCATE (minion_distribution)
783
784 ! clean the farming env
785 CALL deallocate_farming_env(farming_env)
786
787 CALL cp_print_key_finished_output(output_unit, logger, root_section, &
788 "FARMING%PROGRAM_RUN_INFO")
789
790 CALL timestop(handle)
791
792 CONTAINS
793! **************************************************************************************************
794!> \brief ...
795!> \param i ...
796! **************************************************************************************************
797 RECURSIVE SUBROUTINE execute_job(i)
798 INTEGER :: i
799
800 ! change to the new working directory
801
802 CALL m_chdir(trim(farming_env%Job(i)%cwd), ierr)
803 IF (ierr /= 0) &
804 cpabort("Failed to change dir to: "//trim(farming_env%Job(i)%cwd))
805
806 ! generate a fresh call to cp2k_run
807 IF (new_rank == 0) THEN
808
809 IF (farming_env%Job(i)%output == "") THEN
810 ! generate the output file
811 WRITE (output_file, '(A12,I5.5)') "FARMING_OUT_", i
812 ALLOCATE (my_parser)
813 CALL parser_create(my_parser, file_name=trim(farming_env%Job(i)%input))
814 label = "&GLOBAL"
815 CALL parser_search_string(my_parser, label, ignore_case=.true., found=found)
816 IF (found) THEN
817 CALL create_global_section(g_section)
818 CALL section_vals_create(g_data, g_section)
819 CALL cp_unit_set_create(default_units, "OUTPUT")
820 CALL section_vals_parse(g_data, my_parser, default_units)
821 CALL cp_unit_set_release(default_units)
822 CALL section_vals_val_get(g_data, "PROJECT", &
823 c_val=str)
824 IF (str /= "") output_file = trim(str)//".out"
825 CALL section_vals_val_get(g_data, "OUTPUT_FILE_NAME", &
826 c_val=str)
827 IF (str /= "") output_file = str
828 CALL section_vals_release(g_data)
829 CALL section_release(g_section)
830 END IF
831 CALL parser_release(my_parser)
832 DEALLOCATE (my_parser)
833 ELSE
834 output_file = farming_env%Job(i)%output
835 END IF
836
837 CALL open_file(file_name=trim(output_file), &
838 file_action="WRITE", &
839 file_status="UNKNOWN", &
840 file_position="APPEND", &
841 unit_number=new_output_unit)
842 ELSE
843 ! this unit should be negative, otherwise all processors that get a default unit
844 ! start writing output (to the same file, adding to confusion).
845 ! error handling should be careful, asking for a local output unit if required
846 new_output_unit = -1
847 END IF
848
849 CALL cp2k_run(input_declaration, trim(farming_env%Job(i)%input), new_output_unit, new_group, initial_variables)
850
851 IF (new_rank == 0) CALL close_file(unit_number=new_output_unit)
852
853 ! change to the original working directory
854 CALL m_chdir(trim(farming_env%cwd), ierr)
855 cpassert(ierr == 0)
856
857 END SUBROUTINE execute_job
858 END SUBROUTINE farming_run
859
860! **************************************************************************************************
861!> \brief ...
862! **************************************************************************************************
863 SUBROUTINE write_xml_file()
864
865 INTEGER :: i, unit_number
866 TYPE(section_type), POINTER :: root_section
867
868 NULLIFY (root_section)
869 CALL create_cp2k_root_section(root_section)
870 CALL keyword_release(root_section%keywords(0)%keyword)
871 CALL open_file(unit_number=unit_number, &
872 file_name="cp2k_input.xml", &
873 file_action="WRITE", &
874 file_status="REPLACE")
875
876 WRITE (unit=unit_number, fmt="(A)") '<?xml version="1.0" encoding="utf-8"?>'
877
878 !MK CP2K input structure
879 WRITE (unit=unit_number, fmt="(A)") &
880 "<CP2K_INPUT>", &
881 " <CP2K_VERSION>"//trim(cp2k_version)//"</CP2K_VERSION>", &
882 " <CP2K_YEAR>"//trim(cp2k_year)//"</CP2K_YEAR>", &
883 " <COMPILE_DATE>"//trim(compile_date)//"</COMPILE_DATE>", &
884 " <COMPILE_REVISION>"//trim(compile_revision)//"</COMPILE_REVISION>"
885
886 CALL export_references_as_xml(unit_number)
887 CALL export_units_as_xml(unit_number)
888
889 DO i = 1, root_section%n_subsections
890 CALL write_section_xml(root_section%subsections(i)%section, 1, unit_number)
891 END DO
892
893 WRITE (unit=unit_number, fmt="(A)") "</CP2K_INPUT>"
894 CALL close_file(unit_number=unit_number)
895 CALL section_release(root_section)
896
897 END SUBROUTINE write_xml_file
898
899! **************************************************************************************************
900!> \brief runs the given input
901!> \param input_declaration ...
902!> \param input_file_path the path of the input file
903!> \param output_file_path path of the output file (to which it is appended)
904!> if it is "__STD_OUT__" the default_output_unit is used
905!> \param initial_variables key-value list of initial preprocessor variables
906!> \param mpi_comm the mpi communicator to be used for this environment
907!> it will not be freed
908!> \author fawzi
909!> \note
910!> moved here because of circular dependencies
911! **************************************************************************************************
912 SUBROUTINE run_input(input_declaration, input_file_path, output_file_path, initial_variables, mpi_comm)
913 TYPE(section_type), POINTER :: input_declaration
914 CHARACTER(len=*), INTENT(in) :: input_file_path, output_file_path
915 CHARACTER(len=default_path_length), &
916 DIMENSION(:, :), INTENT(IN) :: initial_variables
917 TYPE(mp_comm_type), INTENT(in), OPTIONAL :: mpi_comm
918
919 INTEGER :: unit_nr
920 TYPE(mp_para_env_type), POINTER :: para_env
921
922 IF (PRESENT(mpi_comm)) THEN
923 ALLOCATE (para_env)
924 para_env = mpi_comm
925 ELSE
926 para_env => f77_default_para_env
927 CALL para_env%retain()
928 END IF
929 IF (para_env%is_source()) THEN
930 IF (output_file_path == "__STD_OUT__") THEN
931 unit_nr = default_output_unit
932 ELSE
933 INQUIRE (file=output_file_path, number=unit_nr)
934 END IF
935 ELSE
936 unit_nr = -1
937 END IF
938 CALL cp2k_run(input_declaration, input_file_path, unit_nr, para_env, initial_variables)
939 CALL mp_para_env_release(para_env)
940 END SUBROUTINE run_input
941
942END MODULE cp2k_runs
static GRID_HOST_DEVICE int modulo(int a, int m)
Equivalent of Fortran's MODULO, which always return a positive number. https://gcc....
void apply_cutoff(void *ptr)
void grid_library_set_config(const enum grid_backend backend, const bool validate, const bool apply_cutoff)
Configures the grid library.
void grid_library_print_stats(const int fortran_comm, void(*print_func)(const char *, int, int), const int output_unit)
Prints statistics gathered by the grid library.
Definition atom.F:9
subroutine, public atom_code(root_section)
Driver routine to perform atomic calculations.
Definition atom.F:46
collects all references to literature in CP2K as new algorithms / method are included from literature...
integer, save, public cp2kqs2020
integer, save, public iannuzzi2026
Module to perform a counterpoise correction (BSSE)
Definition bsse.F:14
subroutine, public do_bsse_calculation(force_env, globenv)
Perform an COUNTERPOISE CORRECTION (BSSE) For a 2-body system the correction scheme can be represente...
Definition bsse.F:79
performs CELL optimization
Definition cell_opt.F:13
subroutine, public cp_cell_opt(force_env, globenv)
Main driver to perform geometry optimization.
Definition cell_opt.F:56
Debug energy and derivatives w.r.t. finite differences.
Definition cp2k_debug.F:26
subroutine, public cp2k_debug_energy_and_forces(force_env)
...
Definition cp2k_debug.F:76
some minimal info about CP2K, including its version and license
Definition cp2k_info.F:16
character(len= *), parameter, public compile_revision
Definition cp2k_info.F:39
character(len= *), parameter, public compile_date
Definition cp2k_info.F:57
character(len= *), parameter, public cp2k_year
Definition cp2k_info.F:44
character(len= *), parameter, public cp2k_version
Definition cp2k_info.F:43
subroutine, public run_input(input_declaration, input_file_path, output_file_path, initial_variables, mpi_comm)
runs the given input
Definition cp2k_runs.F:913
subroutine, public write_xml_file()
...
Definition cp2k_runs.F:864
Defines control structures, which contain the parameters and the settings for the DFT-based calculati...
Utility routines to open and close files. Tracking of preconnections.
Definition cp_files.F:16
subroutine, public open_file(file_name, file_status, file_form, file_action, file_position, file_pad, unit_number, debug, skip_get_unit_number, file_access)
Opens the requested file using a free unit number.
Definition cp_files.F:311
subroutine, public close_file(unit_number, file_status, keep_preconnection)
Close an open file given by its logical unit number. Optionally, keep the file and unit preconnected.
Definition cp_files.F:122
various routines to log and control the output. The idea is that decisions about where to log should ...
logical function, public cp_logger_would_log(logger, level)
this function can be called to check if the logger would log a message with the given level from the ...
integer, parameter, public cp_note_level
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)
...
subroutine, public cp_print_key_finished_output(unit_nr, logger, basis_section, print_key_path, local, ignore_should_output, on_file, mpi_io)
should be called after you finish working with a unit obtained with cp_print_key_unit_nr,...
subroutine, public cp_rm_iter_level(iteration_info, level_name, n_rlevel_att)
Removes an iteration level.
subroutine, public cp_add_iter_level(iteration_info, level_name, n_rlevel_new)
Adds an iteration level.
Utility routines to read data from files. Kept as close as possible to the old parser because.
subroutine, public parser_search_string(parser, string, ignore_case, found, line, begin_line, search_from_begin_of_file)
Search a string pattern in a file defined by its logical unit number "unit". A case sensitive search ...
Utility routines to read data from files. Kept as close as possible to the old parser because.
subroutine, public parser_release(parser)
releases the parser
subroutine, public parser_create(parser, file_name, unit_nr, para_env, end_section_label, separator_chars, comment_char, continuation_char, quote_char, section_char, parse_white_lines, initial_variables, apply_preprocessing)
Start a parser run. Initial variables allow to @SET stuff before opening the file.
unit conversion facility
Definition cp_units.F:30
subroutine, public cp_unit_set_release(unit_set)
releases the given unit set
Definition cp_units.F:1298
subroutine, public cp_unit_set_create(unit_set, name)
initializes the given unit set
Definition cp_units.F:1227
subroutine, public export_units_as_xml(iw)
Exports all available units as XML.
Definition cp_units.F:1315
subroutine validate(matrix)
Dummy for when DBM_VALIDATE_AGAINST_DBCSR is not defined.
Definition dbm_api.F:250
subroutine, public dbm_library_print_stats(mpi_comm, output_unit)
Print DBM library statistics.
Definition dbm_api.F:1512
Sets up and terminates the global environment variables.
Definition environment.F:17
subroutine, public cp2k_finalize(root_section, para_env, globenv, wdir, q_finalize)
Writes final timings and banner for CP2K.
subroutine, public cp2k_read(root_section, para_env, globenv)
read part of cp2k_init
subroutine, public cp2k_init(para_env, output_unit, globenv, input_file_name, wdir)
Initializes a CP2K run (setting of the global environment variables)
subroutine, public cp2k_setup(root_section, para_env, globenv)
globenv initializations that need the input and error
interface to use cp2k as library
recursive subroutine, public destroy_force_env(env_id, ierr, q_finalize)
deallocates the force_env with the given id
subroutine, public f_env_add_defaults(f_env_id, f_env, handle)
adds the default environments of the f_env to the stack of the defaults, and returns a new error and ...
type(mp_para_env_type), pointer, save, public default_para_env
recursive subroutine, public create_force_env(new_env_id, input_declaration, input_path, output_path, mpi_comm, output_unit, owns_out_unit, input, ierr, work_dir, initial_variables)
creates a new force environment using the given input, and writing the output to the given output uni...
subroutine, public f_env_rm_defaults(f_env, ierr, handle)
removes the default environments of the f_env to the stack of the defaults, and sets ierr accordingly...
recursive subroutine, public calc_force(env_id, pos, n_el_pos, e_pot, force, n_el_force, ierr)
returns the energy of the configuration given by the positions passed as argument
subroutine, public farming_parse_input(farming_env, root_section, para_env)
...
integer, parameter, public do_nothing
integer, parameter, public do_wait
subroutine, public get_next_job(farming_env, start, end, current, todo)
...
integer, parameter, public do_deadlock
subroutine, public deallocate_farming_env(farming_env)
deallocates all associated fields of the farming_env type and the type itself
integer, parameter, public job_finished
integer, parameter, public job_running
subroutine, public init_farming_env(farming_env)
help poor compilers do their job i.e. provide a default initialization
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
performs geometry optimization
Definition geo_opt.F:13
subroutine, public cp_geo_opt(force_env, globenv, eval_opt_geo, rm_restart_info)
Main driver to perform geometry optimization.
Definition geo_opt.F:58
Define type storing the global information of a run. Keep the amount of stored data small....
subroutine, public globenv_create(globenv)
Creates the global environment globenv.
subroutine, public globenv_release(globenv)
Releases the global environment globenv.
Fortran API for the grid package, which is written in C.
Definition grid_api.F:12
collects all constants needed in input so that they can be used without circular dependencies
integer, parameter, public driver_run
integer, parameter, public energy_run
integer, parameter, public do_farming
integer, parameter, public do_nnp
integer, parameter, public do_cp2k
integer, parameter, public linear_response_run
integer, parameter, public do_tamc
integer, parameter, public ehrenfest
integer, parameter, public do_opt_basis
integer, parameter, public debug_run
integer, parameter, public do_test
integer, parameter, public do_fist
integer, parameter, public do_qmmm
integer, parameter, public do_embed
integer, parameter, public do_sirius
integer, parameter, public do_band
integer, parameter, public do_tree_mc
integer, parameter, public bsse_run
integer, parameter, public mimic_run
integer, parameter, public energy_force_run
integer, parameter, public rtp_method_bse
integer, parameter, public do_optimize_input
integer, parameter, public do_atom
integer, parameter, public mon_car_run
integer, parameter, public do_tree_mc_ana
integer, parameter, public mol_dyn_run
integer, parameter, public cell_opt_run
integer, parameter, public pint_run
integer, parameter, public vib_anal
integer, parameter, public none_run
integer, parameter, public negf_run
integer, parameter, public do_qs
integer, parameter, public do_mixed
integer, parameter, public do_ipi
integer, parameter, public tree_mc_run
integer, parameter, public real_time_propagation
integer, parameter, public geo_opt_run
integer, parameter, public do_swarm
checks the input and perform some automatic "magic" on it
subroutine, public check_cp2k_input(input_declaration, input_file, para_env, output_unit)
performs further checks on an input that parsed successfully
builds the global input section for cp2k
subroutine, public create_global_section(section)
section to hold global settings for the whole program
parse cp2k input files
type(section_vals_type) function, pointer, public read_input(input_declaration, file_path, initial_variables, para_env)
reads the cp2k input from the given filepath and returns a section_vals containing the input
builds the input structure for cp2k
Definition input_cp2k.F:14
subroutine, public create_cp2k_root_section(root_section)
creates the input structure of the file used by cp2k
Definition input_cp2k.F:75
represents keywords in an input
subroutine, public keyword_release(keyword)
releases the given keyword (see doc/ReferenceCounting.html)
routines that parse the input
recursive subroutine, public section_vals_parse(section_vals, parser, default_units, root_section)
...
objects that represent the structure of input sections and the data contained in an input section
recursive subroutine, public write_section_xml(section, level, unit_number)
writes the values in the given section in xml
recursive subroutine, public section_vals_create(section_vals, section)
creates a object where to store the values of a section
subroutine, public section_vals_retain(section_vals)
retains the given section values (see doc/ReferenceCounting.html)
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
recursive subroutine, public section_release(section)
releases the given keyword list (see doc/ReferenceCounting.html)
recursive subroutine, public section_vals_write(section_vals, unit_nr, hide_root, hide_defaults)
writes the values in the given section in a way that is suitable to the automatic parsing
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
recursive subroutine, public section_vals_release(section_vals)
releases the given object
Driver mode - To communicate with i-PI Python wrapper.
Definition ipi_driver.F:14
subroutine, public run_driver(force_env, globenv)
...
Definition ipi_driver.F:76
Defines the basic variable types.
Definition kinds.F:23
integer, parameter, public int_8
Definition kinds.F:54
integer, parameter, public dp
Definition kinds.F:34
integer, parameter, public default_string_length
Definition kinds.F:57
integer, parameter, public default_path_length
Definition kinds.F:58
Performance tests for basic tasks like matrix multiplies, copy, fft.
subroutine, public lib_test(root_section, para_env, globenv)
Master routine for tests.
Machine interface based on Fortran 2003 and POSIX.
Definition machine.F:17
integer, parameter, public default_output_unit
Definition machine.F:58
subroutine, public m_memory(mem)
Returns the total amount of memory [bytes] in use, if known, zero otherwise.
Definition machine.F:452
subroutine, public m_flush(lunit)
flushes units if the &GLOBAL flag is set accordingly
Definition machine.F:136
subroutine, public m_getcwd(curdir)
...
Definition machine.F:619
subroutine, public m_chdir(dir, ierror)
...
Definition machine.F:648
integer(kind=int_8), save, public m_memory_max
Definition machine.F:123
real(kind=dp) function, public m_walltime()
returns time from a real-time clock, protected against rolling early/easily
Definition machine.F:153
preps the system for a Monte Carlo run (sets up some environments, calls the routines to read in the ...
Definition mc_run.F:40
subroutine, public do_mon_car(force_env_1, globenv, input_declaration, input_file_name)
starts the Monte Carlo simulation and determines which ensemble we're running
Definition mc_run.F:103
Perform a molecular dynamics (MD) run using QUICKSTEP.
Definition md_run.F:14
subroutine, public qs_mol_dyn(force_env, globenv, averages, rm_restart_info, hmc_e_initial, hmc_e_final, mdctrl)
Main driver module for Molecular Dynamics.
Definition md_run.F:122
Interface to the message passing library MPI.
subroutine, public mp_para_env_release(para_env)
releases the para object (to be called when you don't want anymore the shared copy of this object)
integer, parameter, public mp_any_source
Module containing the main loop for simulations with the MiMiC framework.
Definition mimic_loop.F:15
subroutine, public do_mimic_loop(force_env)
The main loop for a MiMiC run.
Definition mimic_loop.F:48
Subroutines to perform calculations on molecules from a bigger system. Useful to generate a high-qual...
subroutine, public loop_over_molecules(globenv, force_env)
Prepare data for calculations on isolated molecules.
logical function, public do_mol_loop(force_env)
Is the loop over molecules requested?
Module performing a Nudged Elastic Band Calculation.
Definition neb_methods.F:23
subroutine, public neb(input, input_declaration, para_env, globenv)
Real subroutine for NEB calculations.
Definition neb_methods.F:93
NEGF based quantum transport calculations.
subroutine, public do_negf(force_env)
Perform NEGF calculation.
Fortran API for the offload package, which is written in C.
Definition offload_api.F:12
integer function, public offload_get_device_count()
Returns the number of available devices.
subroutine, public offload_mempool_stats_print(mpi_comm, output_unit)
Print allocation statistics.
integer function, public offload_get_chosen_device()
Returns the chosen device.
subroutine, public run_optimize_basis(input_declaration, root_section, para_env)
main entry point for methods aimed at optimizing basis sets
subroutine, public run_optimize_input(input_declaration, root_section, para_env)
main entry point for methods aimed at optimizing parameters in a CP2K input file
Methods to performs a path integral run.
subroutine, public do_pint_run(para_env, input, input_declaration, globenv)
Perform a path integral simulation.
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.
Contains the setup for the calculation of properties by linear response by the application of second ...
subroutine, public linres_calculation(force_env)
Driver for the linear response calculatios.
provides a uniform framework to add references to CP2K cite and output these
subroutine, public cite_reference(key)
marks a given reference as cited.
subroutine, public export_references_as_xml(unit)
Exports all references as XML.
Routines for the propagation via RT-BSE method.
Definition rt_bse.F:14
subroutine, public run_propagation_bse(qs_env, force_env)
Runs the electron-only real time BSE propagation.
Definition rt_bse.F:142
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
Swarm-framwork, provides a convenient master/worker architecture.
Definition swarm.F:12
subroutine, public run_swarm(input_declaration, root_section, para_env, globenv, input_path)
Central driver routine of the swarm framework, called by cp2k_runs.F.
Definition swarm.F:62
Perform a temperature accelarated hybrid monte carlo (TAHMC) run using QUICKSTEP.
Definition tamc_run.F:14
subroutine, public qs_tamc(force_env, globenv, averages)
Driver routine for TAHMC.
Definition tamc_run.F:147
Tree Monte Carlo entry point, set up, CPU redistribution and input reading.
Definition tmc_setup.F:16
subroutine, public do_analyze_files(input_declaration, root_section, para_env)
analyze TMC trajectory files
Definition tmc_setup.F:348
subroutine, public do_tmc(input_declaration, root_section, para_env, globenv)
tmc_entry point
Definition tmc_setup.F:98
Module performing a vibrational analysis.
subroutine, public vb_anal(input, input_declaration, para_env, globenv)
Module performing a vibrational analysis.
type of a logger, at the moment it contains just a print level starting at which level it should be l...
stores the default units to be used
Definition cp_units.F:149
wrapper to abstract the force evaluation of the various methods
contains the initially parsed file and the initial parallel environment
represent a section of the input file
stores all the informations relevant to an mpi environment