3331 Commits

Author SHA1 Message Date
b75d87dc7e Merge branch 'master' into reconnection 2023-12-31 17:47:14 -03:00
78e3b72889 STATISTICS: Parallelize statistics calculation with OpenMP.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-31 17:45:17 -03:00
5470bbd0da Merge branch 'master' into reconnection 2023-12-28 20:44:10 -03:00
659449669b EVOLUTION: Fix wrong import in update_errors_lmax().
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-28 11:52:22 -03:00
60d13dff6c EVOLUTION: Update subroutine to calculate errors using Lmax-norm.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-28 11:14:34 -03:00
213879c9c4 EVOLUTION: Update subroutine to calculate errors using L2-norm.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-28 10:56:11 -03:00
de49eeedaa EVOLUTION: Add subroutine to calculate errors using the L1-norm.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-28 10:49:24 -03:00
b35d44da73 Merge branch 'master' into reconnection 2023-12-26 22:24:19 -03:00
7c292e7095 EVOLUTION: Fix possible overflow in update_errors_l2().
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-26 22:20:24 -03:00
f66287621e Merge branch 'master' into reconnection 2023-12-23 12:16:30 -03:00
7ab1348259 STATISTICS: Get 'statistics_interval' on all processes.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-23 12:13:13 -03:00
68449d0ccc IO: Add ACTION and STATUS flags to OPEN statements.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-20 18:33:58 -03:00
63d5e5eba1 Merge branch 'master' into reconnection 2023-12-19 16:04:04 -03:00
9455f9be9a IO: Use action='read' explicitely when opening a file for read-only.
Additionally, unify formatting of statements OPEN, READ, WRITE, CLOSE,
INQUIRE.

Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-19 15:55:33 -03:00
f0fbf04cb7 XML: Open a XML file as read-only in XMLParseFile().
Additionally, unify formatting of statements OPEN, READ, WRITE, CLOSE,
INQUIRE.

Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-19 15:47:21 -03:00
bdd09a044b PARAMETERS: Unify formatting of CLOSE statement too.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-19 15:39:44 -03:00
bb36b90171 IO: Access the metadata file as read-only while restoring parameters.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-19 15:38:40 -03:00
f31cb12545 PARAMS: Unify formatting of INQUIRE, READ, and WRITE statements.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-19 15:33:29 -03:00
b10e8d8db4 PARAMETERS: Access the parameter file as read-only.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-19 15:24:45 -03:00
ed7d1205a6 Merge branch 'master' into reconnection 2023-12-18 09:35:17 -03:00
0c8cab74a2 IO, PARAMETERS, SYSTEM: Better parameter restoring.
This commit implements a better way (less I/O operations) restoring of
the parameters during the job restart. Some parameters, such as the size
of the block, or the equation system, cannot be changed during the
restart. Such parameters need to be restored from the restart snapshots.
The new way restores these parameters on the MPI master process only,
updates their values if they were changed, and distributes them to other
MPI processes. This way the number of I/O operations is kept to the
minimum (only one process access one file).

Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-18 09:30:07 -03:00
66f5fc5c58 PARAMETERS: Read parameters on master and distribute them.
This commit restores the previous way of processing the parameter file.
It is read and processed on the MPI master process, and then the list
of parameters is distributed to other MPI processes. This way only one
process accesses the parameter file, reducing the number of I/O
operations, which can be significant in the case of multiprocess MPI
jobs.

Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-17 21:47:38 -03:00
6847d1c994 PARAMETERS: Rewrite module with use of variable strings.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-17 18:09:12 -03:00
37e7b5e2a8 Merge branch 'master' into reconnection 2023-12-14 18:21:41 -03:00
58b6a62ff8 IO: Fix wrong dimensions of corners() in store_metablocks_h5().
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-12-14 16:57:35 -03:00
844800ed5e USER_PROBLEM: Add new perturbation of spectrum of waves.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-11-14 11:26:19 -03:00
947a09c568 USER_PROBLEM: Fix a typo.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-11-01 09:37:29 -03:00
a4dd463548 USER_PROBLEM: Add transverse field and external perturbation.
The external perturbation is provided through a file, one per level with
velocity and magnetic field perturbations.

Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-11-01 09:36:07 -03:00
5333ebdf37 EVOLUTION: 3S*+ RK methods do not have extended CFL coefficients.
The methods by Ranocha et al. (2021) are error-controlled embedded RK
methods, therefore the CFL value should be set explicitely for these
methods.

Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-09-01 16:36:36 -03:00
62017bc5b3 EVOLUTION: Improve the conservation in SSPRK(10,4) method.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-30 17:37:09 -03:00
ac74a7cc2e Merge branch 'master' into reconnection 2023-08-29 17:45:15 -03:00
26022c4ce0 EVOLUTION, FORCING: Add injected flag to update_forcing().
This flag indicates whether the energy injection was performed. If not,
there is no need for the variable update.

Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-29 17:43:03 -03:00
7af3c7dd73 Merge branch 'master' into reconnection 2023-08-29 17:23:51 -03:00
55b13fb895 EVOLUTION: Add missing variable update after adding turbulence forcing.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-29 17:09:48 -03:00
48f6618121 Revert "EVOLUTION: Update all blocks after the mesh update."
This reverts commit 8b36ce58e18bdc5af35c03571e77c5566efb2ae0.
2023-08-29 17:06:15 -03:00
fd3ff031a5 Merge branch 'master' into reconnection 2023-08-29 10:54:11 -03:00
dfe7310408 EVOLUTION: Improve the conservation in the SSPRK3 and SSPRK(4,3) methods.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-29 10:43:42 -03:00
91d3583a78 STATISTICS: Use Kahan summation for statistics integration.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-29 10:32:52 -03:00
8b36ce58e1 EVOLUTION: Update all blocks after the mesh update.
It seems that the selective block update, i.e., update of the blocks
which have been (de)refined only, is not perfect. It violates the
numerical conservation somehow, and requires more investigation.

In order to fix this, perform the update of all data blocks, no matter
if they were refined or not. This makes some blocks to be updated twice,
but resolves the problem of variable conservation.

Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-29 10:15:08 -03:00
39c3cdf7a4 EVOLUTION: Improve the conservation in the SSPRK3(2)4 method.
The 4th step produced errors large enought to give significant
conservation errors.

Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-28 17:53:59 -03:00
e04cc6297a Merge branch 'master' into reconnection 2023-08-14 17:32:28 -03:00
03e99457cc MAKE: Fix mkdeps.sh.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-14 16:42:37 -03:00
47b3b50ae0 IO: Improve description of subroutine write_binary_xml().
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-14 13:05:24 -03:00
a71a1390ca IO: Formatting correction.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-14 12:49:42 -03:00
5574b6fcf1 IO: Rewrite storing of restart and regular XML snapshots.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-14 11:50:07 -03:00
b11a1fad58 XML: Add subroutines to initialize a new tree and add elements.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-14 10:13:40 -03:00
8ac5e49def IO: Enable compression when storing XML restart snapshot.
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-12 07:08:48 -03:00
c015d5849a IO: Add missing item_size for 'complex64' in read_binary_xml().
Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-11 19:54:29 -03:00
14fad08f47 IO: Rewrite read_restart_snapshot_xml().
This subroutine now used the new XML module to parge XML files. It also
used new subroutine read_binary_xml() to read binary files.

Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-11 19:41:00 -03:00
64966c3eb3 IO: Add subroutine to read binary XML files.
This subroutine is also responsible for detection if binary data are
compressed and encoded, and respectively decompress and decode them.

Signed-off-by: Grzegorz Kowal <grzegorz@amuncode.org>
2023-08-11 19:29:08 -03:00