Graphe d'héritage de Arcane::TBBTaskImplementation:
Graphe de collaboration de Arcane::TBBTaskImplementation:Classes | |
| class | Impl |
| class | MDParallelForExecute |
| class | ParallelForExecute |
| class | TaskInfoLockGuard |
| Classe pour positionner TaskThreadInfo::taskIndex(). Plus de détails... | |
| class | TaskThreadInfo |
Fonctions membres publiques | |
| void | build () |
| void | initialize (Int32 nb_thread) override |
| void | terminate () override |
| ITask * | createRootTask (ITaskFunctor *f) override |
| Créé une tâche racine. L'implémentation doit recopier la valeur de f qui est soit un TaskFunctor, soit un TaskFunctorWithContext. | |
| void | executeParallelFor (Int32 begin, Int32 size, const ParallelLoopOptions &options, IRangeFunctor *f) final |
| Exécute le fonctor f en concurrence. | |
| void | executeParallelFor (Int32 begin, Int32 size, Integer grain_size, IRangeFunctor *f) final |
| Exécute le fonctor f en concurrence. | |
| void | executeParallelFor (Int32 begin, Int32 size, IRangeFunctor *f) final |
| Exécute le fonctor f en concurrence. | |
| void | executeParallelFor (const ParallelFor1DLoopInfo &loop_info) override |
| Exécute la boucle loop_info en concurrence. | |
| void | executeParallelFor (const ComplexForLoopRanges< 1 > &loop_ranges, const ForLoopRunInfo &run_info, IMDRangeFunctor< 1 > *functor) final |
| Exécute une boucle 1D en concurrence. | |
| void | executeParallelFor (const ComplexForLoopRanges< 2 > &loop_ranges, const ForLoopRunInfo &run_info, IMDRangeFunctor< 2 > *functor) final |
| Exécute une boucle 2D en concurrence. | |
| void | executeParallelFor (const ComplexForLoopRanges< 3 > &loop_ranges, const ForLoopRunInfo &run_info, IMDRangeFunctor< 3 > *functor) final |
| Exécute une boucle 3D en concurrence. | |
| void | executeParallelFor (const ComplexForLoopRanges< 4 > &loop_ranges, const ForLoopRunInfo &run_info, IMDRangeFunctor< 4 > *functor) final |
| Exécute une boucle 4D en concurrence. | |
| bool | isActive () const final |
| Indique si l'implémentation est active. | |
| Int32 | nbAllowedThread () const final |
| Nombre de threads utilisés au maximum pour gérer les tâches. | |
| Int32 | currentTaskThreadIndex () const final |
| Implémentation de TaskFactory::currentTaskThreadIndex() | |
| Int32 | currentTaskIndex () const final |
| Implémentation de TaskFactory::currentTaskIndex() | |
| void | printInfos (std::ostream &o) const final |
| Affiche les informations sur le runtime utilisé | |
| TaskThreadInfo * | currentTaskThreadInfo () const |
| Instance de TaskThreadInfo associé au thread courant. | |
Fonctions membres privées | |
| template<int RankValue> | |
| void | _executeMDParallelFor (const ComplexForLoopRanges< RankValue > &loop_ranges, IMDRangeFunctor< RankValue > *functor, const ForLoopRunInfo &run_info) |
| Exécution d'une boucle N-dimensions. | |
| void | _executeParallelFor (const ParallelFor1DLoopInfo &loop_info) |
Attributs privés | |
| bool | m_is_active = false |
| Impl * | m_p = nullptr |
Définition à la ligne 415 du fichier TBBTaskImplementation.cc.
|
override |
Définition à la ligne 1095 du fichier TBBTaskImplementation.cc.
|
private |
Exécution d'une boucle N-dimensions.
Définition à la ligne 1219 du fichier TBBTaskImplementation.cc.
Références Arcane::TaskFactory::defaultParallelLoopOptions(), Arcane::ParallelLoopOptions::grainSize(), Arcane::makeLoopRanges(), Arcane::ParallelLoopOptions::maxThread(), Arcane::ParallelLoopOptions::mergeUnsetValues(), Arcane::CheckedConvert::toInteger(), et Arcane::TaskFactory::verboseLevel().
Référencé par executeParallelFor(), executeParallelFor(), executeParallelFor(), et executeParallelFor().
Voici le graphe d'appel pour cette fonction :
Voici le graphe des appelants de cette fonction :
|
private |
Définition à la ligne 1158 du fichier TBBTaskImplementation.cc.
|
inline |
Définition à la ligne 468 du fichier TBBTaskImplementation.cc.
|
inlineoverridevirtual |
Créé une tâche racine. L'implémentation doit recopier la valeur de f qui est soit un TaskFunctor, soit un TaskFunctorWithContext.
Implémente Arcane::ITaskImplementation.
Définition à la ligne 472 du fichier TBBTaskImplementation.cc.
|
finalvirtual |
Implémentation de TaskFactory::currentTaskIndex()
Implémente Arcane::ITaskImplementation.
Définition à la ligne 1317 du fichier TBBTaskImplementation.cc.
Références currentTaskThreadIndex(), et currentTaskThreadInfo().
Voici le graphe d'appel pour cette fonction :
|
inlinefinalvirtual |
Implémentation de TaskFactory::currentTaskThreadIndex()
Implémente Arcane::ITaskImplementation.
Définition à la ligne 522 du fichier TBBTaskImplementation.cc.
Références currentTaskThreadIndex(), et nbAllowedThread().
Référencé par currentTaskIndex(), currentTaskThreadIndex(), et currentTaskThreadInfo().
Voici le graphe d'appel pour cette fonction :
Voici le graphe des appelants de cette fonction :| TBBTaskImplementation::TaskThreadInfo * Arcane::TBBTaskImplementation::currentTaskThreadInfo | ( | ) | const |
Instance de TaskThreadInfo associé au thread courant.
Peut-être nul si le thread courant n'est pas associé à un thread TBB ou si en dehors d'une exécution d'une tâche ou d'une boucle parallèle.
Définition à la ligne 1305 du fichier TBBTaskImplementation.cc.
Références currentTaskThreadIndex().
Référencé par currentTaskIndex().
Voici le graphe d'appel pour cette fonction :
Voici le graphe des appelants de cette fonction :
|
inlinefinalvirtual |
Exécute une boucle 1D en concurrence.
Implémente Arcane::ITaskImplementation.
Définition à la ligne 490 du fichier TBBTaskImplementation.cc.
Références _executeMDParallelFor().
Voici le graphe d'appel pour cette fonction :
|
inlinefinalvirtual |
Exécute une boucle 2D en concurrence.
Implémente Arcane::ITaskImplementation.
Définition à la ligne 496 du fichier TBBTaskImplementation.cc.
Références _executeMDParallelFor().
Voici le graphe d'appel pour cette fonction :
|
inlinefinalvirtual |
Exécute une boucle 3D en concurrence.
Implémente Arcane::ITaskImplementation.
Définition à la ligne 502 du fichier TBBTaskImplementation.cc.
Références _executeMDParallelFor().
Voici le graphe d'appel pour cette fonction :
|
inlinefinalvirtual |
Exécute une boucle 4D en concurrence.
Implémente Arcane::ITaskImplementation.
Définition à la ligne 508 du fichier TBBTaskImplementation.cc.
Références _executeMDParallelFor().
Voici le graphe d'appel pour cette fonction :
|
overridevirtual |
Exécute la boucle loop_info en concurrence.
Implémente Arcane::ITaskImplementation.
Définition à la ligne 1205 du fichier TBBTaskImplementation.cc.
|
finalvirtual |
Exécute le fonctor f en concurrence.
Implémente Arcane::ITaskImplementation.
Définition à la ligne 1296 du fichier TBBTaskImplementation.cc.
Références executeParallelFor().
Référencé par executeParallelFor(), executeParallelFor(), et executeParallelFor().
Voici le graphe d'appel pour cette fonction :
Voici le graphe des appelants de cette fonction :
|
finalvirtual |
Exécute le fonctor f en concurrence.
Implémente Arcane::ITaskImplementation.
Définition à la ligne 1284 du fichier TBBTaskImplementation.cc.
Références Arcane::TaskFactory::defaultParallelLoopOptions(), executeParallelFor(), et Arcane::ParallelLoopOptions::setGrainSize().
Voici le graphe d'appel pour cette fonction :
|
inlinefinalvirtual |
Exécute le fonctor f en concurrence.
Implémente Arcane::ITaskImplementation.
Définition à la ligne 484 du fichier TBBTaskImplementation.cc.
Références Arcane::TaskFactory::defaultParallelLoopOptions(), et executeParallelFor().
Voici le graphe d'appel pour cette fonction :
|
overridevirtual |
. Initialise l'implémentation avec au maximum nb_thread. Si nb_thread vaut 0, l'implémentation peut choisir le nombre de thread automatiquement. Cette méthode est interne à Arcane et ne doit être appelée que lors de l'initialisation de l'exécution.
Implémente Arcane::ITaskImplementation.
Définition à la ligne 1104 du fichier TBBTaskImplementation.cc.
Références Arcane::TaskFactory::defaultParallelLoopOptions(), nbAllowedThread(), Arcane::TaskFactory::setDefaultParallelLoopOptions(), et Arcane::ParallelLoopOptions::setMaxThread().
Voici le graphe d'appel pour cette fonction :
|
inlinefinalvirtual |
Indique si l'implémentation est active.
Implémente Arcane::ITaskImplementation.
Définition à la ligne 515 du fichier TBBTaskImplementation.cc.
|
finalvirtual |
Nombre de threads utilisés au maximum pour gérer les tâches.
Implémente Arcane::ITaskImplementation.
Définition à la ligne 1131 du fichier TBBTaskImplementation.cc.
Référencé par currentTaskThreadIndex(), et initialize().
Voici le graphe des appelants de cette fonction :
|
finalvirtual |
Affiche les informations sur le runtime utilisé
Implémente Arcane::ITaskImplementation.
Définition à la ligne 1140 du fichier TBBTaskImplementation.cc.
|
overridevirtual |
. Termine l'utilisation de l'implémentation. Cette méthode doit être appelée en fin de calcul uniquement.
Implémente Arcane::ITaskImplementation.
Définition à la ligne 1122 du fichier TBBTaskImplementation.cc.
|
private |
Définition à la ligne 543 du fichier TBBTaskImplementation.cc.
|
private |
Définition à la ligne 544 du fichier TBBTaskImplementation.cc.