SST  7.1.0
StructuralSimulationToolkit
linpart.h
1 // Copyright 2009-2017 Sandia Corporation. Under the terms
2 // of Contract DE-NA0003525 with Sandia Corporation, the U.S.
3 // Government retains certain rights in this software.
4 //
5 // Copyright (c) 2009-2017, Sandia Corporation
6 // All rights reserved.
7 //
8 // This file is part of the SST software package. For license
9 // information, see the LICENSE file in the top level directory of the
10 // distribution.
11 
12 
13 #ifndef SST_CORE_PART_LINEAR
14 #define SST_CORE_PART_LINEAR
15 
16 #include <sst/core/part/sstpart.h>
17 #include <sst/core/elementinfo.h>
18 
19 using namespace SST;
20 using namespace SST::Partition;
21 
22 namespace SST {
23 
24 class Output;
25 
26 namespace Partition {
27 
28 
29 
30 /**
31 Performs a linear partition scheme of an SST simulation configuration. In this
32 scheme a list of components (supplied as a graph) are grouped by slicing the list
33 into approximately equal parts. A "part" is generated for each MPI rank performing
34 the simulation. This means Components with sequential ids will be placed close together.
35 In general this scheme provides a very effective partition for most parallel
36 simulations which generate man similar components of interest close together in the input
37 Python configuration. It is also very fast to compute a linear partiton scheme. For
38 more aggressive partition schemes users should try either a simple or Zoltan-based
39 partitioner.
40 */
42 
43 public:
44  SST_ELI_REGISTER_PARTITIONER(
46  "sst",
47  "linear",
48  SST_ELI_ELEMENT_VERSION(1,0,0),
49  "Partitions components by dividing Component ID space into roughly equal portions. Components with sequential IDs will be placed close together.")
50 
51 protected:
52  /** Number of ranks in the simulation */
53  RankInfo rankcount;
54  /** Output object to print partitioning information */
55  Output* partOutput;
56 
57 public:
58  /**
59  Creates a new linear partition scheme.
60  \param mpiRankCount Number of MPI ranks in the simulation
61  \param verbosity The level of information to output
62  */
63  SSTLinearPartition(RankInfo rankCount, RankInfo my_rank, int verbosity);
64 
65  /**
66  Performs a partition of an SST simulation configuration
67  \param graph The simulation configuration to partition
68  */
69  void performPartition(PartitionGraph* graph) override;
70 
71  bool requiresConfigGraph() override { return false; }
72  bool spawnOnAllRanks() override { return false; }
73 
74  // static SSTPartitioner* allocate(RankInfo total_ranks, RankInfo my_rank, int verbosity) {
75  // return new SSTLinearPartition(total_ranks, my_rank, verbosity);
76  // }
77 
78 };
79 
80 }
81 }
82 
83 #endif
Output object provides consistant method for outputing data to stdout, stderr and/or sst debug file...
Definition: output.h:54
Definition: configGraph.h:530
Definition: element.h:31
Definition: action.cc:17
Performs a linear partition scheme of an SST simulation configuration.
Definition: linpart.h:41
Definition: rankInfo.h:21
Base class for Partitioning graphs.
Definition: sstpart.h:31