Skip to content

Commit

Permalink
Merge pull request #448 from fgfuchs/log_loadbalancing_info
Browse files Browse the repository at this point in the history
log loadbalancing info on rank 0
  • Loading branch information
atgeirr authored Mar 2, 2020
2 parents 0cc672d + bca8c36 commit f6cda38
Showing 1 changed file with 17 additions and 7 deletions.
24 changes: 17 additions & 7 deletions opm/grid/cpgrid/CpGrid.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -152,7 +152,6 @@ CpGrid::scatterGrid(EdgeWeightMethod method, const std::vector<cpgrid::OpmWellTy

if (cc.size() > 1)
{
int my_num=cc.rank();
#ifdef HAVE_ZOLTAN
auto part_and_wells =
cpgrid::zoltanGraphPartitionGridOnRoot(*this, wells, transmissibilities, cc, method, 0);
Expand Down Expand Up @@ -247,12 +246,23 @@ CpGrid::scatterGrid(EdgeWeightMethod method, const std::vector<cpgrid::OpmWellTy

distributed_data_->distributeGlobalGrid(*this,*this->current_view_data_, cell_part);
int num_cells = distributed_data_->cell_to_face_.size();
std::ostringstream message;
message << "After loadbalancing process " << my_num << " has " << num_cells << " cells.";
if (num_cells == 0) {
throw std::runtime_error(message.str() + " Aborting.");
} else {
std::cout << message.str() << "\n";

std::vector<int> cc_num_cells(cc.size(), 0);
cc_num_cells[cc.rank()] = num_cells;
cc.sum(cc_num_cells.data(),cc.size());

if (cc.rank() == 0) {
std::string str = "\nAfter loadbalancing on " + std::to_string(cc.size()) + " processes we have\nrank: num cells\n----------------\n";
for (int i = 0; i < cc.size(); ++i) {
str += std::to_string(i) + ": " + std::to_string(cc_num_cells[i]) + "\n";
}
str += "----------------\n";
Opm::OpmLog::info(str);
}
for (const auto& nc : cc_num_cells) {
if (nc == 0) {
throw std::runtime_error("At least one process has zero cells. Aborting.");
}
}

current_view_data_ = distributed_data_.get();
Expand Down

0 comments on commit f6cda38

Please sign in to comment.