Skip to content

Commit

Permalink
Merge branch 'Exawind:master' into multiphase_upwinding
Browse files Browse the repository at this point in the history
  • Loading branch information
wjhorne authored Jul 18, 2024
2 parents 27101d0 + 53f4939 commit 247d582
Show file tree
Hide file tree
Showing 5 changed files with 26 additions and 71 deletions.
30 changes: 18 additions & 12 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ jobs:
container:
image: ecpe4s/exawind-snapshot
env:
SPACK_MANAGER: /spack-manager
EXAWIND_MANAGER: /exawind-manager
E4S_MACHINE: true
steps:
- name: Cancel previous runs
Expand All @@ -38,13 +38,16 @@ jobs:
- name: Tests
run: |
/bin/bash -c " \
source ${SPACK_MANAGER}/start.sh && \
mkdir -p ${SPACK_MANAGER}/environments/exawind && \
cd ${SPACK_MANAGER}/environments/exawind && \
source ${EXAWIND_MANAGER}/start.sh && \
mkdir -p ${EXAWIND_MANAGER}/environments/exawind && \
cd ${EXAWIND_MANAGER}/environments/exawind && \
ln -s ${GITHUB_WORKSPACE} nalu-wind && \
source ${SPACK_MANAGER}/start.sh && \
spack-start && \
spack -e e4s-build config add view:true && \
spack -e e4s-build add cmake && \
spack -e e4s-build install && \
quick-create-dev -s nalu-wind@master+tioga+hypre && \
spack manager external --latest --blacklist nalu-wind gmake && \
spack manager external ${EXAWIND_MANAGER}/environments/e4s-build --exclude nalu-wind gmake && \
spack install && \
spack cd -b nalu-wind && \
spack build-env nalu-wind ctest -j $(nproc) -L unit --output-on-failure \
Expand All @@ -55,7 +58,7 @@ jobs:
container:
image: ecpe4s/exawind-snapshot
env:
SPACK_MANAGER: /spack-manager
EXAWIND_MANAGER: /exawind-manager
E4S_MACHINE: true
steps:
- name: Cancel previous runs
Expand All @@ -69,13 +72,16 @@ jobs:
- name: Tests
run: |
/bin/bash -c " \
source ${SPACK_MANAGER}/start.sh && \
mkdir -p ${SPACK_MANAGER}/environments/exawind && \
cd ${SPACK_MANAGER}/environments/exawind && \
source ${EXAWIND_MANAGER}/start.sh && \
mkdir -p ${EXAWIND_MANAGER}/environments/exawind && \
cd ${EXAWIND_MANAGER}/environments/exawind && \
ln -s ${GITHUB_WORKSPACE} nalu-wind && \
source ${SPACK_MANAGER}/start.sh && \
spack-start && \
spack -e e4s-build config add view:true && \
spack -e e4s-build add cmake && \
spack -e e4s-build install && \
quick-create-dev -s nalu-wind@master+tioga+hypre~trilinos-solvers && \
spack manager external --latest --blacklist nalu-wind gmake && \
spack manager external ${EXAWIND_MANAGER}/environments/e4s-build --exclude nalu-wind gmake && \
spack install && \
spack cd -b nalu-wind && \
spack build-env nalu-wind ctest -j $(nproc) -L unit --output-on-failure \
Expand Down
8 changes: 1 addition & 7 deletions include/overset/TiogaBlock.h
Original file line number Diff line number Diff line change
Expand Up @@ -183,14 +183,8 @@ class TiogaBlock

/** Update iblanks after connectivity updates
*/
void update_iblanks();
/** Update fringe and hole node vectors
*/
void update_fringe_and_hole_nodes(
void update_iblanks(
std::vector<stk::mesh::Entity>&, std::vector<stk::mesh::Entity>&);
/** Update the Tioga view of iblanks prior to donor-to-receptor interpolation
*/
void update_tioga_iblanks();

/** Update element iblanks after connectivity updates
*/
Expand Down
2 changes: 1 addition & 1 deletion reg_tests/CTestList.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -278,7 +278,7 @@ if(NOT ENABLE_CUDA AND NOT ENABLE_ROCM)
# Unit tests
#=============================================================================
add_test_u(unitTest1 1)
add_test_u(unitTest2 2)
#add_test_u(unitTest2 2) # Can hang indefinitely

#=============================================================================
# Performance tests
Expand Down
42 changes: 3 additions & 39 deletions src/overset/TiogaBlock.C
Original file line number Diff line number Diff line change
Expand Up @@ -224,7 +224,9 @@ TiogaBlock::update_connectivity()
}

void
TiogaBlock::update_iblanks()
TiogaBlock::update_iblanks(
std::vector<stk::mesh::Entity>& holeNodes,
std::vector<stk::mesh::Entity>& fringeNodes)
{
sierra::nalu::ScalarIntFieldType* ibf =
meta_.get_field<int>(stk::topology::NODE_RANK, "iblank");
Expand All @@ -239,25 +241,7 @@ TiogaBlock::update_iblanks()
int* ib = stk::mesh::field_data(*ibf, *b);
for (size_t in = 0; in < b->size(); in++) {
ib[in] = ibnode(ip++);
}
}
}

void
TiogaBlock::update_fringe_and_hole_nodes(
std::vector<stk::mesh::Entity>& holeNodes,
std::vector<stk::mesh::Entity>& fringeNodes)
{
sierra::nalu::ScalarIntFieldType* ibf =
meta_.get_field<int>(stk::topology::NODE_RANK, "iblank");

stk::mesh::Selector mesh_selector = get_node_selector(blkParts_);
const stk::mesh::BucketVector& mbkts =
bulk_.get_buckets(stk::topology::NODE_RANK, mesh_selector);

for (auto b : mbkts) {
int* ib = stk::mesh::field_data(*ibf, *b);
for (size_t in = 0; in < b->size(); in++) {
if (ib[in] == 0) {
holeNodes.push_back((*b)[in]);
} else if (ib[in] == -1) {
Expand All @@ -267,26 +251,6 @@ TiogaBlock::update_fringe_and_hole_nodes(
}
}

void
TiogaBlock::update_tioga_iblanks()
{
sierra::nalu::ScalarIntFieldType* ibf =
meta_.get_field<int>(stk::topology::NODE_RANK, "iblank");

stk::mesh::Selector mesh_selector = get_node_selector(blkParts_);
const stk::mesh::BucketVector& mbkts =
bulk_.get_buckets(stk::topology::NODE_RANK, mesh_selector);

auto& ibnode = bdata_.iblank_.h_view;
int ip = 0;
for (auto b : mbkts) {
int* ib = stk::mesh::field_data(*ibf, *b);
for (size_t in = 0; in < b->size(); in++) {
ibnode(ip++) = ib[in];
}
}
}

void
TiogaBlock::update_iblank_cell()
{
Expand Down
15 changes: 3 additions & 12 deletions src/overset/TiogaSTKIface.C
Original file line number Diff line number Diff line change
Expand Up @@ -160,7 +160,8 @@ TiogaSTKIface::post_connectivity_work(const bool isDecoupled)
{
for (auto& tb : blocks_) {
// Update IBLANK information at nodes and elements
tb->update_iblanks();
tb->update_iblanks(
oversetManager_.holeNodes_, oversetManager_.fringeNodes_);
tb->update_iblank_cell();

// For each block determine donor elements that needs to be ghosted to other
Expand All @@ -173,17 +174,7 @@ TiogaSTKIface::post_connectivity_work(const bool isDecoupled)
sierra::nalu::ScalarIntFieldType* ibf =
meta_.get_field<int>(stk::topology::NODE_RANK, "iblank");
std::vector<const stk::mesh::FieldBase*> pvec{ibf};
stk::mesh::parallel_min(bulk_, {ibf});

for (auto& tb : blocks_) {
// Call update_iblanks again to assign holeNodes and fringeNodes vectors
// after iblanks on shared nodes are corrected
tb->update_fringe_and_hole_nodes(
oversetManager_.holeNodes_, oversetManager_.fringeNodes_);
// Return the corrected iblank field to Tioga prior to donor-to-receptor
// interpolation
tb->update_tioga_iblanks();
}
stk::mesh::copy_owned_to_shared(bulk_, pvec);

post_connectivity_sync();

Expand Down

0 comments on commit 247d582

Please sign in to comment.