https://mooseframework.inl.gov
Functions
MultiApp.C File Reference

Go to the source code of this file.

Functions

LocalRankConfig rankConfig (processor_id_type rank, processor_id_type nprocs, dof_id_type napps, processor_id_type min_app_procs, processor_id_type max_app_procs, bool batch_mode)
 Returns app partitioning information relevant to the given rank for a multiapp scenario with the given number of apps (napps) and parallel/mpi procs (nprocs). More...
 
void dataStore (std::ostream &stream, SubAppBackups &backups, void *context)
 
void dataLoad (std::istream &stream, SubAppBackups &backups, void *context)
 

Function Documentation

◆ dataLoad()

void dataLoad ( std::istream &  stream,
SubAppBackups backups,
void context 
)

Definition at line 1535 of file MultiApp.C.

1536 {
1537  MultiApp * multi_app = static_cast<MultiApp *>(context);
1538  mooseAssert(multi_app, "Not set");
1539 
1540  dataLoad(stream, static_cast<std::vector<std::unique_ptr<Backup>> &>(backups), nullptr);
1541 
1542  multi_app->restore();
1543 }
virtual void restore(bool force=true)
Restore the state of every Sub App.
Definition: MultiApp.C:775
void dataLoad(std::istream &stream, SubAppBackups &backups, void *context)
Definition: MultiApp.C:1535
A MultiApp represents one or more MOOSE applications that are running simultaneously.
Definition: MultiApp.h:112

◆ dataStore()

void dataStore ( std::ostream &  stream,
SubAppBackups backups,
void context 
)

Definition at line 1524 of file MultiApp.C.

1525 {
1526  MultiApp * multi_app = static_cast<MultiApp *>(context);
1527  mooseAssert(multi_app, "Not set");
1528 
1529  multi_app->backup();
1530 
1531  dataStore(stream, static_cast<std::vector<std::unique_ptr<Backup>> &>(backups), nullptr);
1532 }
virtual void backup()
Save off the state of every Sub App.
Definition: MultiApp.C:760
void dataStore(std::ostream &stream, SubAppBackups &backups, void *context)
Definition: MultiApp.C:1524
A MultiApp represents one or more MOOSE applications that are running simultaneously.
Definition: MultiApp.h:112

◆ rankConfig()

LocalRankConfig rankConfig ( processor_id_type  rank,
processor_id_type  nprocs,
dof_id_type  napps,
processor_id_type  min_app_procs,
processor_id_type  max_app_procs,
bool  batch_mode = false 
)

Returns app partitioning information relevant to the given rank for a multiapp scenario with the given number of apps (napps) and parallel/mpi procs (nprocs).

min_app_procs and max_app_procs define the min and max number of procs that must/can be used in parallel to run a given (sub)app. batch_mode affects whether 1 subapp is assigned per rank to be re-used to run each of the (napps) simulations or whether 1 subapp is created for each napps simulation (globally).

Each proc calls this function in order to determine which (sub)apps among the global list of all subapps for a multiapp should be run by the given rank.

Definition at line 1331 of file MultiApp.C.

Referenced by Sampler::constructRankConfig(), and MultiApp::init().

1337 {
1338  if (min_app_procs > nprocs)
1339  mooseError("minimum number of procs per app is higher than the available number of procs");
1340  else if (min_app_procs > max_app_procs)
1341  mooseError("minimum number of procs per app must be lower than the max procs per app");
1342 
1343  mooseAssert(rank < nprocs, "rank must be smaller than the number of procs");
1344 
1345  // A "slot" is a group of procs/ranks that are grouped together to run a
1346  // single (sub)app/sim in parallel.
1347 
1348  const processor_id_type slot_size =
1349  std::max(std::min(cast_int<processor_id_type>(nprocs / napps), max_app_procs), min_app_procs);
1350  const processor_id_type nslots = std::min(
1351  nprocs / slot_size,
1352  cast_int<processor_id_type>(std::min(
1353  static_cast<dof_id_type>(std::numeric_limits<processor_id_type>::max()), napps)));
1354  mooseAssert(nprocs >= (nslots * slot_size),
1355  "Ensure that leftover procs is represented by an unsigned type");
1356  const processor_id_type leftover_procs = nprocs - nslots * slot_size;
1357  const dof_id_type apps_per_slot = napps / nslots;
1358  const dof_id_type leftover_apps = napps % nslots;
1359 
1360  std::vector<int> slot_for_rank(nprocs);
1361  processor_id_type slot = 0;
1362  processor_id_type procs_in_slot = 0;
1363  for (processor_id_type rankiter = 0; rankiter <= rank; rankiter++)
1364  {
1365  if (slot < nslots)
1366  slot_for_rank[rankiter] = cast_int<int>(slot);
1367  else
1368  slot_for_rank[rankiter] = -1;
1369  procs_in_slot++;
1370  // this slot keeps growing until we reach slot size plus possibly an extra
1371  // proc if there were any leftover from the slotization of nprocs - this
1372  // must also make sure we don't go over max app procs.
1373  if (procs_in_slot == slot_size + 1 * (slot < leftover_procs && slot_size < max_app_procs))
1374  {
1375  procs_in_slot = 0;
1376  slot++;
1377  }
1378  }
1379 
1380  if (slot_for_rank[rank] < 0)
1381  // ranks assigned a negative slot don't have any apps running on them.
1382  return {0, 0, 0, 0, false, 0};
1383  const processor_id_type slot_num = cast_int<processor_id_type>(slot_for_rank[rank]);
1384 
1385  const bool is_first_local_rank = rank == 0 || (slot_for_rank[rank - 1] != slot_for_rank[rank]);
1386  const dof_id_type n_local_apps = apps_per_slot + 1 * (slot_num < leftover_apps);
1387 
1388  processor_id_type my_first_rank = 0;
1389  for (processor_id_type rankiter = rank; rankiter > 0; rankiter--)
1390  if (slot_for_rank[rank] != slot_for_rank[rankiter])
1391  {
1392  my_first_rank = cast_int<processor_id_type>(slot_for_rank[rankiter + 1]);
1393  break;
1394  }
1395 
1396  dof_id_type app_index = 0;
1397  for (processor_id_type slot = 0; slot < slot_num; slot++)
1398  {
1399  const dof_id_type num_slot_apps = apps_per_slot + 1 * (slot < leftover_apps);
1400  app_index += num_slot_apps;
1401  }
1402 
1403  if (batch_mode)
1404  return {n_local_apps, app_index, 1, slot_num, is_first_local_rank, my_first_rank};
1405  return {n_local_apps, app_index, n_local_apps, app_index, is_first_local_rank, my_first_rank};
1406 }
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:302
auto max(const L &left, const R &right)
uint8_t processor_id_type
auto min(const L &left, const R &right)
uint8_t dof_id_type