Mesh repartitioning test class. More...
Public Member Functions | |
| MeshPartitionerTester (const ServiceBuildInfo &sbi) | |
| IMesh * | mesh () const override |
| Mesh associated with the partitioner. | |
| void | build () override |
| Build-level construction of the service. | |
| void | partitionMesh (bool initial_partition) override |
| void | partitionMesh (bool initial_partition, Int32 nb_part) override |
| void | notifyEndPartition () override |
| Notification when a re-partitioning finishes (after entity exchange). | |
| void | setMaximumComputationTime (Real v) override |
| Sets the proportion of computation time. | |
| Real | maximumComputationTime () const override |
| void | setComputationTimes (RealConstArrayView v) override |
| Computation time of this subdomain. The first element indicates the computation time of the subdomain corresponding to calculations whose cost is proportional to the cells. The following must be associated with a variable (to be done). | |
| RealConstArrayView | computationTimes () const override |
| void | setImbalance (Real v) override |
| Sets the computation time imbalance. | |
| Real | imbalance () const override |
| Computation time imbalance. | |
| void | setMaxImbalance (Real v) override |
| Sets the maximum allowed imbalance. | |
| Real | maxImbalance () const override |
| Maximum allowed imbalance. | |
| ArrayView< float > | cellsWeight () const override |
| void | setCellsWeight (ArrayView< float > weights, Integer nb_weight) override |
| Allows defining the weights of objects to be partitioned: ILoadBalanceMng must now be used. | |
| void | setILoadBalanceMng (ILoadBalanceMng *) override |
| Changes the ILoadBalanceMng to use. | |
| ILoadBalanceMng * | loadBalanceMng () const override |
| Public Member Functions inherited from Arcane::ArcaneMeshPartitionerTesterServiceObject | |
| ArcaneMeshPartitionerTesterServiceObject (const Arcane::ServiceBuildInfo &sbi) | |
| Constructeur. | |
| virtual | ~ArcaneMeshPartitionerTesterServiceObject () |
| Destructeur. | |
| CaseOptionsMeshPartitionerTesterService * | options () const |
| Options du jeu de données du service. | |
| Public Member Functions inherited from Arcane::BasicService | |
| ~BasicService () override | |
| Releases resources. | |
| virtual ISubDomain * | subDomain () |
| Public Member Functions inherited from Arcane::AbstractService | |
| ~AbstractService () override | |
| Destructor. | |
| IServiceInfo * | serviceInfo () const override |
| Access to service information. See IServiceInfo for details. | |
| IBase * | serviceParent () const override |
| Access to the base interface of main Arcane objects. | |
| IService * | serviceInterface () override |
| Returns the low-level IService interface of the service. | |
| Public Member Functions inherited from Arcane::TraceAccessor | |
| TraceAccessor (ITraceMng *m) | |
| Constructs an accessor via the trace manager m. | |
| TraceAccessor (const TraceAccessor &rhs) | |
| Copy constructor. | |
| TraceAccessor & | operator= (const TraceAccessor &rhs) |
| Copy assignment operator. | |
| virtual | ~TraceAccessor () |
| Frees resources. | |
| ITraceMng * | traceMng () const |
| Trace manager. | |
| TraceMessage | info () const |
| Flow for an information message. | |
| TraceMessage | pinfo () const |
| Flow for a parallel information message. | |
| TraceMessage | info (char category) const |
| Flow for an information message of a given category. | |
| TraceMessage | pinfo (char category) const |
| Flow for a parallel information message of a given category. | |
| TraceMessage | info (bool v) const |
| Flow for an information message. | |
| TraceMessage | warning () const |
| Flow for a warning message. | |
| TraceMessage | pwarning () const |
| TraceMessage | error () const |
| Flow for an error message. | |
| TraceMessage | perror () const |
| TraceMessage | log () const |
| Flow for a log message. | |
| TraceMessage | plog () const |
| Flow for a log message. | |
| TraceMessage | logdate () const |
| Flow for a log message preceded by the date. | |
| TraceMessage | fatal () const |
| Flow for a fatal error message. | |
| TraceMessage | pfatal () const |
| Flow for a parallel fatal error message. | |
| TraceMessageDbg | debug (Trace::eDebugLevel=Trace::Medium) const |
| Flow for a debug message. | |
| Trace::eDebugLevel | configDbgLevel () const |
| Debug level of the configuration file. | |
| TraceMessage | info (Int32 verbose_level) const |
| Flow for an information message of a given level. | |
| TraceMessage | linfo () const |
| Flow for an information message with the local information level of this instance. | |
| TraceMessage | linfo (Int32 relative_level) const |
| Flow for an information message with the local information level of this instance. | |
| void | fatalMessage (const StandaloneTraceMessage &o) const |
| Public Member Functions inherited from Arcane::IService | |
| virtual | ~IService () |
| Releases resources. | |
| Public Member Functions inherited from Arcane::MeshAccessor | |
| MeshAccessor (ISubDomain *sd) | |
| MeshAccessor (IMesh *mesh) | |
| MeshAccessor (const MeshHandle &mesh_handle) | |
| Integer | nbCell () const |
| Returns the number of cells in the mesh. | |
| Integer | nbFace () const |
| Returns the number of faces in the mesh. | |
| Integer | nbEdge () const |
| Returns the number of edges in the mesh. | |
| Integer | nbNode () const |
| Returns the number of nodes in the mesh. | |
| VariableNodeReal3 & | nodesCoordinates () const |
| Returns the coordinates of the mesh nodes. | |
| NodeGroup | allNodes () const |
| Returns the group containing all nodes. | |
| EdgeGroup | allEdges () const |
| Returns the group containing all edges. | |
| FaceGroup | allFaces () const |
| Returns the group containing all faces. | |
| CellGroup | allCells () const |
| Returns the group containing all cells. | |
| FaceGroup | outerFaces () const |
| Returns the group containing all boundary faces. | |
| NodeGroup | ownNodes () const |
| Returns the group containing all nodes specific to this domain. | |
| CellGroup | ownCells () const |
| Returns the group containing all cells specific to this domain. | |
| FaceGroup | ownFaces () const |
| Group containing all faces specific to this domain. | |
| EdgeGroup | ownEdges () const |
| Group containing all edges specific to this domain. | |
| IMesh * | mesh () const |
| const MeshHandle & | meshHandle () const |
| Public Member Functions inherited from Arcane::CommonVariables | |
| CommonVariables (IModule *c) | |
| Constructs the references of the common variables for the module c. | |
| CommonVariables (IVariableMng *variable_mng) | |
| Constructs the references of the common variables for the manager variable_mng. | |
| CommonVariables (ISubDomain *sd) | |
| Constructs the references of the common variables for the subdomain sd. | |
| virtual | ~CommonVariables () |
| Releases resources. | |
| Int32 | globalIteration () const |
| Current iteration number. | |
| Real | globalTime () const |
| Current time. | |
| Real | globalOldTime () const |
| Previous current time. | |
| Real | globalFinalTime () const |
| Final time of the simulation. | |
| Real | globalDeltaT () const |
| Current Delta T. | |
| Real | globalCPUTime () const |
| CPU time used (in seconds). | |
| Real | globalOldCPUTime () const |
| Previous CPU time used (in seconds). | |
| Real | globalElapsedTime () const |
| Clock time (elapsed) used (in seconds). | |
| Real | globalOldElapsedTime () const |
| Previous clock time (elapsed) used (in seconds). | |
| Public Member Functions inherited from Arcane::IMeshPartitioner | |
| virtual IPrimaryMesh * | primaryMesh () override |
| Associated mesh. | |
| Public Member Functions inherited from Arcane::IMeshPartitionerBase | |
| virtual | ~IMeshPartitionerBase ()=default |
| Releases resources. | |
Private Attributes | |
| Real | m_imbalance |
| Real | m_max_imbalance |
| Real | m_max_computation_time |
| Integer | m_nb_weight |
| ArrayView< float > | m_cells_weight |
| RealUniqueArray | m_computation_times |
Additional Inherited Members | |
| Static Public Member Functions inherited from Arcane::ArcaneMeshPartitionerTesterServiceObject | |
| template<typename ServiceClassType> | |
| static void | fillServiceInfo (Arcane::ServiceInfo *si) |
| Public Attributes inherited from Arcane::CommonVariables | |
| VariableScalarInt32 | m_global_iteration |
| Current iteration. | |
| VariableScalarReal | m_global_time |
| Current time. | |
| VariableScalarReal | m_global_deltat |
| Global Delta T. | |
| VariableScalarReal | m_global_old_time |
| Time previous to the current time. | |
| VariableScalarReal | m_global_old_deltat |
| Delta T at the time previous to the global time. | |
| VariableScalarReal | m_global_final_time |
| Final time of the case. | |
| VariableScalarReal | m_global_old_cpu_time |
| Previous CPU time used (in seconds). | |
| VariableScalarReal | m_global_cpu_time |
| CPU time used (in seconds). | |
| VariableScalarReal | m_global_old_elapsed_time |
| Previous clock time used (in seconds). | |
| VariableScalarReal | m_global_elapsed_time |
| Clock time used (in seconds). | |
| Protected Member Functions inherited from Arcane::BasicService | |
| BasicService (const ServiceBuildInfo &) | |
| Protected Member Functions inherited from Arcane::AbstractService | |
| AbstractService (const ServiceBuildInfo &) | |
| Constructor from a ServiceBuildInfo. | |
| Protected Member Functions inherited from Arcane::TraceAccessor | |
| void | _setLocalVerboseLevel (Int32 v) |
| Int32 | _localVerboseLevel () const |
| Protected Member Functions inherited from Arcane::IService | |
| IService () | |
| Constructor. | |
Mesh repartitioning test class.
This class is used only to test mesh repartitioning. It simply changes the owner of the cells based on the numbering and without taking into account potential imbalances during computation time.
Definition at line 54 of file MeshPartitionerTesterService.cc.
| Arcane::MeshPartitionerTester::MeshPartitionerTester | ( | const ServiceBuildInfo & | sbi | ) |
Definition at line 120 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Build-level construction of the service.
This method is called right after the constructor.
Reimplemented from Arcane::AbstractService.
Definition at line 67 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Implements Arcane::IMeshPartitioner.
Definition at line 89 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Implements Arcane::IMeshPartitioner.
Definition at line 83 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Computation time imbalance.
Implements Arcane::IMeshPartitioner.
Definition at line 85 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Implements Arcane::IMeshPartitioner.
Definition at line 102 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Maximum allowed imbalance.
Implements Arcane::IMeshPartitioner.
Definition at line 87 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Implements Arcane::IMeshPartitioner.
Definition at line 81 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Mesh associated with the partitioner.
Implements Arcane::IMeshPartitioner.
Definition at line 65 of file MeshPartitionerTesterService.cc.
Referenced by partitionMesh().
|
inlineoverridevirtual |
Notification when a re-partitioning finishes (after entity exchange).
Implements Arcane::IMeshPartitionerBase.
Definition at line 76 of file MeshPartitionerTesterService.cc.
|
overridevirtual |
Re-partitions the mesh mesh
This method changes the owners of the entities and fills the IItemFamily::itemsNewOwner() variable of each entity family of the mesh mesh with the number of the new owning subdomain.
Reimplemented from Arcane::IMeshPartitioner.
Definition at line 133 of file MeshPartitionerTesterService.cc.
References Arcane::ISubDomain::commonVariables(), Arcane::IParallelMng::commRank(), Arcane::IParallelMng::commSize(), ENUMERATE_CELL, Arcane::CommonVariables::globalIteration(), Arcane::IK_Cell, Arcane::TraceAccessor::info(), mesh(), Arcane::ArcaneMeshPartitionerTesterServiceObject::options(), Arcane::Item::owner(), Arcane::ISubDomain::parallelMng(), Arcane::IMesh::toPrimaryMesh(), and Arcane::TraceAccessor::warning().
|
inlineoverridevirtual |
Implements Arcane::IMeshPartitioner.
Definition at line 69 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Allows defining the weights of objects to be partitioned: ILoadBalanceMng must now be used.
Implements Arcane::IMeshPartitioner.
Definition at line 91 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Computation time of this subdomain. The first element indicates the computation time of the subdomain corresponding to calculations whose cost is proportional to the cells. The following must be associated with a variable (to be done).
Implements Arcane::IMeshPartitioner.
Definition at line 82 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Changes the ILoadBalanceMng to use.
Implements Arcane::IMeshPartitioner.
Definition at line 97 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Sets the computation time imbalance.
Implements Arcane::IMeshPartitioner.
Definition at line 84 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Sets the maximum allowed imbalance.
Implements Arcane::IMeshPartitioner.
Definition at line 86 of file MeshPartitionerTesterService.cc.
|
inlineoverridevirtual |
Sets the proportion of computation time.
Proportion of computation time Computation time of the most heavily loaded subdomain
Implements Arcane::IMeshPartitioner.
Definition at line 80 of file MeshPartitionerTesterService.cc.
|
private |
Definition at line 113 of file MeshPartitionerTesterService.cc.
|
private |
Definition at line 114 of file MeshPartitionerTesterService.cc.
|
private |
Definition at line 109 of file MeshPartitionerTesterService.cc.
|
private |
Definition at line 111 of file MeshPartitionerTesterService.cc.
|
private |
Definition at line 110 of file MeshPartitionerTesterService.cc.
|
private |
Definition at line 112 of file MeshPartitionerTesterService.cc.