Line data Source code
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 Sets up and terminates the global environment variables
10 : !> \par History
11 : !> - Merged with Quickstep MODULE start_program_run (17.01.2002,MK)
12 : !> - Compile information added (16.01.2002,MK)
13 : !> - Merged with MODULE cp2k_input, some rearrangements (30.10.2002,MK)
14 : !> - Update seed input (24.10.2016,MK)
15 : !> \author JGH,MK
16 : ! **************************************************************************************************
17 : MODULE environment
18 : USE bibliography, ONLY: Frigo2005,&
19 : Marek2014,&
20 : Solca2024,&
21 : cite_reference
22 : USE cp2k_info, ONLY: &
23 : compile_arch, compile_date, compile_host, compile_revision, cp2k_flags, cp2k_home, &
24 : cp2k_version, cp2k_year, get_runtime_info, r_host_name, r_pid, r_user_name
25 : USE cp_error_handling, ONLY: warning_counter
26 : USE cp_files, ONLY: close_file,&
27 : get_data_dir,&
28 : open_file
29 : USE cp_fm_cholesky, ONLY: FM_CHOLESKY_TYPE_DLAF,&
30 : FM_CHOLESKY_TYPE_SCALAPACK,&
31 : cholesky_type,&
32 : dlaf_cholesky_n_min
33 : USE cp_fm_diag, ONLY: FM_DIAG_TYPE_CUSOLVER,&
34 : FM_DIAG_TYPE_DLAF,&
35 : FM_DIAG_TYPE_ELPA,&
36 : FM_DIAG_TYPE_SCALAPACK,&
37 : cusolver_n_min,&
38 : diag_finalize,&
39 : diag_init,&
40 : eps_check_diag_default
41 : USE cp_fm_diag_utils, ONLY: cp_fm_redistribute_init
42 : USE cp_fm_struct, ONLY: cp_fm_struct_config
43 : USE cp_fm_types, ONLY: cp_fm_get_mm_type,&
44 : cp_fm_setup
45 : USE cp_log_handling, ONLY: &
46 : cp_add_default_logger, cp_get_default_logger, cp_logger_create, &
47 : cp_logger_get_default_unit_nr, cp_logger_release, cp_logger_set, cp_logger_type, &
48 : cp_rm_default_logger, cp_to_string
49 : USE cp_output_handling, ONLY: cp_mpi_io_set,&
50 : cp_print_key_finished_output,&
51 : cp_print_key_unit_nr,&
52 : debug_print_level,&
53 : high_print_level,&
54 : low_print_level,&
55 : medium_print_level,&
56 : silent_print_level
57 : USE fft_tools, ONLY: FWFFT,&
58 : fft3d,&
59 : finalize_fft,&
60 : init_fft
61 : USE force_env_types, ONLY: multiple_fe_list
62 : USE gamma, ONLY: deallocate_md_ftable
63 : USE global_types, ONLY: global_environment_type
64 : USE grid_api, ONLY: GRID_BACKEND_AUTO,&
65 : GRID_BACKEND_CPU,&
66 : GRID_BACKEND_DGEMM,&
67 : GRID_BACKEND_GPU,&
68 : GRID_BACKEND_REF
69 : USE header, ONLY: cp2k_footer,&
70 : cp2k_header
71 : USE input_constants, ONLY: &
72 : callgraph_all, callgraph_none, do_cosma, do_cp2k, do_dgemm_blas, do_dgemm_spla, do_eip, &
73 : do_farming, do_fft_fftw3, do_fft_sg, do_fist, do_qs, do_scalapack, do_sirius, do_test, &
74 : energy_run, mol_dyn_run, none_run
75 : USE input_cp2k_global, ONLY: create_global_section
76 : USE input_enumeration_types, ONLY: enum_i2c,&
77 : enumeration_type
78 : USE input_keyword_types, ONLY: keyword_get,&
79 : keyword_type
80 : USE input_section_types, ONLY: &
81 : section_get_ival, section_get_keyword, section_get_lval, section_get_rval, &
82 : section_release, section_type, section_vals_get, section_vals_get_subs_vals, &
83 : section_vals_get_subs_vals3, section_vals_type, section_vals_val_get, section_vals_val_set
84 : USE kinds, ONLY: default_path_length,&
85 : default_string_length,&
86 : dp,&
87 : int_8,&
88 : print_kind_info
89 : USE local_gemm_api, ONLY: local_gemm_set_library
90 : USE machine, ONLY: &
91 : flush_should_flush, m_cpuid, m_cpuid_name, m_cpuid_static, m_cpuid_vlen, m_cpuinfo, &
92 : m_energy, m_memory_details, m_omp_get_stacksize, m_omp_trace_issues, m_procrun
93 : USE message_passing, ONLY: mp_collect_timings,&
94 : mp_para_env_type
95 : USE mp_perf_env, ONLY: add_mp_perf_env,&
96 : describe_mp_perf_env,&
97 : rm_mp_perf_env
98 : USE orbital_pointers, ONLY: deallocate_orbital_pointers,&
99 : init_orbital_pointers
100 : USE orbital_transformation_matrices, ONLY: deallocate_spherical_harmonics,&
101 : init_spherical_harmonics
102 : USE parallel_rng_types, ONLY: GAUSSIAN,&
103 : check_rng,&
104 : rng_stream_type,&
105 : write_rng_matrices
106 : USE physcon, ONLY: write_physcon
107 : USE reference_manager, ONLY: collect_citations_from_ranks,&
108 : print_cited_references
109 : USE string_utilities, ONLY: ascii_to_string,&
110 : integer_to_string,&
111 : string_to_ascii
112 : USE timings, ONLY: add_timer_env,&
113 : global_timings_level,&
114 : rm_timer_env,&
115 : root_cp2k_name,&
116 : timings_setup_tracing
117 : USE timings_report, ONLY: cost_type_energy,&
118 : cost_type_time,&
119 : timings_report_callgraph,&
120 : timings_report_print
121 : USE voronoi_interface, ONLY: finalize_libvori
122 :
123 : !$ USE OMP_LIB, ONLY: omp_get_max_threads, omp_get_thread_num, omp_get_num_threads
124 : #include "./base/base_uses.f90"
125 :
126 : IMPLICIT NONE
127 :
128 : PRIVATE
129 :
130 : CHARACTER(len=*), PARAMETER, PRIVATE :: moduleN = 'environment'
131 :
132 : ! Public subroutines
133 :
134 : PUBLIC :: cp2k_finalize, cp2k_init, cp2k_read, cp2k_setup, cp2k_get_walltime
135 :
136 : CONTAINS
137 :
138 : ! **************************************************************************************************
139 : !> \brief Initializes a CP2K run (setting of the global environment variables)
140 : !> \param para_env ...
141 : !> \param output_unit ...
142 : !> \param globenv ...
143 : !> \param input_file_name ...
144 : !> \param wdir ...
145 : !> \par History
146 : !> JGH (28.11.2001) : default for pp_library_path
147 : !> - print keys added (17.01.2002, MK)
148 : !> - merged with cp2k_input (30.10.2002,MK)
149 : !> \author JGH,MK
150 : ! **************************************************************************************************
151 10863 : SUBROUTINE cp2k_init(para_env, output_unit, globenv, input_file_name, wdir)
152 :
153 : TYPE(mp_para_env_type), POINTER :: para_env
154 : INTEGER :: output_unit
155 : TYPE(global_environment_type), POINTER :: globenv
156 : CHARACTER(LEN=*) :: input_file_name
157 : CHARACTER(LEN=*), OPTIONAL :: wdir
158 :
159 : CHARACTER(LEN=10*default_string_length) :: cp_flags
160 : INTEGER :: i, ilen, my_output_unit
161 : TYPE(cp_logger_type), POINTER :: logger
162 :
163 : ! create a timer_env
164 :
165 10863 : CALL add_timer_env()
166 :
167 : ! Message passing performance
168 10863 : CALL add_mp_perf_env()
169 :
170 : ! Init the default logger
171 10863 : IF (para_env%is_source()) THEN
172 5537 : my_output_unit = output_unit
173 : ELSE
174 5326 : my_output_unit = -1
175 : END IF
176 10863 : NULLIFY (logger)
177 : CALL cp_logger_create(logger, para_env=para_env, &
178 : default_global_unit_nr=output_unit, &
179 10863 : close_global_unit_on_dealloc=.FALSE.)
180 10863 : CALL cp_add_default_logger(logger)
181 10863 : CALL cp_logger_release(logger)
182 :
183 : ! Initialize timing
184 10863 : CALL timeset(root_cp2k_name, globenv%handle)
185 :
186 : ! Print header
187 11387 : CALL cp2k_header(my_output_unit, wdir)
188 :
189 10863 : IF (my_output_unit > 0) THEN
190 : WRITE (UNIT=my_output_unit, FMT="(/,T2,A,T31,A50)") &
191 5537 : "CP2K| version string: ", ADJUSTR(TRIM(cp2k_version))
192 : WRITE (UNIT=my_output_unit, FMT="(T2,A,T41,A40)") &
193 5537 : "CP2K| source code revision number:", &
194 11074 : ADJUSTR(compile_revision)
195 5537 : cp_flags = cp2k_flags()
196 5537 : ilen = LEN_TRIM(cp_flags)
197 : WRITE (UNIT=my_output_unit, FMT="(T2,A)") &
198 5537 : "CP2K| "//cp_flags(1:73)
199 5537 : IF (ilen > 73) THEN
200 27685 : DO i = 0, (ilen - 75)/61
201 : WRITE (UNIT=my_output_unit, FMT="(T2,A)") &
202 27685 : "CP2K| "//TRIM(cp_flags(74 + i*61:MIN(74 + (i + 1)*61, ilen)))
203 : END DO
204 : END IF
205 : WRITE (UNIT=my_output_unit, FMT="(T2,A,T41,A40)") &
206 5537 : "CP2K| is freely available from ", &
207 11074 : ADJUSTR(TRIM(cp2k_home))
208 : WRITE (UNIT=my_output_unit, FMT="(T2,A,T31,A50)") &
209 5537 : "CP2K| Program compiled at", &
210 11074 : ADJUSTR(compile_date(1:MIN(50, LEN(compile_date))))
211 : WRITE (UNIT=my_output_unit, FMT="(T2,A,T31,A50)") &
212 5537 : "CP2K| Program compiled on", &
213 11074 : ADJUSTR(compile_host(1:MIN(50, LEN(compile_host))))
214 : WRITE (UNIT=my_output_unit, FMT="(T2,A,T31,A50)") &
215 5537 : "CP2K| Program compiled for", &
216 11074 : ADJUSTR(compile_arch(1:MIN(50, LEN(compile_arch))))
217 : WRITE (UNIT=my_output_unit, FMT="(T2,A,T31,A50)") &
218 5537 : "CP2K| Data directory path", &
219 11074 : ADJUSTR(TRIM(get_data_dir()))
220 : WRITE (UNIT=my_output_unit, FMT="(T2,A,T31,A50)") &
221 5537 : "CP2K| Input file name", &
222 11074 : ADJUSTR(TRIM(input_file_name))
223 5537 : FLUSH (my_output_unit) ! ignore &GLOBAL / FLUSH_SHOULD_FLUSH
224 : END IF
225 :
226 : #if defined(__FAST_MATH__)
227 : CALL cp_warn(__LOCATION__, &
228 : "During compilation one of the following flags was active:"// &
229 : " `-ffast-math` (GCC)"// &
230 : " `-hfpN` (Cray, N > 0, default N=2)"// &
231 : " This can lead to wrong results and numerical instabilities"// &
232 : " and is therefore no longer supported.")
233 :
234 : #if !defined(__FORCE_USE_FAST_MATH)
235 : #error "-ffast-math (GCC) or -hfpN (N>0, Cray) can lead to wrong results and numerical instabilities and are therefore no longer supported"
236 : #endif
237 : #endif
238 :
239 : #if defined(NDEBUG)
240 : #error "Please do not build CP2K with NDEBUG. There is no performance advantage and asserts will save your neck."
241 : #endif
242 :
243 10863 : END SUBROUTINE cp2k_init
244 :
245 : ! **************************************************************************************************
246 : !> \brief echoes the list of host names and pids
247 : !> \param para_env ...
248 : !> \param output_unit ...
249 : ! **************************************************************************************************
250 2 : SUBROUTINE echo_all_hosts(para_env, output_unit)
251 : TYPE(mp_para_env_type), POINTER :: para_env
252 : INTEGER, INTENT(IN) :: output_unit
253 :
254 : CHARACTER(LEN=default_string_length) :: string
255 : INTEGER :: ipe
256 2 : INTEGER, ALLOCATABLE, DIMENSION(:) :: all_pid
257 : INTEGER, ALLOCATABLE, DIMENSION(:, :) :: all_host
258 :
259 : ! Print a list of all started processes
260 :
261 6 : ALLOCATE (all_pid(para_env%num_pe), SOURCE=0)
262 2 : all_pid(para_env%mepos + 1) = r_pid
263 :
264 2 : CALL para_env%sum(all_pid)
265 6 : ALLOCATE (all_host(30, para_env%num_pe), SOURCE=0)
266 :
267 2 : CALL string_to_ascii(r_host_name, all_host(:, para_env%mepos + 1))
268 2 : CALL para_env%sum(all_host)
269 2 : IF (output_unit > 0) THEN
270 1 : WRITE (UNIT=output_unit, FMT="(T2,A)") ""
271 3 : DO ipe = 1, para_env%num_pe
272 2 : CALL ascii_to_string(all_host(:, ipe), string)
273 : WRITE (UNIT=output_unit, FMT="(T2,A,T63,I8,T71,I10)") &
274 : TRIM(r_user_name)//"@"//TRIM(string)// &
275 3 : " has created rank and process ", ipe - 1, all_pid(ipe)
276 : END DO
277 : END IF
278 :
279 2 : DEALLOCATE (all_pid)
280 2 : DEALLOCATE (all_host)
281 :
282 2 : END SUBROUTINE echo_all_hosts
283 :
284 : ! **************************************************************************************************
285 : !> \brief echoes the list the number of process per host
286 : !> \param para_env ...
287 : !> \param output_unit ...
288 : !> \param node_count Count number of distributed systems (nodes)
289 : ! **************************************************************************************************
290 10863 : SUBROUTINE echo_all_process_host(para_env, output_unit, node_count)
291 : TYPE(mp_para_env_type), POINTER :: para_env
292 : INTEGER, INTENT(IN) :: output_unit
293 : INTEGER, INTENT(OUT), OPTIONAL :: node_count
294 :
295 : CHARACTER(LEN=default_string_length) :: string, string_sec
296 : INTEGER :: ipe, jpe, nr_dist, nr_occu
297 10863 : INTEGER, ALLOCATABLE, DIMENSION(:) :: all_pid
298 10863 : INTEGER, ALLOCATABLE, DIMENSION(:, :) :: all_host
299 :
300 32589 : ALLOCATE (all_host(30, para_env%num_pe), SOURCE=0)
301 32589 : ALLOCATE (all_pid(para_env%num_pe), SOURCE=0)
302 :
303 10863 : IF (m_procrun(r_pid) == 1) THEN
304 10863 : CALL string_to_ascii(r_host_name, all_host(:, para_env%mepos + 1))
305 10863 : CALL para_env%sum(all_host)
306 : END IF
307 :
308 10863 : nr_dist = 0
309 10863 : IF (output_unit > 0) WRITE (UNIT=output_unit, FMT="(T2,A)") ""
310 32378 : DO ipe = 1, para_env%num_pe
311 21515 : nr_occu = 0
312 32378 : IF (all_pid(ipe) /= -1) THEN
313 10863 : CALL ascii_to_string(all_host(:, ipe), string)
314 32378 : DO jpe = 1, para_env%num_pe
315 21515 : CALL ascii_to_string(all_host(:, jpe), string_sec)
316 32378 : IF (string == string_sec) THEN
317 21515 : nr_occu = nr_occu + 1
318 21515 : all_pid(jpe) = -1
319 : END IF
320 : END DO
321 10863 : IF (output_unit > 0) THEN
322 : WRITE (UNIT=output_unit, FMT="(T2,A,T63,I8,A)") &
323 : TRIM(r_user_name)//"@"//TRIM(string)// &
324 1 : " is running ", nr_occu, " processes"
325 : END IF
326 10863 : nr_dist = nr_dist + 1
327 : END IF
328 : END DO
329 :
330 10863 : DEALLOCATE (all_pid)
331 10863 : DEALLOCATE (all_host)
332 :
333 10863 : CPASSERT(0 < nr_dist)
334 10863 : IF (PRESENT(node_count)) node_count = nr_dist
335 :
336 10863 : END SUBROUTINE echo_all_process_host
337 :
338 : ! **************************************************************************************************
339 : !> \brief read part of cp2k_init
340 : !> \param root_section ...
341 : !> \param para_env ...
342 : !> \param globenv the globenv
343 : !> \author fawzi
344 : !> \note
345 : !> The following routines need to be synchronized wrt. adding/removing
346 : !> of the default environments (logging, performance,error):
347 : !> environment:cp2k_init, environment:cp2k_finalize,
348 : !> f77_interface:f_env_add_defaults, f77_interface:f_env_rm_defaults,
349 : !> f77_interface:create_force_env, f77_interface:destroy_force_env
350 : ! **************************************************************************************************
351 10863 : SUBROUTINE cp2k_read(root_section, para_env, globenv)
352 :
353 : TYPE(section_vals_type), POINTER :: root_section
354 : TYPE(mp_para_env_type), POINTER :: para_env
355 : TYPE(global_environment_type), POINTER :: globenv
356 :
357 : CHARACTER(LEN=3*default_string_length) :: message
358 : CHARACTER(LEN=default_string_length) :: c_val
359 : INTEGER :: i, iw
360 : TYPE(cp_logger_type), POINTER :: logger
361 :
362 : ! Read the input/output section
363 :
364 10863 : logger => cp_get_default_logger()
365 :
366 : ! try to use better names for the local log if it is not too late
367 : CALL section_vals_val_get(root_section, "GLOBAL%OUTPUT_FILE_NAME", &
368 10863 : c_val=c_val)
369 10863 : IF (c_val /= "") THEN
370 : CALL cp_logger_set(logger, &
371 148 : local_filename=TRIM(c_val)//"_localLog")
372 : END IF
373 :
374 : ! Process project name
375 10863 : CALL section_vals_val_get(root_section, "GLOBAL%PROJECT", c_val=c_val)
376 10863 : IF (INDEX(c_val(:LEN_TRIM(c_val)), " ") > 0) THEN
377 : message = "Project name <"//TRIM(c_val)// &
378 2 : "> contains spaces which will be replaced with underscores"
379 2 : CPWARN(TRIM(message))
380 24 : DO i = 1, LEN_TRIM(c_val)
381 : ! Replace space with underscore
382 24 : IF (c_val(i:i) == " ") c_val(i:i) = "_"
383 : END DO
384 2 : CALL section_vals_val_set(root_section, "GLOBAL%PROJECT", c_val=TRIM(c_val))
385 : END IF
386 10863 : IF (c_val /= "") THEN
387 10863 : CALL cp_logger_set(logger, local_filename=TRIM(c_val)//"_localLog")
388 : END IF
389 10863 : logger%iter_info%project_name = c_val
390 :
391 10863 : CALL section_vals_val_get(root_section, "GLOBAL%PRINT_LEVEL", i_val=logger%iter_info%print_level)
392 :
393 : ! Read the CP2K section
394 10863 : CALL read_cp2k_section(root_section, para_env, globenv)
395 :
396 : iw = cp_print_key_unit_nr(logger, root_section, "GLOBAL%PRINT/BASIC_DATA_TYPES", &
397 10863 : extension=".Log")
398 10863 : IF (iw > 0) CALL print_kind_info(iw)
399 : CALL cp_print_key_finished_output(iw, logger, root_section, &
400 10863 : "GLOBAL%PRINT/BASIC_DATA_TYPES")
401 :
402 : iw = cp_print_key_unit_nr(logger, root_section, "GLOBAL%PRINT/PHYSCON", &
403 10863 : extension=".Log")
404 10863 : IF (iw > 0) CALL write_physcon(iw)
405 : CALL cp_print_key_finished_output(iw, logger, root_section, &
406 10863 : "GLOBAL%PRINT/PHYSCON")
407 :
408 10863 : END SUBROUTINE cp2k_read
409 :
410 : ! **************************************************************************************************
411 : !> \brief globenv initializations that need the input and error
412 : !> \param root_section ...
413 : !> \param para_env ...
414 : !> \param globenv the global environment to initialize
415 : !> \author fawzi
416 : !> \note
417 : !> if possible do the initializations here as the environment
418 : !> (error,...) is setup, instead of cp2k_init
419 : ! **************************************************************************************************
420 21726 : SUBROUTINE cp2k_setup(root_section, para_env, globenv)
421 :
422 : TYPE(section_vals_type), POINTER :: root_section
423 : TYPE(mp_para_env_type), POINTER :: para_env
424 : TYPE(global_environment_type), POINTER :: globenv
425 :
426 : INTEGER :: iw, maxl
427 10863 : INTEGER, DIMENSION(:), POINTER :: seed_vals
428 : REAL(KIND=dp), DIMENSION(3, 2) :: initial_seed
429 : TYPE(cp_logger_type), POINTER :: logger
430 :
431 10863 : NULLIFY (logger)
432 21726 : logger => cp_get_default_logger()
433 :
434 : ! Initialize the parallel random number generator
435 :
436 : iw = cp_print_key_unit_nr(logger, root_section, "GLOBAL%PRINT/RNG_MATRICES", &
437 10863 : extension=".Log")
438 10863 : IF (iw > 0) THEN
439 1 : CALL write_rng_matrices(iw)
440 : END IF
441 :
442 : CALL cp_print_key_finished_output(iw, logger, root_section, &
443 10863 : "GLOBAL%PRINT/RNG_MATRICES")
444 :
445 : ! Initialize a global normally Gaussian distributed (pseudo)random number stream
446 :
447 10863 : CALL section_vals_val_get(root_section, "GLOBAL%SEED", i_vals=seed_vals)
448 10863 : IF (SIZE(seed_vals) == 1) THEN
449 97767 : initial_seed(:, :) = REAL(seed_vals(1), KIND=dp)
450 0 : ELSE IF (SIZE(seed_vals) == 6) THEN
451 0 : initial_seed(1:3, 1:2) = RESHAPE(REAL(seed_vals(:), KIND=dp), [3, 2])
452 : ELSE
453 0 : CPABORT("Supply exactly 1 or 6 arguments for SEED in &GLOBAL only!")
454 : END IF
455 :
456 : globenv%gaussian_rng_stream = rng_stream_type( &
457 : name="Global Gaussian random numbers", &
458 : distribution_type=GAUSSIAN, &
459 : seed=initial_seed, &
460 10863 : extended_precision=.TRUE.)
461 :
462 : iw = cp_print_key_unit_nr(logger, root_section, "GLOBAL%PRINT/RNG_CHECK", &
463 10863 : extension=".Log")
464 10863 : IF (iw > 0) THEN
465 1 : CALL check_rng(iw, para_env%is_source())
466 : END IF
467 :
468 : CALL cp_print_key_finished_output(iw, logger, root_section, &
469 10863 : "GLOBAL%PRINT/RNG_CHECK")
470 :
471 : iw = cp_print_key_unit_nr(logger, root_section, "GLOBAL%PRINT/GLOBAL_GAUSSIAN_RNG", &
472 10863 : extension=".Log")
473 10863 : IF (iw > 0) &
474 1 : CALL globenv%gaussian_rng_stream%write(iw, write_all=.TRUE.)
475 :
476 : CALL cp_print_key_finished_output(iw, logger, root_section, &
477 10863 : "GLOBAL%PRINT/GLOBAL_GAUSSIAN_RNG")
478 :
479 10863 : CALL section_vals_val_get(root_section, "GLOBAL%PRINT%SPHERICAL_HARMONICS", i_val=maxl)
480 10863 : IF (maxl >= 0) THEN
481 : iw = cp_print_key_unit_nr(logger, root_section, "GLOBAL%PRINT", &
482 2 : extension=".Log")
483 2 : CALL init_orbital_pointers(maxl)
484 2 : CALL init_spherical_harmonics(maxl, iw)
485 2 : CALL deallocate_spherical_harmonics()
486 2 : CALL deallocate_orbital_pointers()
487 : CALL cp_print_key_finished_output(iw, logger, root_section, &
488 2 : "GLOBAL%PRINT")
489 : END IF
490 :
491 10863 : END SUBROUTINE cp2k_setup
492 :
493 : ! **************************************************************************************************
494 : !> \brief read the global section of new input
495 : !> \param root_section ...
496 : !> \param para_env ...
497 : !> \param globenv ...
498 : !> \par History
499 : !> 06-2005 [created]
500 : !> \author MI
501 : !> \note
502 : !> Should not be required anymore once everything is converted
503 : !> to get information directly from the input structure
504 : ! **************************************************************************************************
505 162945 : SUBROUTINE read_global_section(root_section, para_env, globenv)
506 :
507 : TYPE(section_vals_type), POINTER :: root_section
508 : TYPE(mp_para_env_type), POINTER :: para_env
509 : TYPE(global_environment_type), POINTER :: globenv
510 :
511 : CHARACTER(LEN=6), PARAMETER :: start_section_label = "GLOBAL"
512 :
513 : CHARACTER(LEN=13) :: omp_stacksize, tracing_string
514 : CHARACTER(LEN=6) :: print_level_string
515 : CHARACTER(LEN=default_path_length) :: basis_set_file_name, coord_file_name, &
516 : mm_potential_file_name, &
517 : potential_file_name
518 : CHARACTER(LEN=default_string_length) :: env_num, model_name, project_name
519 : CHARACTER(LEN=default_string_length), &
520 10863 : DIMENSION(:), POINTER :: trace_routines
521 : INTEGER :: cpuid, cpuid_static, i_cholesky, i_dgemm, i_diag, i_fft, i_grid_backend, &
522 : iforce_eval, method_name_id, n_rep_val, nforce_eval, node_count, num_threads, &
523 : output_unit, print_level, trace_max, unit_nr
524 : INTEGER(kind=int_8) :: Buffers, Buffers_avr, Buffers_max, Buffers_min, Cached, Cached_avr, &
525 : Cached_max, Cached_min, MemFree, MemFree_avr, MemFree_max, MemFree_min, MemLikelyFree, &
526 : MemLikelyFree_avr, MemLikelyFree_max, MemLikelyFree_min, MemTotal, MemTotal_avr, &
527 : MemTotal_max, MemTotal_min, Slab, Slab_avr, Slab_max, Slab_min, SReclaimable, &
528 : SReclaimable_avr, SReclaimable_max, SReclaimable_min
529 10863 : INTEGER, DIMENSION(:), POINTER :: i_force_eval
530 : LOGICAL :: ata, do_echo_all_hosts, efl, explicit, &
531 : flag, report_maxloc, trace, &
532 : trace_master
533 : TYPE(cp_logger_type), POINTER :: logger
534 : TYPE(enumeration_type), POINTER :: enum1, enum2
535 : TYPE(keyword_type), POINTER :: keyword
536 : TYPE(section_type), POINTER :: section
537 : TYPE(section_vals_type), POINTER :: dft_section, force_env_sections, &
538 : global_section, qmmm_section, &
539 : subsys_section
540 :
541 10863 : NULLIFY (dft_section, global_section, i_force_eval)
542 :
543 21726 : logger => cp_get_default_logger()
544 10863 : global_section => section_vals_get_subs_vals(root_section, "GLOBAL")
545 10863 : CALL section_vals_val_get(global_section, "BLACS_GRID", i_val=globenv%blacs_grid_layout)
546 10863 : CALL section_vals_val_get(global_section, "BLACS_REPEATABLE", l_val=globenv%blacs_repeatable)
547 10863 : CALL section_vals_val_get(global_section, "PREFERRED_DIAG_LIBRARY", i_val=i_diag)
548 : CALL section_vals_val_get(global_section, "DIRECT_GENERALIZED_DIAGONALIZATION", &
549 10863 : l_val=globenv%direct_generalized_diagonalization)
550 10863 : CALL section_vals_val_get(global_section, "PREFERRED_CHOLESKY_LIBRARY", i_val=i_cholesky)
551 10863 : CALL section_vals_val_get(global_section, "PREFERRED_DGEMM_LIBRARY", i_val=i_dgemm)
552 10863 : CALL section_vals_val_get(global_section, "EPS_CHECK_DIAG", r_val=globenv%eps_check_diag)
553 10863 : CALL section_vals_val_get(global_section, "ENABLE_MPI_IO", l_val=flag)
554 10863 : CALL cp_mpi_io_set(flag)
555 10863 : CALL section_vals_val_get(global_section, "ELPA_KERNEL", i_val=globenv%k_elpa)
556 10863 : CALL section_vals_val_get(global_section, "ELPA_NEIGVEC_MIN", i_val=globenv%elpa_neigvec_min)
557 10863 : CALL section_vals_val_get(global_section, "ELPA_QR", l_val=globenv%elpa_qr)
558 10863 : CALL section_vals_val_get(global_section, "ELPA_ONE_STAGE", l_val=globenv%elpa_one_stage)
559 10863 : CALL section_vals_val_get(global_section, "ELPA_PRINT", l_val=globenv%elpa_print)
560 10863 : CALL section_vals_val_get(global_section, "DLAF_NEIGVEC_MIN", i_val=globenv%dlaf_neigvec_min)
561 10863 : CALL section_vals_val_get(global_section, "DLAF_CHOLESKY_N_MIN", i_val=globenv%dlaf_cholesky_n_min)
562 10863 : CALL section_vals_val_get(global_section, "PREFERRED_FFT_LIBRARY", i_val=i_fft)
563 10863 : CALL section_vals_val_get(global_section, "PRINT_LEVEL", i_val=print_level)
564 10863 : CALL section_vals_val_get(global_section, "PROGRAM_NAME", i_val=globenv%prog_name_id)
565 10863 : CALL section_vals_val_get(global_section, "FFT_POOL_SCRATCH_LIMIT", i_val=globenv%fft_pool_scratch_limit)
566 10863 : CALL section_vals_val_get(global_section, "FFTW_PLAN_TYPE", i_val=globenv%fftw_plan_type)
567 10863 : CALL section_vals_val_get(global_section, "PROJECT_NAME", c_val=project_name)
568 10863 : CALL section_vals_val_get(global_section, "FFTW_WISDOM_FILE_NAME", c_val=globenv%fftw_wisdom_file_name)
569 10863 : CALL section_vals_val_get(global_section, "RUN_TYPE", i_val=globenv%run_type_id)
570 : CALL cp2k_get_walltime(section=global_section, keyword_name="WALLTIME", &
571 10863 : walltime=globenv%cp2k_target_time)
572 10863 : CALL section_vals_val_get(global_section, "TRACE", l_val=trace)
573 10863 : CALL section_vals_val_get(global_section, "TRACE_MASTER", l_val=trace_MASTER)
574 10863 : CALL section_vals_val_get(global_section, "TRACE_MAX", i_val=trace_max)
575 10863 : CALL section_vals_val_get(global_section, "TRACE_ROUTINES", explicit=explicit)
576 10863 : IF (explicit) THEN
577 0 : CALL section_vals_val_get(global_section, "TRACE_ROUTINES", c_vals=trace_routines)
578 : ELSE
579 10863 : NULLIFY (trace_routines)
580 : END IF
581 10863 : CALL section_vals_val_get(global_section, "FLUSH_SHOULD_FLUSH", l_val=flush_should_flush)
582 10863 : CALL section_vals_val_get(global_section, "ECHO_ALL_HOSTS", l_val=do_echo_all_hosts)
583 10863 : report_maxloc = section_get_lval(global_section, "TIMINGS%REPORT_MAXLOC")
584 10863 : global_timings_level = section_get_ival(global_section, "TIMINGS%TIMINGS_LEVEL")
585 10863 : do_echo_all_hosts = do_echo_all_hosts .OR. report_maxloc
586 10863 : force_env_sections => section_vals_get_subs_vals(root_section, "FORCE_EVAL")
587 10863 : CALL section_vals_get(force_env_sections, n_repetition=nforce_eval)
588 : output_unit = cp_print_key_unit_nr(logger, global_section, "PROGRAM_RUN_INFO", &
589 10863 : extension=".log")
590 :
591 10863 : CALL fm_setup(global_section)
592 10863 : CALL fm_diag_rules_setup(global_section)
593 10863 : CALL dgemm_setup(global_section)
594 :
595 10863 : IF (trace .AND. (.NOT. trace_master .OR. para_env%mepos == 0)) THEN
596 0 : unit_nr = -1
597 0 : IF (logger%para_env%is_source() .OR. .NOT. trace_master) &
598 0 : unit_nr = cp_logger_get_default_unit_nr(logger, local=.TRUE.)
599 0 : WRITE (tracing_string, "(I6.6,A1,I6.6)") para_env%mepos, ":", para_env%num_pe
600 0 : IF (ASSOCIATED(trace_routines)) THEN
601 0 : CALL timings_setup_tracing(trace_max, unit_nr, tracing_string, trace_routines)
602 : ELSE
603 0 : CALL timings_setup_tracing(trace_max, unit_nr, tracing_string)
604 : END IF
605 : END IF
606 :
607 10863 : CALL section_vals_val_get(global_section, "TIMINGS%TIME_MPI", l_val=mp_collect_timings)
608 :
609 196 : SELECT CASE (i_diag)
610 : CASE (FM_DIAG_TYPE_SCALAPACK)
611 196 : globenv%diag_library = "ScaLAPACK"
612 : CASE (FM_DIAG_TYPE_ELPA)
613 10667 : globenv%diag_library = "ELPA"
614 10667 : CALL cite_reference(Marek2014)
615 : CASE (FM_DIAG_TYPE_CUSOLVER)
616 0 : globenv%diag_library = "cuSOLVER"
617 : CASE (FM_DIAG_TYPE_DLAF)
618 0 : globenv%diag_library = "DLAF"
619 0 : CALL cite_reference(Solca2024)
620 : CASE DEFAULT
621 10863 : CPABORT("Unknown diagonalization library specified")
622 : END SELECT
623 :
624 10863 : SELECT CASE (i_cholesky)
625 : CASE (FM_CHOLESKY_TYPE_SCALAPACK)
626 10863 : globenv%cholesky_library = "ScaLAPACK"
627 10863 : cholesky_type = FM_CHOLESKY_TYPE_SCALAPACK
628 : CASE (FM_CHOLESKY_TYPE_DLAF)
629 0 : globenv%cholesky_library = "DLAF"
630 0 : cholesky_type = FM_CHOLESKY_TYPE_DLAF
631 0 : dlaf_cholesky_n_min = globenv%dlaf_cholesky_n_min
632 0 : CALL cite_reference(Solca2024)
633 : CASE DEFAULT
634 10863 : CPABORT("Unknown Cholesky decomposition library specified")
635 : END SELECT
636 :
637 10 : SELECT CASE (i_fft)
638 : CASE (do_fft_sg)
639 10 : globenv%default_fft_library = "FFTSG"
640 : CASE (do_fft_fftw3)
641 10853 : globenv%default_fft_library = "FFTW3"
642 10853 : CALL cite_reference(Frigo2005)
643 : CASE DEFAULT
644 10863 : CPABORT("Unknown FFT library specified")
645 : END SELECT
646 :
647 0 : SELECT CASE (i_dgemm)
648 : CASE (do_dgemm_spla)
649 0 : globenv%default_dgemm_library = "SPLA"
650 : CASE (do_dgemm_blas)
651 10863 : globenv%default_dgemm_library = "BLAS"
652 : CASE DEFAULT
653 10863 : CPABORT("Unknown DGEMM library specified")
654 : END SELECT
655 :
656 10863 : IF (globenv%run_type_id == 0) THEN
657 0 : SELECT CASE (globenv%prog_name_id)
658 : CASE (do_farming, do_test)
659 0 : globenv%run_type_id = none_run
660 : CASE (do_cp2k)
661 0 : IF (nforce_eval /= 1) THEN
662 : ! multiple force_eval corresponds at the moment to RESPA calculations only
663 : ! default MD
664 0 : globenv%run_type_id = mol_dyn_run
665 : ELSE
666 0 : CALL section_vals_val_get(force_env_sections, "METHOD", i_val=method_name_id)
667 0 : SELECT CASE (method_name_id)
668 : CASE (do_fist)
669 0 : globenv%run_type_id = mol_dyn_run
670 : CASE (do_eip)
671 0 : globenv%run_type_id = mol_dyn_run
672 : CASE (do_qs)
673 0 : globenv%run_type_id = energy_run
674 : CASE (do_sirius)
675 0 : globenv%run_type_id = energy_run
676 : END SELECT
677 : END IF
678 : END SELECT
679 : END IF
680 :
681 10863 : IF (globenv%prog_name_id == do_farming .AND. globenv%run_type_id /= none_run) THEN
682 0 : CPABORT("FARMING program supports only NONE as run type")
683 : END IF
684 :
685 10863 : IF (globenv%prog_name_id == do_test .AND. globenv%run_type_id /= none_run) &
686 0 : CPABORT("TEST program supports only NONE as run type")
687 :
688 10863 : CALL m_memory_details(MemTotal, MemFree, Buffers, Cached, Slab, SReclaimable, MemLikelyFree)
689 10863 : MemTotal_avr = MemTotal
690 10863 : MemFree_avr = MemFree
691 10863 : Buffers_avr = Buffers
692 10863 : Cached_avr = Cached
693 10863 : Slab_avr = Slab
694 10863 : SReclaimable_avr = SReclaimable
695 10863 : MemLikelyFree_avr = MemLikelyFree
696 10863 : CALL para_env%sum(MemTotal_avr); MemTotal_avr = MemTotal_avr/para_env%num_pe/1024
697 10863 : CALL para_env%sum(MemFree_avr); MemFree_avr = MemFree_avr/para_env%num_pe/1024
698 10863 : CALL para_env%sum(Buffers_avr); Buffers_avr = Buffers_avr/para_env%num_pe/1024
699 10863 : CALL para_env%sum(Cached_avr); Cached_avr = Cached_avr/para_env%num_pe/1024
700 10863 : CALL para_env%sum(Slab_avr); Slab_avr = Slab_avr/para_env%num_pe/1024
701 10863 : CALL para_env%sum(SReclaimable_avr); SReclaimable_avr = SReclaimable_avr/para_env%num_pe/1024
702 10863 : CALL para_env%sum(MemLikelyFree_avr); MemLikelyFree_avr = MemLikelyFree_avr/para_env%num_pe/1024
703 :
704 10863 : MemTotal_min = -MemTotal
705 10863 : MemFree_min = -MemFree
706 10863 : Buffers_min = -Buffers
707 10863 : Cached_min = -Cached
708 10863 : Slab_min = -Slab
709 10863 : SReclaimable_min = -SReclaimable
710 10863 : MemLikelyFree_min = -MemLikelyFree
711 10863 : CALL para_env%max(MemTotal_min); MemTotal_min = -MemTotal_min/1024
712 10863 : CALL para_env%max(MemFree_min); MemFree_min = -MemFree_min/1024
713 10863 : CALL para_env%max(Buffers_min); Buffers_min = -Buffers_min/1024
714 10863 : CALL para_env%max(Cached_min); Cached_min = -Cached_min/1024
715 10863 : CALL para_env%max(Slab_min); Slab_min = -Slab_min/1024
716 10863 : CALL para_env%max(SReclaimable_min); SReclaimable_min = -SReclaimable_min/1024
717 10863 : CALL para_env%max(MemLikelyFree_min); MemLikelyFree_min = -MemLikelyFree_min/1024
718 :
719 10863 : MemTotal_max = MemTotal
720 10863 : MemFree_max = MemFree
721 10863 : Buffers_max = Buffers
722 10863 : Cached_max = Cached
723 10863 : Slab_max = Slab
724 10863 : SReclaimable_max = SReclaimable
725 10863 : MemLikelyFree_max = MemLikelyFree
726 10863 : CALL para_env%max(MemTotal_max); MemTotal_max = MemTotal_max/1024
727 10863 : CALL para_env%max(MemFree_max); MemFree_max = MemFree_max/1024
728 10863 : CALL para_env%max(Buffers_max); Buffers_max = Buffers_max/1024
729 10863 : CALL para_env%max(Cached_max); Cached_max = Cached_max/1024
730 10863 : CALL para_env%max(Slab_max); Slab_max = Slab_max/1024
731 10863 : CALL para_env%max(SReclaimable_max); SReclaimable_max = SReclaimable_max/1024
732 10863 : CALL para_env%max(MemLikelyFree_max); MemLikelyFree_max = MemLikelyFree_max/1024
733 :
734 10863 : MemTotal = MemTotal/1024
735 10863 : MemFree = MemFree/1024
736 10863 : Buffers = Buffers/1024
737 10863 : Cached = Cached/1024
738 10863 : Slab = Slab/1024
739 10863 : SReclaimable = SReclaimable/1024
740 10863 : MemLikelyFree = MemLikelyFree/1024
741 :
742 10863 : node_count = 1
743 : ! Print a list of all started processes
744 10863 : IF (do_echo_all_hosts) THEN
745 2 : CALL echo_all_hosts(para_env, output_unit)
746 :
747 : ! Print the number of processes per host
748 2 : CALL echo_all_process_host(para_env, output_unit, node_count)
749 : ELSE ! no echo
750 10861 : CALL echo_all_process_host(para_env, 0, node_count)
751 : END IF
752 :
753 10863 : num_threads = 1
754 10863 : !$ num_threads = omp_get_max_threads()
755 10863 : IF (output_unit > 0) THEN
756 5537 : WRITE (UNIT=output_unit, FMT=*)
757 5537 : CALL multiple_fe_list(force_env_sections, root_section, i_force_eval, nforce_eval)
758 11020 : DO iforce_eval = 1, nforce_eval
759 : dft_section => section_vals_get_subs_vals3(force_env_sections, "DFT", &
760 5483 : i_rep_section=i_force_eval(iforce_eval))
761 : qmmm_section => section_vals_get_subs_vals3(force_env_sections, "QMMM", &
762 5483 : i_rep_section=i_force_eval(iforce_eval))
763 : CALL section_vals_val_get(dft_section, "BASIS_SET_FILE_NAME", &
764 5483 : c_val=basis_set_file_name)
765 : CALL section_vals_val_get(dft_section, "POTENTIAL_FILE_NAME", &
766 5483 : c_val=potential_file_name)
767 :
768 : CALL section_vals_val_get(qmmm_section, "MM_POTENTIAL_FILE_NAME", &
769 5483 : c_val=mm_potential_file_name)
770 : ! SUBSYS - If any
771 : subsys_section => section_vals_get_subs_vals3(force_env_sections, "SUBSYS", &
772 5483 : i_rep_section=i_force_eval(iforce_eval))
773 5483 : CALL section_vals_get(subsys_section, explicit=explicit)
774 5483 : coord_file_name = "__STD_INPUT__"
775 5483 : IF (explicit) THEN
776 : CALL section_vals_val_get(subsys_section, "TOPOLOGY%COORD_FILE_NAME", &
777 5370 : n_rep_val=n_rep_val)
778 5370 : IF (n_rep_val == 1) THEN
779 : CALL section_vals_val_get(subsys_section, "TOPOLOGY%COORD_FILE_NAME", &
780 956 : c_val=coord_file_name)
781 : END IF
782 : END IF
783 5483 : CALL integer_to_string(i_force_eval(iforce_eval), env_num)
784 :
785 : WRITE (UNIT=output_unit, FMT="(T2,A,T41,A)") &
786 5483 : start_section_label//"| Force Environment number", &
787 5483 : ADJUSTR(env_num(:40)), &
788 5483 : start_section_label//"| Basis set file name", &
789 5483 : ADJUSTR(basis_set_file_name(:40)), &
790 5483 : start_section_label//"| Potential file name", &
791 5483 : ADJUSTR(potential_file_name(:40)), &
792 5483 : start_section_label//"| MM Potential file name", &
793 5483 : ADJUSTR(mm_potential_file_name(:40)), &
794 5483 : start_section_label//"| Coordinate file name", &
795 21986 : ADJUSTR(coord_file_name(:40))
796 : END DO
797 5537 : DEALLOCATE (i_force_eval)
798 :
799 5537 : NULLIFY (enum1, enum2, keyword, section)
800 5537 : CALL create_global_section(section)
801 5537 : keyword => section_get_keyword(section, "PROGRAM_NAME")
802 5537 : CALL keyword_get(keyword, enum=enum1)
803 5537 : keyword => section_get_keyword(section, "RUN_TYPE")
804 5537 : CALL keyword_get(keyword, enum=enum2)
805 :
806 : WRITE (UNIT=output_unit, FMT="(T2,A,T41,A40)") &
807 5537 : start_section_label//"| Method name", &
808 5537 : ADJUSTR(TRIM(enum_i2c(enum1, globenv%prog_name_id))), &
809 5537 : start_section_label//"| Project name", &
810 5537 : ADJUSTR(project_name(:40)), &
811 5537 : start_section_label//"| Run type", &
812 5537 : ADJUSTR(TRIM(enum_i2c(enum2, globenv%run_type_id))), &
813 5537 : start_section_label//"| FFT library", &
814 5537 : ADJUSTR(globenv%default_fft_library(:40)), &
815 5537 : start_section_label//"| Diagonalization library", &
816 5537 : ADJUSTR(globenv%diag_library(:40)), &
817 5537 : start_section_label//"| Cholesky decomposition library", &
818 5537 : ADJUSTR(globenv%cholesky_library(:40)), &
819 5537 : start_section_label//"| DGEMM library", &
820 11074 : ADJUSTR(globenv%default_dgemm_library(:40))
821 :
822 5537 : IF (globenv%diag_library == "ELPA") THEN
823 : WRITE (UNIT=output_unit, FMT="(T2,A,T71,I10)") &
824 5438 : start_section_label//"| Minimum number of eigenvectors for ELPA usage", &
825 10876 : globenv%elpa_neigvec_min
826 : END IF
827 :
828 5537 : IF (globenv%diag_library == "DLAF") THEN
829 : WRITE (UNIT=output_unit, FMT="(T2,A,T71,I10)") &
830 0 : start_section_label//"| Minimum number of eigenvectors for DLAF usage", &
831 0 : globenv%dlaf_neigvec_min
832 : END IF
833 :
834 5537 : IF (globenv%diag_library == "cuSOLVER" .OR. globenv%diag_library == "ScaLAPACK" .OR. &
835 : globenv%diag_library == "DLAF") THEN
836 : WRITE (UNIT=output_unit, FMT="(T2,A,T71,L10)") &
837 99 : start_section_label//"| Direct generalized diagonalization requested", &
838 198 : globenv%direct_generalized_diagonalization
839 : END IF
840 :
841 5537 : IF (globenv%diag_library == "cuSOLVER") THEN
842 : WRITE (UNIT=output_unit, FMT="(T2,A,T71,I10)") &
843 0 : start_section_label//"| Minimum matrix size for cuSOLVER diagonalization", &
844 0 : cusolver_n_min
845 : END IF
846 :
847 5537 : IF (globenv%cholesky_library == "DLAF") THEN
848 : WRITE (UNIT=output_unit, FMT="(T2,A,T71,I10)") &
849 0 : start_section_label//"| Minimum matrix size for Cholesky decomposition with DLAF", &
850 0 : globenv%dlaf_cholesky_n_min
851 : END IF
852 :
853 : #if defined(__CHECK_DIAG)
854 : ! Perform default check if no threshold value has been specified explicitly
855 : IF (globenv%eps_check_diag < 0.0_dp) THEN
856 : WRITE (UNIT=output_unit, FMT="(T2,A,T71,ES10.3)") &
857 : start_section_label//"| Orthonormality check for eigenvectors enabled", &
858 : eps_check_diag_default
859 : ELSE
860 : WRITE (UNIT=output_unit, FMT="(T2,A,T71,ES10.3)") &
861 : start_section_label//"| Orthonormality check for eigenvectors enabled", &
862 : globenv%eps_check_diag
863 : END IF
864 : #else
865 5537 : IF (globenv%eps_check_diag < 0.0_dp) THEN
866 : WRITE (UNIT=output_unit, FMT="(T2,A,T73,A)") &
867 5529 : start_section_label//"| Orthonormality check for eigenvectors", &
868 11058 : "DISABLED"
869 : ELSE
870 : WRITE (UNIT=output_unit, FMT="(T2,A,T71,ES10.3)") &
871 8 : start_section_label//"| Orthonormality check for eigenvectors enabled", &
872 16 : globenv%eps_check_diag
873 : END IF
874 : #endif
875 5537 : CALL section_release(section)
876 :
877 0 : SELECT CASE (cp_fm_get_mm_type())
878 : CASE (do_scalapack)
879 : WRITE (UNIT=output_unit, FMT="(T2,A,T72,A)") &
880 0 : start_section_label//"| Matrix multiplication library", "ScaLAPACK"
881 : CASE (do_cosma)
882 : WRITE (UNIT=output_unit, FMT="(T2,A,T76,A)") &
883 5537 : start_section_label//"| Matrix multiplication library", "COSMA"
884 : END SELECT
885 :
886 5537 : CALL section_vals_val_get(global_section, "ALLTOALL_SGL", l_val=ata)
887 : WRITE (UNIT=output_unit, FMT="(T2,A,T80,L1)") &
888 5537 : start_section_label//"| All-to-all communication in single precision", ata
889 5537 : CALL section_vals_val_get(global_section, "EXTENDED_FFT_LENGTHS", l_val=efl)
890 : WRITE (UNIT=output_unit, FMT="(T2,A,T80,L1)") &
891 5537 : start_section_label//"| FFTs using library dependent lengths", efl
892 :
893 141 : SELECT CASE (print_level)
894 : CASE (silent_print_level)
895 141 : print_level_string = "SILENT"
896 : CASE (low_print_level)
897 2667 : print_level_string = " LOW"
898 : CASE (medium_print_level)
899 2664 : print_level_string = "MEDIUM"
900 : CASE (high_print_level)
901 39 : print_level_string = " HIGH"
902 : CASE (debug_print_level)
903 26 : print_level_string = " DEBUG"
904 : CASE DEFAULT
905 5537 : CPABORT("Unknown print_level")
906 : END SELECT
907 :
908 5537 : CALL section_vals_val_get(global_section, "GRID%BACKEND", i_val=i_grid_backend)
909 5527 : SELECT CASE (i_grid_backend)
910 : CASE (GRID_BACKEND_AUTO)
911 : WRITE (UNIT=output_unit, FMT="(T2,A,T75,A6)") &
912 5527 : start_section_label//"| Grid backend", "AUTO"
913 : CASE (GRID_BACKEND_CPU)
914 : WRITE (UNIT=output_unit, FMT="(T2,A,T75,A6)") &
915 4 : start_section_label//"| Grid backend", "CPU"
916 : CASE (GRID_BACKEND_DGEMM)
917 : WRITE (UNIT=output_unit, FMT="(T2,A,T75,A6)") &
918 4 : start_section_label//"| Grid backend", "DGEMM"
919 : CASE (GRID_BACKEND_GPU)
920 : WRITE (UNIT=output_unit, FMT="(T2,A,T75,A6)") &
921 0 : start_section_label//"| Grid backend", "GPU"
922 : CASE (GRID_BACKEND_REF)
923 : WRITE (UNIT=output_unit, FMT="(T2,A,T75,A6)") &
924 5537 : start_section_label//"| Grid backend", "REF"
925 : END SELECT
926 :
927 : WRITE (UNIT=output_unit, FMT="(T2,A,T75,A6)") &
928 5537 : start_section_label//"| Global print level", print_level_string
929 : WRITE (UNIT=output_unit, FMT="(T2,A,T75,L6)") &
930 5537 : start_section_label//"| MPI I/O enabled", flag
931 : WRITE (UNIT=output_unit, FMT="(T2,A,T75,I6)") &
932 5537 : start_section_label//"| Total number of message passing processes", &
933 5537 : para_env%num_pe, &
934 5537 : start_section_label//"| Number of distributed systems (nodes)", &
935 5537 : node_count, &
936 5537 : start_section_label//"| Number of threads for this process", &
937 5537 : num_threads, &
938 11074 : start_section_label//"| This output is from process", para_env%mepos
939 :
940 5537 : CALL m_omp_get_stacksize(omp_stacksize)
941 : WRITE (UNIT=output_unit, FMT="(T2,A,T68,A13)") &
942 5537 : start_section_label//"| OpenMP stack size per thread (OMP_STACKSIZE)", &
943 11074 : ADJUSTR(omp_stacksize)
944 :
945 5537 : IF (0 <= m_omp_trace_issues()) THEN ! only show in header if enabled
946 : WRITE (UNIT=output_unit, FMT="(T2,A,T68,A13)") &
947 0 : start_section_label//"| OpenMP issue trace (CP2K_OMP_TRACE)", &
948 0 : "enabled"
949 : END IF
950 :
951 5537 : CALL m_cpuinfo(model_name)
952 : WRITE (UNIT=output_unit, FMT="(T2,A,T30,A51)") &
953 5537 : start_section_label//"| CPU model name", ADJUSTR(TRIM(model_name))
954 :
955 5537 : cpuid = m_cpuid()
956 5537 : cpuid_static = m_cpuid_static()
957 :
958 5537 : IF ((cpuid > 0) .OR. (cpuid_static > 0)) THEN
959 : WRITE (UNIT=output_unit, FMT="(T2,A,T75,I6)") &
960 5537 : start_section_label//"| CPUID", cpuid
961 5537 : IF (cpuid /= cpuid_static) THEN
962 : WRITE (UNIT=output_unit, FMT="(T2,A,T75,I6)") &
963 0 : start_section_label//"| Compiled for CPUID", cpuid_static
964 : END IF
965 : END IF
966 :
967 : ! filter cpuids by vlen to show more relevant information
968 5537 : IF (m_cpuid_vlen(cpuid_static) < m_cpuid_vlen(cpuid)) THEN
969 : ! base/machine_cpuid.c relies on the (same) target flags as the Fortran code
970 : CALL cp_hint(__LOCATION__, "The compiler target flags ("// &
971 : TRIM(m_cpuid_name(cpuid_static))//") used to build this binary cannot exploit "// &
972 : "all extensions of this CPU model ("//TRIM(m_cpuid_name(cpuid))//"). "// &
973 0 : "Consider compiler target flags as part of FCFLAGS and CFLAGS (ARCH file).")
974 : END IF
975 :
976 5537 : WRITE (UNIT=output_unit, FMT="()")
977 5537 : WRITE (UNIT=output_unit, FMT="(T2,A)") "MEMORY| system memory details [Kb]"
978 5537 : WRITE (UNIT=output_unit, FMT="(T2,A23,4A14)") "MEMORY| ", "rank 0", "min", "max", "average"
979 5537 : WRITE (UNIT=output_unit, FMT="(T2,A23,4I14)") "MEMORY| MemTotal ", memtotal, memtotal_min, memtotal_max, memtotal_avr
980 5537 : WRITE (UNIT=output_unit, FMT="(T2,A23,4I14)") "MEMORY| MemFree ", memFree, memfree_min, memfree_max, memfree_avr
981 5537 : WRITE (UNIT=output_unit, FMT="(T2,A23,4I14)") "MEMORY| Buffers ", Buffers, Buffers_min, Buffers_max, Buffers_avr
982 5537 : WRITE (UNIT=output_unit, FMT="(T2,A23,4I14)") "MEMORY| Cached ", Cached, Cached_min, Cached_max, Cached_avr
983 5537 : WRITE (UNIT=output_unit, FMT="(T2,A23,4I14)") "MEMORY| Slab ", Slab, Slab_min, Slab_max, Slab_avr
984 : WRITE (UNIT=output_unit, FMT="(T2,A23,4I14)") &
985 5537 : "MEMORY| SReclaimable ", SReclaimable, SReclaimable_min, SReclaimable_max, &
986 11074 : SReclaimable_avr
987 : WRITE (UNIT=output_unit, FMT="(T2,A23,4I14)") &
988 5537 : "MEMORY| MemLikelyFree ", MemLikelyFree, MemLikelyFree_min, MemLikelyFree_max, &
989 11074 : MemLikelyFree_avr
990 5537 : WRITE (UNIT=output_unit, FMT='()')
991 :
992 : END IF
993 :
994 : CALL cp_print_key_finished_output(output_unit, logger, global_section, &
995 10863 : "PROGRAM_RUN_INFO")
996 :
997 10863 : END SUBROUTINE read_global_section
998 :
999 : ! **************************************************************************************************
1000 : !> \brief ...
1001 : !> \param root_section ...
1002 : !> \param para_env ...
1003 : !> \param globenv ...
1004 : !> \par History
1005 : !> 2-Dec-2000 (JGH) added default fft library
1006 : !> \author JGH,MK
1007 : ! **************************************************************************************************
1008 10863 : SUBROUTINE read_cp2k_section(root_section, para_env, globenv)
1009 :
1010 : TYPE(section_vals_type), POINTER :: root_section
1011 : TYPE(mp_para_env_type), POINTER :: para_env
1012 : TYPE(global_environment_type), POINTER :: globenv
1013 :
1014 : INTEGER :: output_unit
1015 : TYPE(cp_logger_type), POINTER :: logger
1016 : TYPE(section_vals_type), POINTER :: global_section
1017 :
1018 10863 : global_section => section_vals_get_subs_vals(root_section, "GLOBAL")
1019 10863 : CALL read_global_section(root_section, para_env, globenv)
1020 10863 : logger => cp_get_default_logger()
1021 : output_unit = cp_print_key_unit_nr(logger, global_section, "PROGRAM_RUN_INFO", &
1022 10863 : extension=".log")
1023 :
1024 10863 : CALL fft_setup_library(globenv, global_section)
1025 10863 : CALL diag_setup_library(globenv)
1026 :
1027 : CALL cp_print_key_finished_output(output_unit, logger, global_section, &
1028 10863 : "PROGRAM_RUN_INFO")
1029 :
1030 10863 : END SUBROUTINE read_cp2k_section
1031 :
1032 : ! **************************************************************************************************
1033 : !> \brief check FFT preferred library availability, if not switch
1034 : !> \param globenv ...
1035 : !> \param global_section ...
1036 : !> \par History
1037 : !> 2-Dec-2000 (JGH) added default fft library
1038 : !> Nov-2013 (MI) refactoring
1039 : !> \author JGH,MK
1040 : ! **************************************************************************************************
1041 10863 : SUBROUTINE fft_setup_library(globenv, global_section)
1042 :
1043 : TYPE(global_environment_type), POINTER :: globenv
1044 : TYPE(section_vals_type), POINTER :: global_section
1045 :
1046 : CHARACTER(LEN=3*default_string_length) :: message
1047 : COMPLEX(KIND=dp), DIMENSION(4, 4, 4) :: zz
1048 : INTEGER :: stat
1049 : INTEGER, DIMENSION(3) :: n
1050 : LOGICAL :: try_fftw
1051 :
1052 43452 : n(:) = 4
1053 10863 : zz(:, :, :) = 0.0_dp
1054 :
1055 : ! Setup the FFT library
1056 : ! If the user has specified PREFERRED_FFT_LIBRARY try that first (default FFTW3)
1057 : ! If that one is not available, try FFTW3 (unless it has been tried already)
1058 : ! If FFTW3 is not available use FFTSG
1059 :
1060 10863 : IF (globenv%default_fft_library == "FFTW3") THEN
1061 : try_fftw = .FALSE.
1062 : ELSE
1063 10 : try_fftw = .TRUE.
1064 : END IF
1065 :
1066 : ! Initialize FFT library with the user's preferred FFT library
1067 : CALL init_fft(fftlib=TRIM(globenv%default_fft_library), &
1068 : alltoall=section_get_lval(global_section, "ALLTOALL_SGL"), &
1069 : fftsg_sizes=.NOT. section_get_lval(global_section, "EXTENDED_FFT_LENGTHS"), &
1070 : pool_limit=globenv%fft_pool_scratch_limit, &
1071 : wisdom_file=globenv%fftw_wisdom_file_name, &
1072 10863 : plan_style=globenv%fftw_plan_type)
1073 :
1074 : ! Check for FFT library
1075 10863 : CALL fft3d(FWFFT, n, zz, status=stat)
1076 10863 : IF (stat /= 0) THEN
1077 0 : IF (try_fftw) THEN
1078 : message = "FFT library "//TRIM(globenv%default_fft_library)// &
1079 0 : " is not available. Trying FFT library FFTW3."
1080 0 : CPWARN(TRIM(message))
1081 0 : globenv%default_fft_library = "FFTW3"
1082 : CALL init_fft(fftlib=TRIM(globenv%default_fft_library), &
1083 : alltoall=section_get_lval(global_section, "ALLTOALL_SGL"), &
1084 : fftsg_sizes=.NOT. section_get_lval(global_section, "EXTENDED_FFT_LENGTHS"), &
1085 : pool_limit=globenv%fft_pool_scratch_limit, &
1086 : wisdom_file=globenv%fftw_wisdom_file_name, &
1087 0 : plan_style=globenv%fftw_plan_type)
1088 :
1089 0 : CALL fft3d(FWFFT, n, zz, status=stat)
1090 : END IF
1091 0 : IF (stat /= 0) THEN
1092 : message = "FFT library "//TRIM(globenv%default_fft_library)// &
1093 0 : " is not available. Trying FFT library FFTSG."
1094 0 : CPWARN(TRIM(message))
1095 0 : globenv%default_fft_library = "FFTSG"
1096 : CALL init_fft(fftlib=TRIM(globenv%default_fft_library), &
1097 : alltoall=section_get_lval(global_section, "ALLTOALL_SGL"), &
1098 : fftsg_sizes=.NOT. section_get_lval(global_section, "EXTENDED_FFT_LENGTHS"), &
1099 : pool_limit=globenv%fft_pool_scratch_limit, &
1100 : wisdom_file=globenv%fftw_wisdom_file_name, &
1101 0 : plan_style=globenv%fftw_plan_type)
1102 :
1103 0 : CALL fft3d(FWFFT, n, zz, status=stat)
1104 0 : IF (stat /= 0) THEN
1105 0 : CPABORT("FFT library FFTSG does not work. No FFT library available.")
1106 : END IF
1107 : END IF
1108 : END IF
1109 :
1110 10863 : END SUBROUTINE fft_setup_library
1111 :
1112 : ! **************************************************************************************************
1113 : !> \brief availability diagonalizatioon library
1114 : !>
1115 : !> \param globenv ...
1116 : !> \author MI
1117 : ! **************************************************************************************************
1118 10863 : SUBROUTINE diag_setup_library(globenv)
1119 : TYPE(global_environment_type), POINTER :: globenv
1120 :
1121 : CHARACTER(LEN=3*default_string_length) :: message
1122 : LOGICAL :: fallback_applied
1123 :
1124 : CALL diag_init(diag_lib=TRIM(globenv%diag_library), &
1125 : fallback_applied=fallback_applied, &
1126 : elpa_kernel=globenv%k_elpa, &
1127 : elpa_neigvec_min_input=globenv%elpa_neigvec_min, &
1128 : elpa_qr=globenv%elpa_qr, &
1129 : elpa_print=globenv%elpa_print, &
1130 : elpa_one_stage=globenv%elpa_one_stage, &
1131 : dlaf_neigvec_min_input=globenv%dlaf_neigvec_min, &
1132 : eps_check_diag_input=globenv%eps_check_diag, &
1133 : direct_generalized_diagonalization_input= &
1134 10863 : globenv%direct_generalized_diagonalization)
1135 :
1136 10863 : IF (fallback_applied) THEN
1137 : message = "Diagonalization library "//TRIM(globenv%diag_library)// &
1138 0 : " is not available. The ScaLAPACK library is used as fallback."
1139 0 : CPWARN(TRIM(message))
1140 : END IF
1141 :
1142 10863 : END SUBROUTINE diag_setup_library
1143 :
1144 : ! **************************************************************************************************
1145 : !> \brief ...
1146 : !> \param glob_section ...
1147 : ! **************************************************************************************************
1148 54315 : SUBROUTINE fm_setup(glob_section)
1149 : TYPE(section_vals_type), POINTER :: glob_section
1150 :
1151 : INTEGER :: mm_type, ncb, nrb
1152 : LOGICAL :: force_me
1153 : TYPE(section_vals_type), POINTER :: fm_section
1154 :
1155 10863 : fm_section => section_vals_get_subs_vals(glob_section, "FM")
1156 :
1157 10863 : CALL section_vals_val_get(fm_section, "NROW_BLOCKS", i_val=nrb)
1158 10863 : CALL section_vals_val_get(fm_section, "NCOL_BLOCKS", i_val=ncb)
1159 10863 : CALL section_vals_val_get(fm_section, "FORCE_BLOCK_SIZE", l_val=force_me)
1160 10863 : CALL cp_fm_struct_config(nrow_block=nrb, ncol_block=ncb, force_block=force_me)
1161 :
1162 10863 : CALL section_vals_val_get(fm_section, "TYPE_OF_MATRIX_MULTIPLICATION", i_val=mm_type)
1163 10863 : CALL cp_fm_setup(mm_type)
1164 :
1165 10863 : END SUBROUTINE fm_setup
1166 :
1167 : ! **************************************************************************************************
1168 : !> \brief ...
1169 : !> \param glob_section ...
1170 : ! **************************************************************************************************
1171 10863 : SUBROUTINE dgemm_setup(glob_section)
1172 : TYPE(section_vals_type), POINTER :: glob_section
1173 :
1174 : INTEGER :: dgemm_type
1175 :
1176 10863 : CALL section_vals_val_get(glob_section, "PREFERRED_DGEMM_LIBRARY", i_val=dgemm_type)
1177 :
1178 10863 : CALL local_gemm_set_library(dgemm_type)
1179 :
1180 10863 : END SUBROUTINE dgemm_setup
1181 :
1182 : ! **************************************************************************************************
1183 : !> \brief Parses the input section used to define the heuristic rules which determine if
1184 : !> a FM matrix should be redistributed before diagonalizing it.
1185 : !> \param glob_section the global input section
1186 : !> \author Nico Holmberg [01.2018]
1187 : ! **************************************************************************************************
1188 54315 : SUBROUTINE fm_diag_rules_setup(glob_section)
1189 : TYPE(section_vals_type), POINTER :: glob_section
1190 :
1191 : INTEGER :: a, x
1192 : LOGICAL :: elpa_force_redistribute, should_print
1193 : TYPE(section_vals_type), POINTER :: section
1194 :
1195 10863 : section => section_vals_get_subs_vals(glob_section, "FM_DIAG_SETTINGS")
1196 :
1197 10863 : CALL section_vals_val_get(section, "PARAMETER_A", i_val=a)
1198 10863 : CALL section_vals_val_get(section, "PARAMETER_X", i_val=x)
1199 10863 : CALL section_vals_val_get(section, "PRINT_FM_REDISTRIBUTE", l_val=should_print)
1200 10863 : CALL section_vals_val_get(section, "ELPA_FORCE_REDISTRIBUTE", l_val=elpa_force_redistribute)
1201 :
1202 10863 : CALL cp_fm_redistribute_init(a, x, should_print, elpa_force_redistribute)
1203 :
1204 10863 : END SUBROUTINE fm_diag_rules_setup
1205 : ! **************************************************************************************************
1206 : !> \brief reads the Walltime also in format HH:MM:SS
1207 : !> \param section ...
1208 : !> \param keyword_name ...
1209 : !> \param walltime ...
1210 : !> \par History
1211 : !> none
1212 : !> \author Mandes
1213 : ! **************************************************************************************************
1214 10883 : SUBROUTINE cp2k_get_walltime(section, keyword_name, walltime)
1215 : TYPE(section_vals_type), POINTER :: section
1216 : CHARACTER(LEN=*), INTENT(in) :: keyword_name
1217 : REAL(KIND=dp), INTENT(out) :: walltime
1218 :
1219 : CHARACTER(LEN=1) :: c1, c2
1220 : CHARACTER(LEN=100) :: txt
1221 : INTEGER :: hours, ierr, minutes, n, seconds
1222 :
1223 10883 : CALL section_vals_val_get(section, keyword_name, c_val=txt)
1224 10883 : n = LEN_TRIM(txt)
1225 :
1226 10883 : IF (n == 0) THEN
1227 10662 : walltime = -1.0_dp
1228 221 : ELSE IF (INDEX(txt, ":") == 0) THEN
1229 169 : READ (txt(1:n), FMT=*, IOSTAT=ierr) walltime
1230 169 : IF (ierr /= 0) CPABORT('Could not parse WALLTIME: "'//txt(1:n)//'"')
1231 : ELSE
1232 52 : READ (txt(1:n), FMT="(I2,A1,I2,A1,I2)", IOSTAT=ierr) hours, c1, minutes, c2, seconds
1233 52 : IF (n /= 8 .OR. ierr /= 0 .OR. c1 /= ":" .OR. c2 /= ":") &
1234 0 : CPABORT('Could not parse WALLTIME: "'//txt(1:n)//'"')
1235 52 : walltime = 3600.0_dp*REAL(hours, dp) + 60.0_dp*REAL(minutes, dp) + REAL(seconds, dp)
1236 : END IF
1237 10883 : END SUBROUTINE cp2k_get_walltime
1238 :
1239 : ! **************************************************************************************************
1240 : !> \brief Writes final timings and banner for CP2K
1241 : !> \param root_section ...
1242 : !> \param para_env ...
1243 : !> \param globenv ...
1244 : !> \param wdir ...
1245 : !> \param q_finalize ...
1246 : !> \par History
1247 : !> none
1248 : !> \author JGH,MK
1249 : !> \note
1250 : !> The following routines need to be synchronized wrt. adding/removing
1251 : !> of the default environments (logging, performance,error):
1252 : !> environment:cp2k_init, environment:cp2k_finalize,
1253 : !> f77_interface:f_env_add_defaults, f77_interface:f_env_rm_defaults,
1254 : !> f77_interface:create_force_env, f77_interface:destroy_force_env
1255 : ! **************************************************************************************************
1256 21726 : SUBROUTINE cp2k_finalize(root_section, para_env, globenv, wdir, q_finalize)
1257 :
1258 : TYPE(section_vals_type), POINTER :: root_section
1259 : TYPE(mp_para_env_type), POINTER :: para_env
1260 : TYPE(global_environment_type), POINTER :: globenv
1261 : CHARACTER(LEN=*), OPTIONAL :: wdir
1262 : LOGICAL, INTENT(IN), OPTIONAL :: q_finalize
1263 :
1264 : CHARACTER(LEN=default_path_length) :: cg_filename
1265 : INTEGER :: cg_mode, iw, unit_exit
1266 : LOGICAL :: delete_it, do_finalize, report_maxloc, &
1267 : sort_by_self_time
1268 : REAL(KIND=dp) :: r_timings
1269 : TYPE(cp_logger_type), POINTER :: logger
1270 :
1271 : ! Look if we inherited a failure, more care is needed if so
1272 : ! i.e. the input is most likely not available
1273 : ! Set flag if this is a development version
1274 :
1275 10863 : do_finalize = .TRUE.
1276 10863 : IF (PRESENT(q_finalize)) do_finalize = q_finalize
1277 : ! Clean up
1278 10863 : NULLIFY (logger)
1279 10863 : logger => cp_get_default_logger()
1280 10863 : IF (do_finalize) THEN
1281 10653 : CALL deallocate_spherical_harmonics()
1282 10653 : CALL deallocate_orbital_pointers()
1283 10653 : CALL deallocate_md_ftable()
1284 10653 : CALL diag_finalize()
1285 : ! finalize the fft (i.e. writes the wisdom if FFTW3 )
1286 10653 : CALL finalize_fft(para_env, globenv%fftw_wisdom_file_name)
1287 10653 : CALL finalize_libvori()
1288 : END IF
1289 :
1290 : ! Write message passing performance info
1291 :
1292 : iw = cp_print_key_unit_nr(logger, root_section, "GLOBAL%PROGRAM_RUN_INFO", &
1293 10863 : extension=".log")
1294 10863 : CALL describe_mp_perf_env(iw)
1295 : CALL cp_print_key_finished_output(iw, logger, root_section, &
1296 10863 : "GLOBAL%PROGRAM_RUN_INFO")
1297 :
1298 10863 : CALL collect_citations_from_ranks(para_env)
1299 : iw = cp_print_key_unit_nr(logger, root_section, "GLOBAL%REFERENCES", &
1300 10863 : extension=".Log")
1301 10863 : IF (iw > 0) THEN
1302 5529 : WRITE (UNIT=iw, FMT="(/,T2,A)") REPEAT("-", 79)
1303 5529 : WRITE (UNIT=iw, FMT="(T2,A,T80,A)") "-", "-"
1304 5529 : WRITE (UNIT=iw, FMT="(T2,A,T30,A,T80,A)") "-", "R E F E R E N C E S", "-"
1305 5529 : WRITE (UNIT=iw, FMT="(T2,A,T80,A)") "-", "-"
1306 5529 : WRITE (UNIT=iw, FMT="(T2,A)") REPEAT("-", 79)
1307 5529 : WRITE (UNIT=iw, FMT="(T2,A)") ""
1308 5529 : WRITE (UNIT=iw, FMT="(T2,A)") TRIM(cp2k_version)//", the CP2K developers group ("//TRIM(cp2k_year)//")."
1309 5529 : WRITE (UNIT=iw, FMT="(T2,A)") "CP2K is freely available from "//TRIM(cp2k_home)//" ."
1310 5529 : WRITE (UNIT=iw, FMT="(T2,A)") ""
1311 5529 : CALL print_cited_references(unit=iw)
1312 : END IF
1313 : CALL cp_print_key_finished_output(iw, logger, root_section, &
1314 10863 : "GLOBAL%REFERENCES")
1315 :
1316 10863 : CALL timestop(globenv%handle) ! corresponding the "CP2K" in cp2k_init
1317 :
1318 : iw = cp_print_key_unit_nr(logger, root_section, "GLOBAL%TIMINGS", &
1319 10863 : extension=".Log")
1320 10863 : r_timings = section_get_rval(root_section, "GLOBAL%TIMINGS%THRESHOLD")
1321 10863 : sort_by_self_time = section_get_lval(root_section, "GLOBAL%TIMINGS%SORT_BY_SELF_TIME")
1322 10863 : report_maxloc = section_get_lval(root_section, "GLOBAL%TIMINGS%REPORT_MAXLOC")
1323 10863 : IF (m_energy() /= 0.0_dp) THEN
1324 0 : CALL timings_report_print(iw, r_timings, sort_by_self_time, cost_type_energy, report_maxloc, para_env)
1325 : END IF
1326 10863 : CALL timings_report_print(iw, r_timings, sort_by_self_time, cost_type_time, report_maxloc, para_env)
1327 :
1328 : ! Write the callgraph, if desired by user
1329 10863 : CALL section_vals_val_get(root_section, "GLOBAL%CALLGRAPH", i_val=cg_mode)
1330 10863 : IF (cg_mode /= CALLGRAPH_NONE) THEN
1331 2 : CALL section_vals_val_get(root_section, "GLOBAL%CALLGRAPH_FILE_NAME", c_val=cg_filename)
1332 2 : IF (LEN_TRIM(cg_filename) == 0) cg_filename = TRIM(logger%iter_info%project_name)
1333 2 : IF (cg_mode == CALLGRAPH_ALL) & !incorporate mpi-rank into filename
1334 0 : cg_filename = TRIM(cg_filename)//"_"//TRIM(ADJUSTL(cp_to_string(para_env%mepos)))
1335 2 : IF (iw > 0) THEN
1336 1 : WRITE (UNIT=iw, FMT="(T2,3X,A)") "Writing callgraph to: "//TRIM(cg_filename)//".callgraph"
1337 1 : WRITE (UNIT=iw, FMT="()")
1338 1 : WRITE (UNIT=iw, FMT="(T2,A)") "-------------------------------------------------------------------------------"
1339 : END IF
1340 2 : IF (cg_mode == CALLGRAPH_ALL .OR. para_env%is_source()) &
1341 1 : CALL timings_report_callgraph(TRIM(cg_filename)//".callgraph")
1342 : END IF
1343 :
1344 : CALL cp_print_key_finished_output(iw, logger, root_section, &
1345 10863 : "GLOBAL%TIMINGS")
1346 :
1347 10863 : CALL rm_mp_perf_env()
1348 10863 : CALL rm_timer_env()
1349 :
1350 10863 : IF (para_env%is_source()) THEN
1351 : iw = cp_print_key_unit_nr(logger, root_section, "GLOBAL%PROGRAM_RUN_INFO", &
1352 5537 : extension=".log")
1353 :
1354 : ! Deleting (if existing) the external EXIT files
1355 5537 : delete_it = .FALSE.
1356 5537 : INQUIRE (FILE="EXIT", EXIST=delete_it)
1357 5537 : IF (delete_it) THEN
1358 0 : CALL open_file(file_name="EXIT", unit_number=unit_exit)
1359 0 : CALL close_file(unit_number=unit_exit, file_status="DELETE")
1360 : END IF
1361 :
1362 5537 : delete_it = .FALSE.
1363 5537 : INQUIRE (FILE=TRIM(logger%iter_info%project_name)//".EXIT", EXIST=delete_it)
1364 5537 : IF (delete_it) THEN
1365 0 : CALL open_file(file_name=TRIM(logger%iter_info%project_name)//".EXIT", unit_number=unit_exit)
1366 0 : CALL close_file(unit_number=unit_exit, file_status="DELETE")
1367 : END IF
1368 :
1369 : ! Print OpenMP issue counter and number of warnings for this workload
1370 5537 : IF (iw > 0) THEN
1371 5537 : IF (0 <= m_omp_trace_issues()) THEN
1372 0 : WRITE (iw, "(T2,A,I0)") "The number of traced issues for OpenMP : ", m_omp_trace_issues()
1373 : END IF
1374 5537 : WRITE (iw, "(T2,A,I0)") "The number of warnings for this run is : ", warning_counter
1375 5537 : WRITE (iw, *) ""
1376 5537 : WRITE (UNIT=iw, FMT="(T2,A)") REPEAT("-", 79)
1377 : END IF
1378 :
1379 : ! Update the runtime environment variables
1380 5537 : CALL get_runtime_info()
1381 :
1382 : ! Just a choice, do not print the CP2K footer if there is a failure
1383 5799 : CALL cp2k_footer(iw, wdir)
1384 5537 : IF (iw > 0) FLUSH (iw) ! ignore &GLOBAL / FLUSH_SHOULD_FLUSH
1385 :
1386 : CALL cp_print_key_finished_output(iw, logger, root_section, &
1387 5537 : "GLOBAL%PROGRAM_RUN_INFO")
1388 : END IF
1389 :
1390 : ! Release message passing environment
1391 10863 : CALL cp_rm_default_logger()
1392 :
1393 10863 : END SUBROUTINE cp2k_finalize
1394 :
1395 : END MODULE environment
|