class
PhaseA class representing a phase of objects distributed across ranks.
Methods
- def _Phase__update_or_create_directed_edge(self, from_id: int, to_id: int, v: float)
- Convenience method to update or create directed edge with given volume.
- def compute_edges(self)
- Compute and return dict of communication edge IDs to volumes.
- def copy_ranks(self, phase: typing.Self)
- Copy ranks from one phase to self.
- def get_communications(self)
- Return the phase communications dict.
- def get_edge_maxima(self)
- Reduce directed edges into undirected with maximum.
- def get_edges(self)
- Retrieve communication edges of phase.
- def get_id(self)
- Retrieve index of this phase.
- def get_largest_volumes(self)
- Return largest directed volumes from undirected ones.
- def get_lb_iterations(self)
- Return list of load balancing iterations.
- def get_number_of_objects(self)
- Return number of objects.
- def get_number_of_ranks(self)
- Retrieve number of ranks belonging to phase.
- def get_object_ids(self)
- Return IDs of all objects belonging to phase.
- def get_objects(self)
- Return all objects belonging to phase.
- def get_objects_dict(self)
- Return all objects as dictionaries with `from` and `to` values retrieved from the object communicator.
- def get_rank_ids(self)
- Retrieve IDs of ranks belonging to phase.
- def get_ranks(self)
- Retrieve ranks belonging to phase.
- def get_sub_id(self)
- Retrieve sub-index of this phase.
- def populate_from_log(self, phase_id)
- Populate this phase by reading in a load profile from log files.
- def populate_from_samplers(self, n_ranks, n_objects, t_sampler, v_sampler, c_degree, n_r_mapped = 0)
- Use samplers to populate either all or n ranks in a phase.
- def populate_from_specification(self, spec: Execution.lbsPhaseSpecification.PhaseSpecification, multiple_sharing: bool = False)
- Populate this phase using a specification listing phases, ranks, tasks and communications.
- def set_communications(self, communications: dict)
- Set the phase communications dict.
- def set_id(self, p_id: int)
- Set index of this phase.
- def set_lb_iterations(self, lb_iterations: typing.List[typing.Self])
- Set possibly empty list of load balancing iterations.
- def set_ranks(self, ranks: typing.Set[lbsRank.Rank])
- Set list of ranks for this phase.
- def transfer_object(self, r_src: lbsRank.Rank, o: lbsObject.Object, r_dst: lbsRank.Rank)
- Transfer object from source to destination rank.
- def transfer_objects(self, r_src: lbsRank.Rank, o_src: list, r_dst: lbsRank.Rank, o_dst: typing.Optional[list] = None)
- Transfer list of objects between source and destination ranks.
- def update_edges(self, o: lbsObject.Object, r_src: lbsRank.Rank, r_dst: lbsRank.Rank)
- Update inter-rank communication edges before object transfer.
Special methods
- def __init__(self, lgr: logging.Logger, p_id: int = 0, reader: IO.lbsVTDataReader.LoadReader = None, p_sub_id: int = 0)
- Class constructor logger: a Logger instance p_id: an integer indexing the phase ID reader: a JSON VT reader instance p_sub_id: an optional integer to index e.g. LB iterations