Isorropia: Partitioning, Load Balancing and more
|
Interface (abstract base class) for computing a new 2D partitioning and describing the layout of elements in the new partitions. More...
#include <Isorropia_Partitioner2D.hpp>
Public Member Functions | |
virtual | ~Partitioner2D () |
Destructor. More... | |
virtual void | partition (bool force_repartitioning=false)=0 |
Method which does the work of computing a new partitioning. More... | |
virtual int | numElemsInPart (int part) const =0 |
Return the number of LOCAL elements in a given part. More... | |
virtual void | elemsInPart (int part, int *elementList, int len) const =0 |
Fill user-allocated list (of length len) with the local element ids to be located in the given part. More... | |
virtual int | extractPartsView (int &size, const int *&array) const |
Give access of the part assignments array that is owned by the current processor. More... | |
virtual int | extractPartsCopy (int len, int &size, int *array) const |
Copy a part of the part assignment array. More... | |
virtual void | setParameters (const Teuchos::ParameterList ¶mlist)=0 |
Set parameters for the Operator instance. More... | |
virtual void | compute (bool forceRecomputing=false)=0 |
Method which does the work of computing a new partitioning/coloring/ordering, depending on the child class used. More... | |
virtual bool | alreadyComputed () const =0 |
Query whether the computation has already been called. More... | |
virtual int | numProperties () const =0 |
Return the number of different values used for "properties". More... | |
virtual int | numLocalProperties () const =0 |
Return the number of different values used for "properties" for this process only. More... | |
virtual const int & | operator[] (int myElem) const =0 |
Return the "property" for a given element that resided locally. More... | |
virtual int | numElemsWithProperty (int property) const =0 |
Return the number of LOCAL elements with the given property. More... | |
virtual void | elemsWithProperty (int property, int *elementList, int len) const =0 |
Fill user-allocated list (of length len) with the local element ids of the LOCAL elements with the given property. More... | |
virtual int | extractPropertiesView (int &size, const int *&array) const =0 |
Give access of the property array that is owned by the current processor. More... | |
virtual int | extractPropertiesCopy (int len, int &size, int *array) const =0 |
Copy a part of the property array. More... | |
Interface (abstract base class) for computing a new 2D partitioning and describing the layout of elements in the new partitions.
If the methods which describe the new partitioning (e.g., newPartitionNumber(), etc.) are called before compute_partitioning() has been called, behavior is not well defined. Implementations will either return empty/erroneous data, or throw an exception. In most cases, implementations will probably call compute_partitioning() internally in a constructor or factory method, so this won't usually be an issue.
|
inlinevirtual |
Destructor.
Reimplemented in Isorropia::Epetra::Partitioner2D.
|
pure virtual |
Method which does the work of computing a new partitioning.
Implementations of this interface will typically be constructed with an object or information describing the existing ('old') partitioning. This method computes a 'new' rebalanced partitioning for that input data.
force_repartitioning | Optional argument defaults to false. Depending on the implementation, compute_partitioning() should only perform a repartitioning the first time it is called, and subsequent repeated calls are no-ops. If the user's intent is to re-compute the partitioning (e.g., if parameters or other inputs have been changed), then setting this flag to true will force a new partitioning to be computed. |
Implements Isorropia::Partitioner.
Implemented in Isorropia::Epetra::Partitioner2D.
|
pure virtual |
Return the number of LOCAL elements in a given part.
[in] | part | the part ID we want to know the number of local elements. |
Implements Isorropia::Partitioner.
Implemented in Isorropia::Epetra::Partitioner2D.
|
pure virtual |
Fill user-allocated list (of length len) with the local element ids to be located in the given part.
[in] | part | the part ID we consider |
[out] | elementList | array of elements that belongs to this part ID, must be allocated by user with size at least len |
[in] | len | maximum number of elements we can put in the array. Usually, may be the result of Isorropia::Partitioner::numElemsInPart(). . |
Implements Isorropia::Partitioner.
Implemented in Isorropia::Epetra::Partitioner2D.
|
inlinevirtualinherited |
Give access of the part assignments array that is owned by the current processor.
[out] | size | Number of elements in the array. |
[out] | array | Pointer to the the part assignements array inside the object. |
|
inlinevirtualinherited |
Copy a part of the part assignment array.
[in] | len | of the array given by the user. |
[out] | size | Number of elements in the array. |
[out] | array | Array of part assignments. Allocated by the user with a size of at least len elements. |
|
pure virtualinherited |
Set parameters for the Operator instance.
The contents of the input paramlist object are copied into an internal ParameterList attribute. Instances of this interface should not retain a reference to the input ParameterList after this method returns.
[in] | paramlist | List of parameters that the user wants to use. |
Implemented in Isorropia::Epetra::Operator.
|
pure virtualinherited |
Method which does the work of computing a new partitioning/coloring/ordering, depending on the child class used.
forceRecomputing | Optional argument defaults to false. Depending on the implementation, compute() should only perform a computation the first time it is called, and subsequent repeated calls are no-ops. If the user's intent is to re-compute the results (e.g., if parameters or other inputs have been changed), then setting this flag to true will force a new result to be computed. |
Implemented in Isorropia::Epetra::Operator, Isorropia::Epetra::Partitioner, Isorropia::Epetra::Colorer, Isorropia::Epetra::Partitioner2D, Isorropia::Epetra::Orderer, and Isorropia::Epetra::LevelScheduler.
|
pure virtualinherited |
Query whether the computation has already been called.
True
if the computation has already been done, False
otherwise. Implemented in Isorropia::Epetra::Operator.
|
pure virtualinherited |
Return the number of different values used for "properties".
For example, the number of colors or the number of parts used for the overall graph/matrix.
Implemented in Isorropia::Epetra::Operator.
|
pure virtualinherited |
Return the number of different values used for "properties" for this process only.
Implemented in Isorropia::Epetra::Operator.
|
pure virtualinherited |
Return the "property" for a given element that resided locally.
[in] | myElem | the local ID of the element we want to know the property. |
Implemented in Isorropia::Epetra::Operator.
|
pure virtualinherited |
Return the number of LOCAL elements with the given property.
[in] | property | Value of the property to consider. |
Implemented in Isorropia::Epetra::Operator.
|
pure virtualinherited |
Fill user-allocated list (of length len) with the local element ids of the LOCAL elements with the given property.
[in] | property | Value of the property to consider. |
[out] | elementList | User allocated array (of size at least len ) of local ID that have the asked property. |
[in] | len | Maximum lenght for the array. If len is greater than the result of numElemsWithProperty() for property , only the first and relevant elements are filled. |
Implemented in Isorropia::Epetra::Operator.
|
pure virtualinherited |
Give access of the property array that is owned by the current processor.
[out] | size | Number of elements in the array. |
[out] | array | Pointer to the the properties array inside the object. |
Implemented in Isorropia::Epetra::Operator.
|
pure virtualinherited |
Copy a part of the property array.
[in] | len | of the array given by the user. |
[out] | size | Number of elements in the array. |
[out] | array | Array of properties. Allocated by the user with a size of at least len elements. |
Implemented in Isorropia::Epetra::Operator.