Skip to content

Commit

Permalink
Merge branch 'develop' into jmm/two-more-pedagogical-examples
Browse files Browse the repository at this point in the history
  • Loading branch information
Yurlungur authored Sep 30, 2024
2 parents b4c9ad6 + 3de592d commit 27d5491
Show file tree
Hide file tree
Showing 101 changed files with 2,348 additions and 1,392 deletions.
14 changes: 11 additions & 3 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,14 +2,21 @@

## Current develop

### Changed (changing behavior/API/variables/...)
### Added (new features/APIs/variables/...)
- [[PR 1179]](https://github.com/parthenon-hpc-lab/parthenon/pull/1179) Make a global variable for whether simulation is a restart
- [[PR 1171]](https://github.com/parthenon-hpc-lab/parthenon/pull/1171) Add PARTHENON_USE_SYSTEM_PACKAGES build option
- [[PR 1161]](https://github.com/parthenon-hpc-lab/parthenon/pull/1161) Make flux field Metadata accessible, add Metadata::CellMemAligned flag, small perfomance upgrades

### Changed (changing behavior/API/variables/...)
- [[PR 1171]](https://github.com/parthenon-hpc-lab/parthenon/pull/1171) Add PARTHENON_USE_SYSTEM_PACKAGES build option
- [[PR 1172]](https://github.com/parthenon-hpc-lab/parthenon/pull/1172) Make parthenon manager robust against external MPI init and finalize calls

### Fixed (not changing behavior/API/variables/...)

- [[PR 1178]](https://github.com/parthenon-hpc-lab/parthenon/pull/1178) Fix issue with mesh pointer when using relative residual tolerance in BiCGSTAB solver.
- [[PR1173]](https://github.com/parthenon-hpc-lab/parthenon/pull/1173) Make debugging easier by making parthenon throw an error if ParameterInput is different on multiple MPI ranks.

### Infrastructure (changes irrelevant to downstream codes)

- [[PR1176]](https://github.com/parthenon-hpc-lab/parthenon/pull/1176) Move some code from header to implementation files

### Removed (removing behavior/API/varaibles/...)

Expand All @@ -21,6 +28,7 @@
Date: 2024-08-30

### Added (new features/APIs/variables/...)
- [[PR 1167]](https://github.com/parthenon-hpc-lab/parthenon/pull/1167) Store block gid and neighbor refinement levels in sparse packs
- [[PR 1151]](https://github.com/parthenon-hpc-lab/parthenon/pull/1151) Add time offset `c` to LowStorageIntegrator
- [[PR 1147]](https://github.com/parthenon-hpc-lab/parthenon/pull/1147) Add `par_reduce_inner` functions
- [[PR 1159]](https://github.com/parthenon-hpc-lab/parthenon/pull/1159) Add additional timestep controllers in parthenon/time.
Expand Down
20 changes: 17 additions & 3 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
# Copyright(C) 2020-2024 The Parthenon collaboration
# Licensed under the 3-clause BSD License, see LICENSE file for details
#=========================================================================================
# (C) (or copyright) 2020-2023. Triad National Security, LLC. All rights reserved.
# (C) (or copyright) 2020-2024. Triad National Security, LLC. All rights reserved.
#
# This program was produced under U.S. Government contract 89233218CNA000001 for Los
# Alamos National Laboratory (LANL), which is operated by Triad National Security, LLC
Expand Down Expand Up @@ -60,6 +60,17 @@ option(CODE_COVERAGE "Enable code coverage reporting" OFF)
option(ENABLE_ASAN "Turn on ASAN" OFF)
option(ENABLE_HWASAN "Turn on HWASAN (currently ARM-only)" OFF)

option(PARTHENON_USE_SYSTEM_PACKAGES "Enables search for system packages when available" OFF)
if (PARTHENON_USE_SYSTEM_PACKAGES)
option(PARTHENON_IMPORT_KOKKOS
"If ON, attempt to link to an external Kokkos library. If OFF, build Kokkos from source and package with Parthenon"
ON)
else()
option(PARTHENON_IMPORT_KOKKOS
"If ON, attempt to link to an external Kokkos library. If OFF, build Kokkos from source and package with Parthenon"
OFF)
endif()

include(cmake/Format.cmake)
include(cmake/Lint.cmake)

Expand Down Expand Up @@ -204,7 +215,6 @@ endif()
set(CMAKE_CXX_STANDARD_REQUIRED ON)
set(CMAKE_CXX_STANDARD 17)

option(PARTHENON_IMPORT_KOKKOS "If ON, attempt to link to an external Kokkos library. If OFF, build Kokkos from source and package with Parthenon" OFF)
if (NOT TARGET Kokkos::kokkos)
if (PARTHENON_IMPORT_KOKKOS)
find_package(Kokkos 4)
Expand Down Expand Up @@ -367,7 +377,11 @@ if (PARTHENON_ENABLE_UNIT_TESTS OR PARTHENON_ENABLE_INTEGRATION_TESTS OR PARTHEN
endif()

if (PARTHENON_ENABLE_ASCENT)
find_package(Ascent REQUIRED NO_DEFAULT_PATH)
if (PARTHENON_USE_SYSTEM_PACKAGES)
find_package(Ascent REQUIRED)
else()
find_package(Ascent REQUIRED NO_DEFAULT_PATH)
endif()
endif()

# Installation configuration
Expand Down
3 changes: 2 additions & 1 deletion doc/sphinx/src/building.rst
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,8 @@ General list of cmake options:
|| PARTHENON\_COPYRIGHT\_CHECK\_DEFAULT || OFF || Option || Check copyright as part of the default target (otherwise use the `check-copyright` target) |
|| CMAKE\_INSTALL\_PREFIX || machine specific || String || Optional path for library installation |
|| Kokkos\_ROOT || unset || String || Path to a Kokkos source directory (containing CMakeLists.txt) |
|| PARTHENON\_IMPORT\_KOKKOS || ON/OFF || Option || If ON, attempt to link to an external Kokkos library. If OFF, build Kokkos from source and package with Parthenon |
|| PARTHENON\_USE\_SYSTEM\_PACKAGES || OFF || Option || If ON, attempt to link to system dependencies for Kokkos and Ascent if possible. If OFF, will avoid doing so by default. |
|| PARTHENON\_IMPORT\_KOKKOS || OFF/ON || Option || If ON, attempt to link to an external Kokkos library. Else build from source. Default is ON if PARTHENON\_USE\_SYSTEM\_PACKAGES and OFF otherwise. |
|| BUILD\_SHARED\_LIBS || OFF || Option || If installing Parthenon, whether to build as shared rather than static |
+-------------------------------------------+--------------------------------+---------+--------------------------------------------------------------------------------------------------------------------------------------------------------------+

Expand Down
19 changes: 16 additions & 3 deletions doc/sphinx/src/interface/metadata.rst
Original file line number Diff line number Diff line change
Expand Up @@ -158,9 +158,22 @@ classes may be allocated. The behaviours are the following:
sense (e.g. if the ``WithFluxes`` variable has ``Metadata::Cell``
set the new variable will have ``Metadata::Face``) will be created in
the package with the name ``bnd_flux::name_of_original_variable`` and
``Metadata::Flux`` and ``Metadata::OneCopy``. When creating packs that
include fluxes, the new flux field will be included in the flux portion
of the pack if the parent field is in the pack.
``Metadata::Flux`` and ``Metadata::OneCopy``. Additionally, the flags
``Metadata::Sparse``, ``Metadata::Vector``, and ``Metadata::Tensor``
will propagate to the flux ``Metadata`` if they are set in the base field
``Metadata``. By default, a flux field for a cell-centered field is
built with ``Metadata::CellMemAligned`` flag set for backwards
compatability. A shared pointer to the ``Metadata`` object for the flux
field can be accessed from the base ``Metadata`` with the method
``Metadata::GetSPtrFluxMetadata()``. This can be used to set flags other
than the defaults or set custom prolongation/restriction operations for
the fluxes. Note that calling `Metadata::RegisterRefinementOps<...>()`
on the base field propagates the registered refinement operations through
to the flux `Metadata` for backward compatibility. If separate operations
are desired for the fluxes, the ordering of calls to `RegisterRefinementOps`
on the base field and the flux field matters. When creating packs that
include fluxes, the new flux field will be included in the flux portion of
the pack if the parent field is in the pack.

- If ``Metadata::Flux`` is set, this field is exchanged on shared elements
across fine-coarse boundaries when the flux correction tasks are called.
Expand Down
3 changes: 3 additions & 0 deletions example/advection/parthenon_app_inputs.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,9 @@
// the public, perform publicly and display publicly, and to permit others to do so.
//========================================================================================

#include <algorithm>
#include <cstdio>
#include <memory>
#include <sstream>
#include <string>

Expand Down
1 change: 1 addition & 0 deletions example/calculate_pi/pi_driver.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@

// Standard Includes
#include <fstream>
#include <iostream>
#include <memory>
#include <string>
#include <vector>
Expand Down
1 change: 1 addition & 0 deletions example/fine_advection/parthenon_app_inputs.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
// the public, perform publicly and display publicly, and to permit others to do so.
//========================================================================================

#include <memory>
#include <sstream>
#include <string>

Expand Down
2 changes: 1 addition & 1 deletion example/kokkos_pi/kokkos_pi.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@
// and using flat range and MDRange in Kokkos
//

#include <stdio.h>
#include <cstdio>

#include <iostream>
#include <memory>
Expand Down
1 change: 1 addition & 0 deletions example/poisson/parthenon_app_inputs.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@

#include <sstream>
#include <string>
#include <vector>

#include <parthenon/package.hpp>

Expand Down
1 change: 1 addition & 0 deletions example/poisson/poisson_driver.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
//========================================================================================

#include <algorithm>
#include <iostream>
#include <memory>
#include <string>
#include <vector>
Expand Down
1 change: 1 addition & 0 deletions example/poisson/poisson_package.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@

#include <algorithm>
#include <cmath>
#include <iostream>
#include <limits>
#include <memory>
#include <string>
Expand Down
1 change: 1 addition & 0 deletions example/poisson_gmg/poisson_driver.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
//========================================================================================

#include <algorithm>
#include <cstdio>
#include <memory>
#include <string>
#include <vector>
Expand Down
1 change: 1 addition & 0 deletions example/poisson_gmg/poisson_package.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
#include <limits>
#include <memory>
#include <string>
#include <utility>
#include <vector>

#include <bvals/boundary_conditions_generic.hpp>
Expand Down
6 changes: 5 additions & 1 deletion example/sparse_advection/parthenon_app_inputs.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -10,9 +10,13 @@
// the public, perform publicly and display publicly, and to permit others to do so.
//========================================================================================

#include <algorithm>
#include <cstdio>
#include <limits>
#include <memory>
#include <sstream>
#include <string>
#include <vector>

#include <parthenon/package.hpp>

Expand Down Expand Up @@ -141,7 +145,7 @@ void PostStepDiagnosticsInLoop(Mesh *mesh, ParameterInput *pin, const SimTime &t
}

#ifdef MPI_PARALLEL
static_assert(sizeof(std::uint64_t) == sizeof(unsigned long long int),
static_assert(sizeof(std::uint64_t) == sizeof(unsigned long long int), // NOLINT
"MPI_UNSIGNED_LONG_LONG same as uint64_t");
if (Globals::my_rank == 0) {
PARTHENON_MPI_CHECK(MPI_Reduce(MPI_IN_PLACE, num_allocated.data(), n, MPI_INT,
Expand Down
3 changes: 3 additions & 0 deletions example/stochastic_subgrid/parthenon_app_inputs.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,9 @@
// the public, perform publicly and display publicly, and to permit others to do so.
//========================================================================================

#include <algorithm>
#include <cstdio>
#include <memory>
#include <sstream>
#include <string>

Expand Down
2 changes: 2 additions & 0 deletions src/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -230,6 +230,7 @@ add_library(parthenon
solvers/mg_solver.hpp
solvers/solver_utils.hpp

tasks/tasks.cpp
tasks/tasks.hpp
tasks/thread_pool.hpp

Expand All @@ -244,6 +245,7 @@ add_library(parthenon
utils/bit_hacks.hpp
utils/buffer_utils.cpp
utils/buffer_utils.hpp
utils/cell_center_offsets.cpp
utils/cell_center_offsets.hpp
utils/change_rundir.cpp
utils/communication_buffer.hpp
Expand Down
2 changes: 2 additions & 0 deletions src/amr_criteria/amr_criteria.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,9 @@
//========================================================================================
#include "amr_criteria/amr_criteria.hpp"

#include <iostream>
#include <memory>
#include <string>

#include "amr_criteria/refinement_package.hpp"
#include "interface/meshblock_data.hpp"
Expand Down
1 change: 1 addition & 0 deletions src/amr_criteria/refinement_package.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
#include <algorithm>
#include <exception>
#include <memory>
#include <string>
#include <utility>

#include "amr_criteria/amr_criteria.hpp"
Expand Down
1 change: 1 addition & 0 deletions src/argument_parser.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
#ifndef ARGUMENT_PARSER_HPP_
#define ARGUMENT_PARSER_HPP_

#include <cstdio>
#include <iostream>
#include <string>

Expand Down
11 changes: 7 additions & 4 deletions src/bvals/boundary_conditions.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -19,14 +19,17 @@
#include <string>

#include "basic_types.hpp"
#include "interface/meshblock_data.hpp"
#include "interface/swarm_container.hpp"
#include "mesh/domain.hpp"

namespace parthenon {

// Physical boundary conditions
// Forward declarations
template <typename T>
class MeshBlockData;
template <typename T>
class MeshData;
class Swarm;

// Physical boundary conditions
using BValFunc = std::function<void(std::shared_ptr<MeshBlockData<Real>> &, bool)>;
using SBValFunc = std::function<void(std::shared_ptr<Swarm> &)>;

Expand Down
1 change: 1 addition & 0 deletions src/bvals/bvals.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@
#include <iostream>
#include <iterator>
#include <limits>
#include <memory>
#include <sstream>
#include <stdexcept>
#include <string>
Expand Down
1 change: 1 addition & 0 deletions src/bvals/comms/bnd_info.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
//========================================================================================

#include <algorithm>
#include <cstdio>
#include <iostream> // debug
#include <memory>
#include <string>
Expand Down
2 changes: 1 addition & 1 deletion src/bvals/comms/boundary_communication.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -213,7 +213,7 @@ TaskStatus ReceiveBoundBufs(std::shared_ptr<MeshData<Real>> &md) {
[&all_received](auto pbuf) { all_received = pbuf->TryReceive() && all_received; });

int ibound = 0;
if (Globals::sparse_config.enabled) {
if (Globals::sparse_config.enabled && all_received) {
ForEachBoundary<bound_type>(
md, [&](auto pmb, sp_mbd_t rc, nb_t &nb, const sp_cv_t v) {
const std::size_t ibuf = cache.idx_vec[ibound];
Expand Down
1 change: 1 addition & 0 deletions src/bvals/comms/build_boundary_buffers.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
#include <random>
#include <string>
#include <unordered_map>
#include <utility>
#include <vector>

#include "bvals_in_one.hpp"
Expand Down
4 changes: 3 additions & 1 deletion src/bvals/comms/tag_map.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,11 @@
// the public, perform publicly and display publicly, and to permit others to do so.
//========================================================================================

#include "tag_map.hpp"
#include <memory>

#include "bnd_info.hpp"
#include "bvals_utils.hpp"
#include "tag_map.hpp"
#include "utils/loop_utils.hpp"

namespace parthenon {
Expand Down
1 change: 1 addition & 0 deletions src/bvals/neighbor_block.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
#include <stdexcept> // runtime_error
#include <string> // c_str()
#include <unordered_set>
#include <vector>

#include "globals.hpp"
#include "mesh/forest/logical_location.hpp"
Expand Down
3 changes: 3 additions & 0 deletions src/driver/driver.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,10 @@
#include <chrono>
#include <fstream>
#include <iomanip>
#include <iostream>
#include <limits>
#include <string>
#include <vector>

#include "driver/driver.hpp"

Expand Down
7 changes: 4 additions & 3 deletions src/globals.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
// Copyright(C) 2014 James M. Stone <[email protected]> and other code contributors
// Licensed under the 3-clause BSD License, see LICENSE file for details
//========================================================================================
// (C) (or copyright) 2020-2021. Triad National Security, LLC. All rights reserved.
// (C) (or copyright) 2020-2024. Triad National Security, LLC. All rights reserved.
//
// This program was produced under U.S. Government contract 89233218CNA000001 for Los
// Alamos National Laboratory (LANL), which is operated by Triad National Security, LLC
Expand All @@ -30,8 +30,9 @@ namespace Globals {
int nghost;

// all of these global variables are set at the start of main():
int my_rank; // MPI rank of this process
int nranks; // total number of MPI ranks
int my_rank; // MPI rank of this process
int nranks; // total number of MPI ranks
bool is_restart; // Whether this simulation is restarted from a checkpoint file

// sparse configuration values that are needed in various places
SparseConfig sparse_config;
Expand Down
3 changes: 2 additions & 1 deletion src/globals.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
// Copyright(C) 2014 James M. Stone <[email protected]> and other code contributors
// Licensed under the 3-clause BSD License, see LICENSE file for details
//========================================================================================
// (C) (or copyright) 2020-2021. Triad National Security, LLC. All rights reserved.
// (C) (or copyright) 2020-2024. Triad National Security, LLC. All rights reserved.
//
// This program was produced under U.S. Government contract 89233218CNA000001 for Los
// Alamos National Laboratory (LANL), which is operated by Triad National Security, LLC
Expand Down Expand Up @@ -36,6 +36,7 @@ struct SparseConfig {
};

extern int my_rank, nranks, nghost;
extern bool is_restart;

extern SparseConfig sparse_config;

Expand Down
1 change: 1 addition & 0 deletions src/interface/data_collection.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
// the public, perform publicly and display publicly, and to permit others to do so.
//========================================================================================

#include <memory>
#include <string>

#include "interface/data_collection.hpp"
Expand Down
Loading

0 comments on commit 27d5491

Please sign in to comment.