Skip to content

Commit

Permalink
Merge branch 'develop' into lroberts36/add-fine-variables
Browse files Browse the repository at this point in the history
  • Loading branch information
lroberts36 committed May 23, 2024
2 parents 0f07b70 + 22b5159 commit 27d3676
Show file tree
Hide file tree
Showing 7 changed files with 53 additions and 25 deletions.
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@
- [[PR 1004]](https://github.com/parthenon-hpc-lab/parthenon/pull/1004) Allow parameter modification from an input file for restarts

### Fixed (not changing behavior/API/variables/...)
- [[PR 1088]](https://github.com/parthenon-hpc-lab/parthenon/pull/1088) Correctly fill fluxes for non-cell variables in SparsePacks
- [[PR 1083]](https://github.com/parthenon-hpc-lab/parthenon/pull/1083) Correctly fill VariableFluxPack for edge fluxes in 2D
- [[PR 1087]](https://github.com/parthenon-hpc-lab/parthenon/pull/1087) Make sure InnerLoopPatternTVR is resolved on device properly when it is the default loop pattern
- [[PR 1071]](https://github.com/parthenon-hpc-lab/parthenon/pull/1070) Fix bug in static mesh refinement related to redefinition of Mesh::root_level
- [[PR 1073]](https://github.com/parthenon-hpc-lab/parthenon/pull/1073) Fix bug in AMR and sparse restarts
Expand Down
10 changes: 5 additions & 5 deletions src/interface/sparse_pack.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -350,22 +350,22 @@ class SparsePack : public SparsePackBase {
auto &flux(const int b, const int dir, const int idx) const {
PARTHENON_DEBUG_REQUIRE(!flat_, "Accessor cannot be used for flat packs");
PARTHENON_DEBUG_REQUIRE(dir > 0 && dir < 4 && with_fluxes_, "Bad input to flux call");
return pack_(dir, b, idx);
return pack_(dir - 1 + flx_idx_, b, idx);
}

KOKKOS_INLINE_FUNCTION
Real &flux(const int b, const int dir, const int idx, const int k, const int j,
const int i) const {
PARTHENON_DEBUG_REQUIRE(!flat_, "Accessor cannot be used for flat packs");
PARTHENON_DEBUG_REQUIRE(dir > 0 && dir < 4 && with_fluxes_, "Bad input to flux call");
return pack_(dir, b, idx)(k, j, i);
return pack_(dir - 1 + flx_idx_, b, idx)(k, j, i);
}

KOKKOS_INLINE_FUNCTION
Real &flux(const int dir, const int idx, const int k, const int j, const int i) const {
PARTHENON_DEBUG_REQUIRE(flat_, "Accessor must only be used for flat packs");
PARTHENON_DEBUG_REQUIRE(dir > 0 && dir < 4 && with_fluxes_, "Bad input to flux call");
return pack_(dir, 0, idx)(k, j, i);
return pack_(dir - 1 + flx_idx_, 0, idx)(k, j, i);
}

KOKKOS_INLINE_FUNCTION
Expand All @@ -375,7 +375,7 @@ class SparsePack : public SparsePackBase {
PARTHENON_DEBUG_REQUIRE(!flat_, "Accessor cannot be used for flat packs");
PARTHENON_DEBUG_REQUIRE(dir > 0 && dir < 4 && with_fluxes_, "Bad input to flux call");
const int n = bounds_(0, b, idx.VariableIdx()) + idx.Offset();
return pack_(dir, b, n)(k, j, i);
return pack_(dir - 1 + flx_idx_, b, n)(k, j, i);
}

template <class TIn, REQUIRES(IncludesType<TIn, Ts...>::value)>
Expand All @@ -384,7 +384,7 @@ class SparsePack : public SparsePackBase {
PARTHENON_DEBUG_REQUIRE(!flat_, "Accessor cannot be used for flat packs");
PARTHENON_DEBUG_REQUIRE(dir > 0 && dir < 4 && with_fluxes_, "Bad input to flux call");
const int vidx = GetLowerBound(b, t) + t.idx;
return pack_(dir, b, vidx)(k, j, i);
return pack_(dir - 1 + flx_idx_, b, vidx)(k, j, i);
}

template <class... VTs>
Expand Down
31 changes: 22 additions & 9 deletions src/interface/sparse_pack_base.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,7 @@ SparsePackBase SparsePackBase::Build(T *pmd, const PackDescriptor &desc,
int max_size = 0;
int nblocks = 0;
bool contains_face_or_edge = false;
bool contains_face_with_fluxes = false;
int size = 0; // local var used to compute size/block
ForEachBlock(pmd, include_block, [&](int b, mbd_t *pmbd) {
if (!desc.flat) {
Expand All @@ -122,8 +123,13 @@ SparsePackBase SparsePackBase::Build(T *pmd, const PackDescriptor &desc,
if (uid_map.count(uid) > 0) {
const auto pv = uid_map.at(uid);
if (pv->IsAllocated()) {
if (pv->IsSet(Metadata::Face) || pv->IsSet(Metadata::Edge))
if (pv->IsSet(Metadata::Edge)) contains_face_or_edge = true;
if (pv->IsSet(Metadata::Face)) {
if (pv->IsSet(Metadata::WithFluxes) && desc.with_fluxes) {
contains_face_with_fluxes = true;
}
contains_face_or_edge = true;
}
int prod = pv->GetDim(6) * pv->GetDim(5) * pv->GetDim(4);
size += prod; // max size/block (or total size for flat)
pack.size_ += prod; // total ragged size
Expand All @@ -138,7 +144,11 @@ SparsePackBase SparsePackBase::Build(T *pmd, const PackDescriptor &desc,

// Allocate the views
int leading_dim = 1;
if (desc.with_fluxes) {
pack.flx_idx_ = 1;
if (contains_face_with_fluxes) {
leading_dim += 5;
pack.flx_idx_ = 3;
} else if (desc.with_fluxes) {
leading_dim += 3;
} else if (contains_face_or_edge) {
leading_dim += 2;
Expand Down Expand Up @@ -205,11 +215,11 @@ SparsePackBase SparsePackBase::Build(T *pmd, const PackDescriptor &desc,

if (pv->IsSet(Metadata::Face)) {
pack.pack_h_(0, b, idx).topological_element =
TopologicalElement::E1;
TopologicalElement::F1;
pack.pack_h_(1, b, idx).topological_element =
TopologicalElement::E2;
TopologicalElement::F2;
pack.pack_h_(2, b, idx).topological_element =
TopologicalElement::E3;
TopologicalElement::F3;
}

} else { // This is a cell, node, or a variable that doesn't have
Expand All @@ -221,13 +231,16 @@ SparsePackBase SparsePackBase::Build(T *pmd, const PackDescriptor &desc,
}
if (pv->IsSet(Metadata::Vector))
pack.pack_h_(0, b, idx).vector_component = v + 1;
}

if (desc.with_fluxes && pv->IsSet(Metadata::WithFluxes)) {
pack.pack_h_(1, b, idx) = pvf->data.Get(0, t, u, v);
pack.pack_h_(2, b, idx) = pvf->data.Get(1, t, u, v);
pack.pack_h_(3, b, idx) = pvf->data.Get(2, t, u, v);
if (desc.with_fluxes && pv->IsSet(Metadata::WithFluxes)) {
pack.pack_h_(0 + pack.flx_idx_, b, idx) = pvf->data.Get(0, t, u, v);
if (!pv->IsSet(Metadata::Edge)) {
pack.pack_h_(1 + pack.flx_idx_, b, idx) = pvf->data.Get(1, t, u, v);
pack.pack_h_(2 + pack.flx_idx_, b, idx) = pvf->data.Get(2, t, u, v);
}
}

for (auto el :
GetTopologicalElements(pack.pack_h_(0, b, idx).topological_type)) {
pack.pack_h_(static_cast<int>(el) % 3, b, idx).topological_element =
Expand Down
1 change: 1 addition & 0 deletions src/interface/sparse_pack_base.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,7 @@ class SparsePackBase {
bounds_h_t bounds_h_;
coords_t coords_;

int flx_idx_;
bool with_fluxes_;
bool coarse_;
bool flat_;
Expand Down
30 changes: 21 additions & 9 deletions src/interface/variable_pack.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -452,9 +452,14 @@ class VariableFluxPack : public VariablePack<T> {
// host only
inline auto flux_alloc_status() const { return flux_alloc_status_; }

KOKKOS_FORCEINLINE_FUNCTION
const ViewOfParArrays<T> &flux(const int dir) const {
assert(dir > 0 && dir <= this->ndim_);
template <TopologicalType TT = TopologicalType::Face>
KOKKOS_FORCEINLINE_FUNCTION const ViewOfParArrays<T> &flux(const int dir) const {
assert(dir > 0);
if constexpr (TT == TopologicalType::Edge) {
assert(dir <= this->ndim_ || (this->ndim_ == 2 && dir == 3));
} else {
assert(dir <= this->ndim_);
}
return f_[dir - 1];
}

Expand All @@ -471,10 +476,11 @@ class VariableFluxPack : public VariablePack<T> {
constexpr bool IsFluxAllocated(const int /*n*/) const { return true; }
#endif

KOKKOS_FORCEINLINE_FUNCTION
T &flux(const int dir, const int n, const int k, const int j, const int i) const {
template <TopologicalType TT = TopologicalType::Face>
KOKKOS_FORCEINLINE_FUNCTION T &flux(const int dir, const int n, const int k,
const int j, const int i) const {
assert(IsFluxAllocated(n));
return flux(dir)(n)(k, j, i);
return flux<TT>(dir)(n)(k, j, i);
}

private:
Expand Down Expand Up @@ -681,9 +687,15 @@ void FillFluxViews(const VariableVector<T> &vars, const int ndim,
for (int i = 0; i < v->GetDim(4); i++) {
host_al(vindex) = v->IsAllocated();
if (v->IsAllocated()) {
host_f1(vindex) = v->data.Get(0, k, j, i);
if (ndim >= 2) host_f2(vindex) = v->data.Get(1, k, j, i);
if (ndim >= 3) host_f3(vindex) = v->data.Get(2, k, j, i);
if (v->IsSet(Metadata::Edge)) {
if (ndim >= 2) host_f3(vindex) = v->data.Get(2, k, j, i);
if (ndim >= 3) host_f2(vindex) = v->data.Get(1, k, j, i);
if (ndim >= 3) host_f1(vindex) = v->data.Get(0, k, j, i);
} else {
host_f1(vindex) = v->data.Get(0, k, j, i);
if (ndim >= 2) host_f2(vindex) = v->data.Get(1, k, j, i);
if (ndim >= 3) host_f3(vindex) = v->data.Get(2, k, j, i);
}
}

vindex++;
Expand Down
2 changes: 1 addition & 1 deletion src/utils/interpolation.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
// Interpolation copied/refactored from
// https://github.com/lanl/phoebus and https://github.com/lanl/spiner
//========================================================================================
// (C) (or copyright) 2022-2024. Triad National Security, LLC. All rights reserved.
// (C) (or copyright) 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
2 changes: 1 addition & 1 deletion src/utils/robust.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
//========================================================================================
// Copied from https://github.com/lanl/phoebus
//========================================================================================
// (C) (or copyright) 2022-2024. Triad National Security, LLC. All rights reserved.
// (C) (or copyright) 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

0 comments on commit 27d3676

Please sign in to comment.