Loading [MathJax]/extensions/tex2jax.js
The Gaudi Framework  master (f5098d57)
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
PrecedenceRulesGraph.h
Go to the documentation of this file.
1 /***********************************************************************************\
2 * (c) Copyright 1998-2025 CERN for the benefit of the LHCb and ATLAS collaborations *
3 * *
4 * This software is distributed under the terms of the Apache version 2 licence, *
5 * copied verbatim in the file "LICENSE". *
6 * *
7 * In applying this licence, CERN does not waive the privileges and immunities *
8 * granted to it by virtue of its status as an Intergovernmental Organization *
9 * or submit itself to any jurisdiction. *
10 \***********************************************************************************/
11 #ifndef GAUDIHIVE_PRECEDENCERULESGRAPH_H
12 #define GAUDIHIVE_PRECEDENCERULESGRAPH_H
13 
14 // std includes
15 #include <algorithm>
16 #include <memory>
17 #include <sstream>
18 #include <unordered_map>
19 #include <variant>
20 #include <vector>
21 
22 #include <boost/filesystem.hpp>
23 #include <boost/graph/adjacency_list.hpp>
24 #include <boost/graph/graphml.hpp>
25 
26 // fwk includes
27 #include "../AlgsExecutionStates.h"
28 #include "../EventSlot.h"
29 #include "Visitors/IGraphVisitor.h"
30 #include <Gaudi/Algorithm.h>
32 #include <GaudiKernel/DataObject.h>
33 #include <GaudiKernel/ICondSvc.h>
36 #include <GaudiKernel/TaggedBool.h>
38 
39 namespace concurrency {
45 } // namespace concurrency
46 
47 namespace precedence {
48 
49  // Precedence trace utilities ==============================================
50  struct AlgoTraceProps {
52  AlgoTraceProps( const std::string& name, int index = -1, int rank = -1, long int runtime = -1,
53  long long int start = -1 )
54  : m_name( name ), m_index( index ), m_rank( rank ), m_runtime( runtime ), m_start( start ) {}
55  std::string m_name;
56  int m_index{ -1 };
57  int m_rank{ -1 };
58  long int m_runtime{ -1 }; // us
59  long long int m_start{ -1 }; // ns
60  int m_eccentricity{ -1 };
61  };
62 
63  using PrecTrace = boost::adjacency_list<boost::vecS, boost::vecS, boost::bidirectionalS, AlgoTraceProps>;
64  using AlgoTraceVertex = boost::graph_traits<PrecTrace>::vertex_descriptor;
65 
66  // Precedence rules utilities ==============================================
67  struct AlgoProps {
68  AlgoProps() {}
69  AlgoProps( Gaudi::Algorithm* algo, uint nodeIndex, uint algoIndex )
70  : m_name( algo->name() )
71  , m_nodeIndex( nodeIndex )
72  , m_algoIndex( algoIndex )
73  , m_algorithm( algo )
74  , m_isAsynchronous( algo->isAsynchronous() ) {}
75 
76  std::string m_name{ "" };
77  int m_nodeIndex{ -1 };
78  int m_algoIndex{ -1 };
79  int m_rank{ -1 };
83  bool m_isAsynchronous{ false };
84  };
85 
87  DecisionHubProps( const std::string& name, uint nodeIndex, concurrency::Concurrent modeConcurrent,
88  concurrency::PromptDecision modePromptDecision, concurrency::ModeOr modeOR,
89  concurrency::AllPass allPass, concurrency::Inverted isInverted )
90  : m_name( name )
91  , m_nodeIndex( nodeIndex )
92  , m_modeConcurrent( modeConcurrent )
93  , m_modePromptDecision( modePromptDecision )
94  , m_inverted( isInverted )
95  , m_modeOR( modeOR )
96  , m_allPass( allPass ) {}
97 
98  std::string m_name;
100 
107  bool m_inverted{ false };
109  bool m_modeOR;
111  bool m_allPass;
112  };
113 
114  struct DataProps {
115  DataProps( const DataObjID& id ) : m_id( id ) {}
116 
118  };
119 
121  CondDataProps( const DataObjID& id ) : DataProps( id ) {}
122  };
123 
124  // Vertex unpacking ========================================================
125 
126  struct VertexName {
127  std::string operator()( const AlgoProps& props ) const { return props.m_name; }
128 
129  std::string operator()( const DecisionHubProps& props ) const { return props.m_name; }
130 
131  std::string operator()( const DataProps& props ) const { return props.m_id.fullKey(); }
132  };
133 
134  struct GroupMode {
135  std::string operator()( const AlgoProps& ) const { return ""; }
136 
137  std::string operator()( const DecisionHubProps& props ) const {
138  return props.m_modeConcurrent ? "Concurrent" : "Sequential";
139  }
140 
141  std::string operator()( const DataProps& ) const { return ""; }
142  };
143 
144  struct GroupLogic {
145  std::string operator()( const AlgoProps& ) const { return ""; }
146 
147  std::string operator()( const DecisionHubProps& props ) const { return props.m_modeOR ? "OR" : "AND"; }
148 
149  std::string operator()( const DataProps& ) const { return ""; }
150  };
151 
152  struct GroupExit {
153  std::string operator()( const AlgoProps& ) const { return ""; }
154 
155  std::string operator()( const DecisionHubProps& props ) const {
156  return props.m_modePromptDecision ? "Early" : "Late";
157  }
158 
159  std::string operator()( const DataProps& ) const { return ""; }
160  };
161 
163  std::string operator()( const AlgoProps& ) const { return ""; }
164 
165  std::string operator()( const DecisionHubProps& props ) const {
166  return props.m_inverted ? "Inverted" : "Non-inverted";
167  }
168 
169  std::string operator()( const DataProps& ) const { return ""; }
170  };
171 
172  struct AllPass {
173  std::string operator()( const AlgoProps& ) const { return ""; }
174 
175  std::string operator()( const DecisionHubProps& props ) const { return props.m_allPass ? "Optimist" : "Realist"; }
176 
177  std::string operator()( const DataProps& ) const { return ""; }
178  };
179 
180  struct CFDecision {
181  CFDecision( const EventSlot& slot ) : m_slot( slot ) {}
182 
183  std::string operator()( const AlgoProps& props ) const {
184  return std::to_string( m_slot.controlFlowState.at( props.m_nodeIndex ) );
185  }
186 
187  std::string operator()( const DecisionHubProps& props ) const {
188  return std::to_string( m_slot.controlFlowState.at( props.m_nodeIndex ) );
189  }
190 
191  std::string operator()( const DataProps& ) const { return ""; }
192 
194  };
195 
196  struct EntityState {
197  EntityState( const EventSlot& slot, SmartIF<ISvcLocator>& svcLocator, bool conditionsEnabled )
198  : m_slot( slot )
199  , m_whiteboard( svcLocator->service<IHiveWhiteBoard>( "EventDataSvc", false ) )
200  , m_conditionsEnabled( conditionsEnabled ) {
202  MsgStream log{ msgSvc, "EntityState.Getter" };
203 
204  // Figure if we can discover the data object states
205  if ( !m_whiteboard.isValid() ) {
206  log << MSG::WARNING << "Failed to locate EventDataSvc: no way to add DO "
207  << "states to the TTT dump " << endmsg;
208  }
209 
210  if ( m_conditionsEnabled ) {
211  // Figure if we can discover Condition data object states
212  m_condSvc = svcLocator->service<ICondSvc>( "CondSvc", false );
213  if ( !m_condSvc.isValid() )
214  log << MSG::WARNING << "Failed to locate CondSvc: no way to add Condition DO "
215  << "states to the TTT dump " << endmsg;
216  }
217 
218  if ( !m_slot.eventContext->valid() )
219  log << MSG::WARNING << "Event context is invalid: no way to add DO states"
220  << " in the TTT dump" << endmsg;
221  }
222 
223  // Returns algorithm's FSM state
224  std::string operator()( const AlgoProps& props ) const {
225  std::ostringstream oss;
226  oss << m_slot.algsStates[props.m_algoIndex];
227  return oss.str();
228  }
229 
230  std::string operator()( const DecisionHubProps& ) const { return ""; }
231 
232  std::string operator()( const DataProps& props ) const {
233  std::string state;
234 
235  if ( m_whiteboard.isValid() && m_slot.eventContext->valid() )
236  if ( m_whiteboard->selectStore( m_slot.eventContext->slot() ).isSuccess() )
237  state = m_whiteboard->exists( props.m_id ) ? "Produced" : "Missing";
238 
239  return state;
240  }
241 
242  std::string operator()( const CondDataProps& props ) const {
243  std::string state;
244 
245  if ( m_condSvc.isValid() && m_slot.eventContext->valid() )
246  state = m_condSvc->isValidID( *( m_slot.eventContext ), props.m_id ) ? "Produced" : "Missing";
247 
248  return state;
249  }
250 
252 
255  bool m_conditionsEnabled{ false };
256  };
257 
258  struct StartTime {
260  : m_slot( slot ), m_timelineSvc( svcLocator->service<ITimelineSvc>( "TimelineSvc", false ) ) {
262  MsgStream log{ msgSvc, "StartTime.Getter" };
263 
264  // Figure if we can discover the algorithm timings
265  if ( !m_timelineSvc.isValid() ) {
266  log << MSG::WARNING << "Failed to locate the TimelineSvc: no way to "
267  << "add algorithm start time to the TTT dumps" << endmsg;
268  }
269  }
270 
271  std::string operator()( const AlgoProps& props ) const {
272 
273  std::string startTime;
274 
275  if ( m_timelineSvc.isValid() ) {
276 
277  TimelineEvent te{};
278  te.algorithm = props.m_name;
279  te.slot = m_slot.eventContext->slot();
280  te.event = m_slot.eventContext->evt();
281 
282  m_timelineSvc->getTimelineEvent( te );
283  startTime = std::to_string(
284  std::chrono::duration_cast<std::chrono::nanoseconds>( te.start.time_since_epoch() ).count() );
285  }
286 
287  return startTime;
288  }
289 
290  std::string operator()( const DecisionHubProps& ) const { return ""; }
291 
292  std::string operator()( const DataProps& ) const { return ""; }
293 
296  };
297 
298  struct EndTime {
300  : m_slot( slot ), m_timelineSvc( svcLocator->service<ITimelineSvc>( "TimelineSvc", false ) ) {
302  MsgStream log{ msgSvc, "EndTime.Getter" };
303 
304  // Figure if we can discover the algorithm timings
305  if ( !m_timelineSvc.isValid() )
306  log << MSG::WARNING << "Failed to locate the TimelineSvc: no way to add "
307  << "algorithm completion time to the TTT dumps" << endmsg;
308  }
309 
310  std::string operator()( const AlgoProps& props ) const {
311 
312  std::string endTime;
313 
314  if ( m_timelineSvc.isValid() ) {
315 
316  TimelineEvent te{};
317  te.algorithm = props.m_name;
318  te.slot = m_slot.eventContext->slot();
319  te.event = m_slot.eventContext->evt();
320 
321  m_timelineSvc->getTimelineEvent( te );
322  endTime =
323  std::to_string( std::chrono::duration_cast<std::chrono::nanoseconds>( te.end.time_since_epoch() ).count() );
324  }
325 
326  return endTime;
327  }
328 
329  std::string operator()( const DecisionHubProps& ) const { return ""; }
330 
331  std::string operator()( const DataProps& ) const { return ""; }
332 
335  };
336 
337  struct Duration {
339  : m_slot( slot ), m_timelineSvc( svcLocator->service<ITimelineSvc>( "TimelineSvc", false ) ) {
341  MsgStream log{ msgSvc, "Duration.Getter" };
342 
343  // Figure if we can discover the algorithm timings
344  if ( !m_timelineSvc.isValid() )
345  log << MSG::WARNING << "Failed to locate the TimelineSvc: no way to add "
346  << "algorithm's runtimes to the TTT dumps" << endmsg;
347  }
348 
349  std::string operator()( const AlgoProps& props ) const {
350 
351  std::string time;
352 
353  if ( m_timelineSvc.isValid() ) {
354 
355  TimelineEvent te;
356  te.algorithm = props.m_name;
357  te.slot = m_slot.eventContext->slot();
358  te.event = m_slot.eventContext->evt();
359 
360  m_timelineSvc->getTimelineEvent( te );
361  time = std::to_string( std::chrono::duration_cast<std::chrono::nanoseconds>( te.end - te.start ).count() );
362  }
363 
364  return time;
365  }
366 
367  std::string operator()( const DecisionHubProps& ) const { return ""; }
368 
369  std::string operator()( const DataProps& ) const { return ""; }
370 
373  };
374 
375  struct Operations {
376  std::string operator()( const AlgoProps& props ) const {
377  return props.m_isAsynchronous ? "Asynchronous" : "CPU-bound";
378  }
379 
380  std::string operator()( const DecisionHubProps& ) const { return ""; }
381 
382  std::string operator()( const DataProps& ) const { return ""; }
383  };
384 
385  static inline std::ostream& operator<<( std::ostream& os, const AlgoProps& ) { return os << "Algorithm"; }
386  static inline std::ostream& operator<<( std::ostream& os, const DecisionHubProps& ) { return os << "DecisionHub"; }
387  static inline std::ostream& operator<<( std::ostream& os, const DataProps& ) { return os << "Data"; }
388  static inline std::ostream& operator<<( std::ostream& os, const CondDataProps& ) { return os << "ConditionData"; }
389 
390  //=========================================================================
391 
392  using VariantVertexProps = std::variant<AlgoProps, DecisionHubProps, DataProps, CondDataProps>;
393  using PRGraph = boost::adjacency_list<boost::vecS, boost::vecS, boost::bidirectionalS, VariantVertexProps>;
394  using PRVertexDesc = boost::graph_traits<PRGraph>::vertex_descriptor;
395 
396 } // namespace precedence
397 
398 struct Cause final {
399  enum class source { Root, Task };
400 
402  std::string m_sourceName;
403 };
404 
405 namespace concurrency {
406  class PrecedenceRulesGraph;
407 
408  using precedence::AlgoProps;
410  using precedence::DataProps;
414 
415  // ==========================================================================
417  public:
419  ControlFlowNode( PrecedenceRulesGraph& graph, unsigned int nodeIndex, const std::string& name )
420  : m_graph( &graph ), m_nodeIndex( nodeIndex ), m_nodeName( name ) {}
422  virtual ~ControlFlowNode() = default;
423 
425  virtual bool accept( IGraphVisitor& visitor ) = 0;
427  virtual void printState( std::stringstream& output, EventSlot& slot, const unsigned int& recursionLevel ) const = 0;
429  const unsigned int& getNodeIndex() const { return m_nodeIndex; }
431  const std::string& name() const { return m_nodeName; }
432 
433  public:
435 
436  protected:
437  unsigned int m_nodeIndex;
438  std::string m_nodeName;
439  };
440 
441  class DecisionNode final : public ControlFlowNode {
442  public:
444  DecisionNode( PrecedenceRulesGraph& graph, unsigned int nodeIndex, const std::string& name,
445  Concurrent modeConcurrent, PromptDecision modePromptDecision, ModeOr modeOR, AllPass allPass,
446  Inverted isInverted )
447  : ControlFlowNode( graph, nodeIndex, name )
448  , m_modeConcurrent( modeConcurrent )
449  , m_modePromptDecision( modePromptDecision )
450  , m_modeOR( modeOR )
451  , m_allPass( allPass )
452  , m_inverted( isInverted ) {}
453 
455  bool accept( IGraphVisitor& visitor ) override;
457  void addParentNode( DecisionNode* node );
459  void addDaughterNode( ControlFlowNode* node );
461  const std::vector<ControlFlowNode*>& getDaughters() const { return m_children; }
463  void printState( std::stringstream& output, EventSlot& slot, const unsigned int& recursionLevel ) const override;
464 
465  public:
472  bool m_modeOR;
474  bool m_allPass;
476  bool m_inverted{ false };
478  std::vector<ControlFlowNode*> m_children;
480  std::vector<DecisionNode*> m_parents;
481  };
482 
483  // ==========================================================================
484  class DataNode;
485 
486  class AlgorithmNode final : public ControlFlowNode {
487  public:
489  AlgorithmNode( PrecedenceRulesGraph& graph, Gaudi::Algorithm* algoPtr, unsigned int nodeIndex,
490  unsigned int algoIndex )
491  : ControlFlowNode( graph, nodeIndex, algoPtr->name() )
492  , m_algorithm( algoPtr )
493  , m_algoIndex( algoIndex )
494  , m_algoName( algoPtr->name() )
495  , m_isAsynchronous( algoPtr->isAsynchronous() ) {}
496 
498  bool accept( IGraphVisitor& visitor ) override;
499 
501  void addParentNode( DecisionNode* node );
503  const std::vector<DecisionNode*>& getParentDecisionHubs() const { return m_parents; }
504 
506  void addOutputDataNode( DataNode* node );
508  void addInputDataNode( DataNode* node );
510  const std::vector<DataNode*>& getOutputDataNodes() const { return m_outputs; }
512  const std::vector<DataNode*>& getInputDataNodes() const { return m_inputs; }
513 
515  void setRank( float rank ) { m_rank = rank; }
517  float getRank() const { return m_rank; }
518 
522  unsigned int getAlgoIndex() const { return m_algoIndex; }
523 
525  void setAsynchronous( bool value ) { m_isAsynchronous = value; }
527  bool isAsynchronous() const { return m_isAsynchronous; }
528 
530  void printState( std::stringstream& output, EventSlot& slot, const unsigned int& recursionLevel ) const override;
531 
532  public:
534  std::vector<DecisionNode*> m_parents;
535 
536  private:
540  unsigned int m_algoIndex;
542  std::string m_algoName;
544  float m_rank = -1;
547 
549  std::vector<DataNode*> m_outputs;
551  std::vector<DataNode*> m_inputs;
552  };
553 
554  // ==========================================================================
555  class DataNode {
556  public:
559 
561  virtual ~DataNode() = default;
562 
563  const DataObjID& name() const { return m_data_object_path; }
564 
566  virtual bool accept( IGraphVisitor& visitor ) {
567  return visitor.visitEnter( *this ) ? visitor.visit( *this ) : true;
568  }
571  if ( std::find( m_producers.begin(), m_producers.end(), node ) == m_producers.end() )
572  m_producers.push_back( node );
573  }
576  if ( std::find( m_consumers.begin(), m_consumers.end(), node ) == m_consumers.end() )
577  m_consumers.push_back( node );
578  }
580  const std::vector<AlgorithmNode*>& getProducers() const { return m_producers; }
582  const std::vector<AlgorithmNode*>& getConsumers() const { return m_consumers; }
583 
584  public:
586 
587  private:
589  std::vector<AlgorithmNode*> m_producers;
590  std::vector<AlgorithmNode*> m_consumers;
591  };
592 
593  class ConditionNode final : public DataNode {
594  public:
597  : DataNode( graph, path ), m_condSvc( condSvc ) {}
598 
602  bool accept( IGraphVisitor& visitor ) override {
603  return visitor.visitEnter( *this ) ? visitor.visit( *this ) : true;
604  }
605 
606  public:
607  // Service for Conditions handling
609  };
610 
611  // ==========================================================================
612 
614  virtual ~IPrecedenceRulesGraph() = default;
615  };
616 
617  template <typename T>
618  struct CompareNodes {
619  bool operator()( const T& a, const T& b ) const { return a->name() < b->name(); }
620  };
621 
622  class PrecedenceRulesGraph : public CommonMessaging<IPrecedenceRulesGraph> {
623  public:
625  PrecedenceRulesGraph( const std::string& name, SmartIF<ISvcLocator> svc ) : m_svcLocator( svc ), m_name( name ) {
626  // make sure that CommonMessaging is initialized
627  setUpMessaging();
628  }
629 
632 
634  void accept( IGraphVisitor& visitor ) const;
635 
637  StatusCode addDataNode( const DataObjID& dataPath );
639  DataNode* getDataNode( const DataObjID& dataPath ) const { return m_dataPathToDataNodeMap.at( dataPath ).get(); }
641  void registerIODataObjects( const Gaudi::Algorithm* algo );
644 
646  void addHeadNode( const std::string& headName, concurrency::Concurrent, concurrency::PromptDecision,
649  DecisionNode* getHeadNode() const { return m_headNode; }
651  StatusCode addAlgorithmNode( Gaudi::Algorithm* daughterAlgo, const std::string& parentName );
653  AlgorithmNode* getAlgorithmNode( const std::string& algoName ) const {
654  return m_algoNameToAlgoNodeMap.at( algoName ).get();
655  }
657  StatusCode addDecisionHubNode( Gaudi::Algorithm* daughterAlgo, const std::string& parentName,
661  unsigned int getControlFlowNodeCounter() const { return m_nodeCounter; }
662 
664  void rankAlgorithms( IGraphVisitor& ranker ) const;
665 
667  const std::string& name() const override { return m_name; }
669  SmartIF<ISvcLocator>& serviceLocator() const override { return m_svcLocator; }
672  void printState( std::stringstream& output, EventSlot& slot, const unsigned int& recursionLevel ) const;
673 
675  void enableAnalysis() { m_enableAnalysis = true; }
676  PRVertexDesc node( const std::string& ) const;
677 
679  std::string dumpDataFlow() const;
681  std::string dumpControlFlow() const;
683  void dumpPrecRules( const boost::filesystem::path&, const EventSlot& slot );
685  void dumpPrecTrace( const boost::filesystem::path&, const EventSlot& slot );
687  void addEdgeToPrecTrace( const AlgorithmNode* u, const AlgorithmNode* v );
689  void dumpControlFlow( std::ostringstream&, ControlFlowNode*, const int& ) const;
690 
691  private:
695  std::unordered_map<std::string, std::unique_ptr<AlgorithmNode>> m_algoNameToAlgoNodeMap;
697  std::unordered_map<std::string, std::unique_ptr<DecisionNode>> m_decisionNameToDecisionHubMap;
699  std::unordered_map<DataObjID, std::unique_ptr<DataNode>, DataObjID_Hasher> m_dataPathToDataNodeMap;
701  std::unordered_map<std::string, DataObjIDColl> m_algoNameToAlgoInputsMap;
702  std::unordered_map<std::string, DataObjIDColl> m_algoNameToAlgoOutputsMap;
703 
705  unsigned int m_nodeCounter = 0;
707  unsigned int m_algoCounter = 0;
708 
711  const std::string m_name;
712 
715  std::map<std::string, precedence::AlgoTraceVertex> m_prec_trace_map;
716  bool m_enableAnalysis{ false };
719 
722  };
723 
724 } // namespace concurrency
725 #endif
precedence
Definition: precedence.py:1
EventSlot::eventContext
std::unique_ptr< EventContext > eventContext
Cache for the eventContext.
Definition: EventSlot.h:83
ITimelineSvc.h
concurrency::AlgorithmNode::m_rank
float m_rank
Algorithm rank of any kind.
Definition: PrecedenceRulesGraph.h:544
concurrency::AlgorithmNode::setAsynchronous
void setAsynchronous(bool value)
Set the asynchronous flag.
Definition: PrecedenceRulesGraph.h:525
concurrency::ControlFlowNode::accept
virtual bool accept(IGraphVisitor &visitor)=0
Visitor entry point.
precedence::EntityState::m_condSvc
SmartIF< ICondSvc > m_condSvc
Definition: PrecedenceRulesGraph.h:254
concurrency::AlgorithmNode::m_parents
std::vector< DecisionNode * > m_parents
Control flow parents of an AlgorithmNode (DecisionNodes)
Definition: PrecedenceRulesGraph.h:534
precedence::EndTime::m_timelineSvc
SmartIF< ITimelineSvc > m_timelineSvc
Definition: PrecedenceRulesGraph.h:334
ConditionsStallTest.condSvc
condSvc
Definition: ConditionsStallTest.py:77
concurrency::DataNode::m_producers
std::vector< AlgorithmNode * > m_producers
Definition: PrecedenceRulesGraph.h:589
precedence::DecisionHubProps::DecisionHubProps
DecisionHubProps(const std::string &name, uint nodeIndex, concurrency::Concurrent modeConcurrent, concurrency::PromptDecision modePromptDecision, concurrency::ModeOr modeOR, concurrency::AllPass allPass, concurrency::Inverted isInverted)
Definition: PrecedenceRulesGraph.h:87
concurrency::PrecedenceRulesGraph::printState
void printState(std::stringstream &output, EventSlot &slot, const unsigned int &recursionLevel) const
Print a string representing the control flow state.
Definition: PrecedenceRulesGraph.cpp:260
concurrency::PrecedenceRulesGraph::dumpPrecTrace
void dumpPrecTrace(const boost::filesystem::path &, const EventSlot &slot)
dump to file the precedence trace
Definition: PrecedenceRulesGraph.cpp:666
concurrency::PrecedenceRulesGraph::addDataNode
StatusCode addDataNode(const DataObjID &dataPath)
Add DataNode that represents DataObject.
Definition: PrecedenceRulesGraph.cpp:421
concurrency::ControlFlowNode::printState
virtual void printState(std::stringstream &output, EventSlot &slot, const unsigned int &recursionLevel) const =0
Print a string representing the control flow state.
Gaudi.Configuration.log
log
Definition: Configuration.py:28
concurrency::PrecedenceRulesGraph::accept
void accept(IGraphVisitor &visitor) const
An entry point to visit all graph nodes.
Definition: PrecedenceRulesGraph.cpp:538
precedence::DataProps::m_id
DataObjID m_id
Definition: PrecedenceRulesGraph.h:117
precedence::DecisionHubProps::m_modeConcurrent
bool m_modeConcurrent
Whether all daughters will be evaluated concurrently or sequentially.
Definition: PrecedenceRulesGraph.h:102
precedence::AlgoProps::AlgoProps
AlgoProps()
Definition: PrecedenceRulesGraph.h:68
AtlasMCRecoFullPrecedenceDump.path
path
Definition: AtlasMCRecoFullPrecedenceDump.py:49
precedence::Duration::operator()
std::string operator()(const DecisionHubProps &) const
Definition: PrecedenceRulesGraph.h:367
precedence::AlgoProps::m_algoIndex
int m_algoIndex
Definition: PrecedenceRulesGraph.h:78
precedence::Operations::operator()
std::string operator()(const DataProps &) const
Definition: PrecedenceRulesGraph.h:382
concurrency::AlgorithmNode::getInputDataNodes
const std::vector< DataNode * > & getInputDataNodes() const
Get all consumer nodes.
Definition: PrecedenceRulesGraph.h:512
concurrency::PrecedenceRulesGraph::getControlFlowNodeCounter
unsigned int getControlFlowNodeCounter() const
Get total number of control flow graph nodes.
Definition: PrecedenceRulesGraph.h:661
precedence::EntityState::m_conditionsEnabled
bool m_conditionsEnabled
Definition: PrecedenceRulesGraph.h:255
precedence::CondDataProps::CondDataProps
CondDataProps(const DataObjID &id)
Definition: PrecedenceRulesGraph.h:121
concurrency::DataNode::m_consumers
std::vector< AlgorithmNode * > m_consumers
Definition: PrecedenceRulesGraph.h:590
precedence::AlgoTraceProps::m_runtime
long int m_runtime
Definition: PrecedenceRulesGraph.h:58
TimelineEvent::start
time_point start
Definition: TimelineEvent.h:26
concurrency::AlgorithmNode::setRank
void setRank(float rank)
Set Algorithm rank.
Definition: PrecedenceRulesGraph.h:515
check_ParticleID.props
props
Definition: check_ParticleID.py:21
concurrency::PrecedenceRulesGraph::m_name
const std::string m_name
Definition: PrecedenceRulesGraph.h:711
precedence::DecisionNegation::operator()
std::string operator()(const DataProps &) const
Definition: PrecedenceRulesGraph.h:169
EventSlot
Class representing an event slot.
Definition: EventSlot.h:24
concurrency::DecisionNode::m_modeOR
bool m_modeOR
Whether acting as "and" (false) or "or" node (true)
Definition: PrecedenceRulesGraph.h:472
concurrency::PrecedenceRulesGraph
Definition: PrecedenceRulesGraph.h:622
concurrency::ControlFlowNode::name
const std::string & name() const
Get node name.
Definition: PrecedenceRulesGraph.h:431
precedence::StartTime
Definition: PrecedenceRulesGraph.h:258
concurrency::PrecedenceRulesGraph::m_decisionNameToDecisionHubMap
std::unordered_map< std::string, std::unique_ptr< DecisionNode > > m_decisionNameToDecisionHubMap
Index: map of decision's name to DecisionHub.
Definition: PrecedenceRulesGraph.h:697
concurrency::PrecedenceRulesGraph::dumpPrecRules
void dumpPrecRules(const boost::filesystem::path &, const EventSlot &slot)
dump to file the precedence rules
Definition: PrecedenceRulesGraph.cpp:625
concurrency::DecisionNode::m_children
std::vector< ControlFlowNode * > m_children
All direct daughter nodes in the tree.
Definition: PrecedenceRulesGraph.h:478
concurrency::AlgorithmNode::m_outputs
std::vector< DataNode * > m_outputs
Algorithm outputs (DataNodes)
Definition: PrecedenceRulesGraph.h:549
precedence::Duration::m_timelineSvc
SmartIF< ITimelineSvc > m_timelineSvc
Definition: PrecedenceRulesGraph.h:372
precedence::EndTime::EndTime
EndTime(const EventSlot &slot, SmartIF< ISvcLocator > &svcLocator)
Definition: PrecedenceRulesGraph.h:299
precedence::DecisionNegation::operator()
std::string operator()(const DecisionHubProps &props) const
Definition: PrecedenceRulesGraph.h:165
concurrency::PrecedenceRulesGraph::m_enableAnalysis
bool m_enableAnalysis
Definition: PrecedenceRulesGraph.h:716
MSG::WARNING
@ WARNING
Definition: IMessageSvc.h:25
concurrency::AlgorithmNode::getOutputDataNodes
const std::vector< DataNode * > & getOutputDataNodes() const
Get all supplier nodes.
Definition: PrecedenceRulesGraph.h:510
concurrency::AlgorithmNode::m_algoName
std::string m_algoName
The name of the algorithm.
Definition: PrecedenceRulesGraph.h:542
IHiveWhiteBoard
Definition: IHiveWhiteBoard.h:27
precedence::DecisionHubProps::m_name
std::string m_name
Definition: PrecedenceRulesGraph.h:98
concurrency::AlgorithmNode::m_algoIndex
unsigned int m_algoIndex
The index of the algorithm.
Definition: PrecedenceRulesGraph.h:540
concurrency::DecisionNode::m_modePromptDecision
bool m_modePromptDecision
Whether to evaluate the hub decision ASA its child decisions allow to do that.
Definition: PrecedenceRulesGraph.h:470
concurrency::CompareNodes::operator()
bool operator()(const T &a, const T &b) const
Definition: PrecedenceRulesGraph.h:619
precedence::EntityState::m_whiteboard
SmartIF< IHiveWhiteBoard > m_whiteboard
Definition: PrecedenceRulesGraph.h:253
precedence::AlgoProps::m_nodeIndex
int m_nodeIndex
Definition: PrecedenceRulesGraph.h:77
precedence::AlgoProps::m_isAsynchronous
bool m_isAsynchronous
If an algorithm is asynchronous.
Definition: PrecedenceRulesGraph.h:83
precedence::Duration
Definition: PrecedenceRulesGraph.h:337
precedence::EntityState::operator()
std::string operator()(const DecisionHubProps &) const
Definition: PrecedenceRulesGraph.h:230
precedence::PRGraph
boost::adjacency_list< boost::vecS, boost::vecS, boost::bidirectionalS, VariantVertexProps > PRGraph
Definition: PrecedenceRulesGraph.h:393
concurrency::ConditionNode::accept
bool accept(IGraphVisitor &visitor) override
Need to hide the (identical) base method with this one so that visitEnter(ConditionNode&) and visit(C...
Definition: PrecedenceRulesGraph.h:602
precedence::Operations
Definition: PrecedenceRulesGraph.h:375
precedence::EndTime
Definition: PrecedenceRulesGraph.h:298
concurrency::DecisionNode::addParentNode
void addParentNode(DecisionNode *node)
Add a parent node.
Definition: PrecedenceRulesGraph.cpp:41
precedence::AlgoTraceProps::m_index
int m_index
Definition: PrecedenceRulesGraph.h:56
concurrency::PrecedenceRulesGraph::initialize
StatusCode initialize()
Initialize graph.
Definition: PrecedenceRulesGraph.cpp:220
gaudirun.output
output
Definition: gaudirun.py:521
concurrency::ControlFlowNode::m_nodeIndex
unsigned int m_nodeIndex
Definition: PrecedenceRulesGraph.h:437
concurrency::DataNode::m_graph
PrecedenceRulesGraph * m_graph
Definition: PrecedenceRulesGraph.h:585
concurrency::AlgorithmNode::getParentDecisionHubs
const std::vector< DecisionNode * > & getParentDecisionHubs() const
Get all parent decision hubs.
Definition: PrecedenceRulesGraph.h:503
GaudiPartProp.tests.id
id
Definition: tests.py:111
concurrency::DataNode::name
const DataObjID & name() const
Definition: PrecedenceRulesGraph.h:563
precedence::AllPass::operator()
std::string operator()(const AlgoProps &) const
Definition: PrecedenceRulesGraph.h:173
IOTest.start
start
Definition: IOTest.py:110
concurrency::IGraphVisitor
Definition: IGraphVisitor.h:21
concurrency::DecisionNode::addDaughterNode
void addDaughterNode(ControlFlowNode *node)
Add a daughter node.
Definition: PrecedenceRulesGraph.cpp:47
precedence::VertexName::operator()
std::string operator()(const AlgoProps &props) const
Definition: PrecedenceRulesGraph.h:127
concurrency::AlgorithmNode::printState
void printState(std::stringstream &output, EventSlot &slot, const unsigned int &recursionLevel) const override
Print a string representing the control flow state.
Definition: PrecedenceRulesGraph.cpp:77
precedence::Duration::m_slot
const EventSlot & m_slot
Definition: PrecedenceRulesGraph.h:371
precedence::GroupMode::operator()
std::string operator()(const AlgoProps &) const
Definition: PrecedenceRulesGraph.h:135
TimelineEvent::event
size_t event
Definition: TimelineEvent.h:22
precedence::DecisionHubProps::m_nodeIndex
uint m_nodeIndex
Definition: PrecedenceRulesGraph.h:99
concurrency::AlgorithmNode::getAlgoIndex
unsigned int getAlgoIndex() const
Get algorithm index.
Definition: PrecedenceRulesGraph.h:522
concurrency::AlgorithmNode::accept
bool accept(IGraphVisitor &visitor) override
Visitor entry point.
Definition: PrecedenceRulesGraph.cpp:191
precedence::Duration::operator()
std::string operator()(const AlgoProps &props) const
Definition: PrecedenceRulesGraph.h:349
AvalancheSchedulerErrorTest.msgSvc
msgSvc
Definition: AvalancheSchedulerErrorTest.py:80
precedence::EndTime::operator()
std::string operator()(const AlgoProps &props) const
Definition: PrecedenceRulesGraph.h:310
concurrency::AlgorithmNode
Definition: PrecedenceRulesGraph.h:486
precedence::CFDecision
Definition: PrecedenceRulesGraph.h:180
TimelineEvent::slot
size_t slot
Definition: TimelineEvent.h:21
precedence::AllPass::operator()
std::string operator()(const DecisionHubProps &props) const
Definition: PrecedenceRulesGraph.h:175
concurrency::AlgorithmNode::AlgorithmNode
AlgorithmNode(PrecedenceRulesGraph &graph, Gaudi::Algorithm *algoPtr, unsigned int nodeIndex, unsigned int algoIndex)
Constructor.
Definition: PrecedenceRulesGraph.h:489
precedence::PRVertexDesc
boost::graph_traits< PRGraph >::vertex_descriptor PRVertexDesc
Definition: PrecedenceRulesGraph.h:394
concurrency::PrecedenceRulesGraph::m_headNode
DecisionNode * m_headNode
the head node of the control flow graph
Definition: PrecedenceRulesGraph.h:693
precedence::AlgoTraceProps::m_eccentricity
int m_eccentricity
Definition: PrecedenceRulesGraph.h:60
TimelineEvent
Definition: TimelineEvent.h:16
concurrency::DecisionNode::printState
void printState(std::stringstream &output, EventSlot &slot, const unsigned int &recursionLevel) const override
Print a string representing the control flow state.
Definition: PrecedenceRulesGraph.cpp:53
precedence::CondDataProps
Definition: PrecedenceRulesGraph.h:120
precedence::EndTime::operator()
std::string operator()(const DataProps &) const
Definition: PrecedenceRulesGraph.h:331
Gaudi::svcLocator
GAUDI_API ISvcLocator * svcLocator()
precedence::AlgoTraceProps::AlgoTraceProps
AlgoTraceProps(const std::string &name, int index=-1, int rank=-1, long int runtime=-1, long long int start=-1)
Definition: PrecedenceRulesGraph.h:52
concurrency::ConditionNode
Definition: PrecedenceRulesGraph.h:593
precedence::StartTime::m_timelineSvc
SmartIF< ITimelineSvc > m_timelineSvc
Definition: PrecedenceRulesGraph.h:295
concurrency::ControlFlowNode::~ControlFlowNode
virtual ~ControlFlowNode()=default
Destructor.
SmartIF::isValid
bool isValid() const
Allow for check if smart pointer is valid.
Definition: SmartIF.h:72
CommonMessaging< IPrecedenceRulesGraph >::setUpMessaging
MSG::Level setUpMessaging() const
Set up local caches.
Definition: CommonMessaging.h:174
plotSpeedupsPyRoot.graph
graph
Definition: plotSpeedupsPyRoot.py:168
StatusCode
Definition: StatusCode.h:65
Gaudi::tagged_bool_ns::tagged_bool
Definition: TaggedBool.h:16
TaggedBool.h
ITimelineSvc
Definition: ITimelineSvc.h:21
concurrency::AlgorithmNode::addInputDataNode
void addInputDataNode(DataNode *node)
Associate an AlgorithmNode, which is a data consumer of this one.
Definition: PrecedenceRulesGraph.cpp:214
concurrency::PrecedenceRulesGraph::m_dataPathToDataNodeMap
std::unordered_map< DataObjID, std::unique_ptr< DataNode >, DataObjID_Hasher > m_dataPathToDataNodeMap
Index: map of data path to DataNode.
Definition: PrecedenceRulesGraph.h:699
IGraphVisitor.h
precedence::AlgoProps::m_rank
int m_rank
Definition: PrecedenceRulesGraph.h:79
Gaudi::Parsers::operator<<
std::ostream & operator<<(std::ostream &o, const Catalog &c)
printout operator
Definition: Catalog.h:67
ICondSvc
Definition: ICondSvc.h:39
concurrency::DataNode::~DataNode
virtual ~DataNode()=default
Destructor.
CommonMessaging
Definition: CommonMessaging.h:66
Cause::m_source
source m_source
Definition: PrecedenceRulesGraph.h:401
Gaudi::Algorithm
Base class from which all concrete algorithm classes should be derived.
Definition: Algorithm.h:90
precedence::GroupMode
Definition: PrecedenceRulesGraph.h:134
concurrency::IGraphVisitor::visit
virtual bool visit(DecisionNode &)
Definition: IGraphVisitor.h:26
concurrency::PrecedenceRulesGraph::name
const std::string & name() const override
Retrieve name of the service.
Definition: PrecedenceRulesGraph.h:667
precedence::DataProps::DataProps
DataProps(const DataObjID &id)
Definition: PrecedenceRulesGraph.h:115
precedence::GroupLogic::operator()
std::string operator()(const DecisionHubProps &props) const
Definition: PrecedenceRulesGraph.h:147
ISvcLocator::service
StatusCode service(const Gaudi::Utils::TypeNameString &name, T *&svc, bool createIf=true)
Templated method to access a service by name.
Definition: ISvcLocator.h:98
concurrency::IPrecedenceRulesGraph::~IPrecedenceRulesGraph
virtual ~IPrecedenceRulesGraph()=default
concurrency::DecisionNode::m_modeConcurrent
bool m_modeConcurrent
Whether all daughters will be evaluated concurrently or sequentially.
Definition: PrecedenceRulesGraph.h:467
precedence::GroupExit::operator()
std::string operator()(const DecisionHubProps &props) const
Definition: PrecedenceRulesGraph.h:155
precedence::DataProps
Definition: PrecedenceRulesGraph.h:114
concurrency::PrecedenceRulesGraph::m_prec_trace_map
std::map< std::string, precedence::AlgoTraceVertex > m_prec_trace_map
Definition: PrecedenceRulesGraph.h:715
precedence::PrecTrace
boost::adjacency_list< boost::vecS, boost::vecS, boost::bidirectionalS, AlgoTraceProps > PrecTrace
Definition: PrecedenceRulesGraph.h:63
concurrency::PrecedenceRulesGraph::m_nodeCounter
unsigned int m_nodeCounter
Total number of nodes in the graph.
Definition: PrecedenceRulesGraph.h:705
precedence::CFDecision::operator()
std::string operator()(const AlgoProps &props) const
Definition: PrecedenceRulesGraph.h:183
concurrency::PrecedenceRulesGraph::getDataNode
DataNode * getDataNode(const DataObjID &dataPath) const
Get DataNode by DataObject path using graph index.
Definition: PrecedenceRulesGraph.h:639
precedence::CFDecision::CFDecision
CFDecision(const EventSlot &slot)
Definition: PrecedenceRulesGraph.h:181
precedence::AllPass::operator()
std::string operator()(const DataProps &) const
Definition: PrecedenceRulesGraph.h:177
precedence::GroupExit::operator()
std::string operator()(const DataProps &) const
Definition: PrecedenceRulesGraph.h:159
precedence::DecisionNegation::operator()
std::string operator()(const AlgoProps &) const
Definition: PrecedenceRulesGraph.h:163
Cause::source
source
Definition: PrecedenceRulesGraph.h:399
concurrency::PrecedenceRulesGraph::PrecedenceRulesGraph
PrecedenceRulesGraph(const std::string &name, SmartIF< ISvcLocator > svc)
Constructor.
Definition: PrecedenceRulesGraph.h:625
Algorithm.h
concurrency::PrecedenceRulesGraph::rankAlgorithms
void rankAlgorithms(IGraphVisitor &ranker) const
Rank Algorithm nodes by the number of data outputs.
Definition: PrecedenceRulesGraph.cpp:550
concurrency::DataNode::accept
virtual bool accept(IGraphVisitor &visitor)
Entry point for a visitor.
Definition: PrecedenceRulesGraph.h:566
precedence::DecisionNegation
Definition: PrecedenceRulesGraph.h:162
SmartIF< ISvcLocator >
precedence::VertexName::operator()
std::string operator()(const DataProps &props) const
Definition: PrecedenceRulesGraph.h:131
precedence::VertexName
Definition: PrecedenceRulesGraph.h:126
CommonMessaging.h
IHiveWhiteBoard.h
precedence::DecisionHubProps::m_modeOR
bool m_modeOR
Whether acting as "and" (false) or "or" node (true)
Definition: PrecedenceRulesGraph.h:109
concurrency::PrecedenceRulesGraph::addDecisionHubNode
StatusCode addDecisionHubNode(Gaudi::Algorithm *daughterAlgo, const std::string &parentName, concurrency::Concurrent, concurrency::PromptDecision, concurrency::ModeOr, concurrency::AllPass, concurrency::Inverted)
Add a node, which aggregates decisions of direct daughter nodes.
Definition: PrecedenceRulesGraph.cpp:451
precedence::Duration::operator()
std::string operator()(const DataProps &) const
Definition: PrecedenceRulesGraph.h:369
endmsg
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:202
concurrency::DecisionNode::getDaughters
const std::vector< ControlFlowNode * > & getDaughters() const
Get children nodes.
Definition: PrecedenceRulesGraph.h:461
precedence::AlgoTraceProps::m_rank
int m_rank
Definition: PrecedenceRulesGraph.h:57
Cause::source::Root
@ Root
concurrency::DecisionNode::m_inverted
bool m_inverted
Whether the selection result is negated or not.
Definition: PrecedenceRulesGraph.h:476
concurrency::ControlFlowNode::ControlFlowNode
ControlFlowNode(PrecedenceRulesGraph &graph, unsigned int nodeIndex, const std::string &name)
Constructor.
Definition: PrecedenceRulesGraph.h:419
concurrency::PrecedenceRulesGraph::dumpControlFlow
std::string dumpControlFlow() const
Print out control flow of Algorithms and Sequences.
Definition: PrecedenceRulesGraph.cpp:560
MsgStream
Definition: MsgStream.h:33
precedence::AlgoTraceProps
Definition: PrecedenceRulesGraph.h:50
plotSpeedupsPyRoot.time
time
Definition: plotSpeedupsPyRoot.py:180
concurrency::AlgorithmNode::getRank
float getRank() const
Get Algorithm rank.
Definition: PrecedenceRulesGraph.h:517
concurrency::PrecedenceRulesGraph::m_algoNameToAlgoNodeMap
std::unordered_map< std::string, std::unique_ptr< AlgorithmNode > > m_algoNameToAlgoNodeMap
Index: map of algorithm's name to AlgorithmNode.
Definition: PrecedenceRulesGraph.h:695
concurrency::PrecedenceRulesGraph::m_algoCounter
unsigned int m_algoCounter
Total number of algorithm nodes in the graph.
Definition: PrecedenceRulesGraph.h:707
precedence::AlgoTraceProps::AlgoTraceProps
AlgoTraceProps()
Definition: PrecedenceRulesGraph.h:51
precedence::VariantVertexProps
std::variant< AlgoProps, DecisionHubProps, DataProps, CondDataProps > VariantVertexProps
Definition: PrecedenceRulesGraph.h:392
DataObjID
Definition: DataObjID.h:48
precedence::EndTime::operator()
std::string operator()(const DecisionHubProps &) const
Definition: PrecedenceRulesGraph.h:329
concurrency::DataNode::DataNode
DataNode(PrecedenceRulesGraph &graph, const DataObjID &path)
Constructor.
Definition: PrecedenceRulesGraph.h:558
precedence::Duration::Duration
Duration(const EventSlot &slot, SmartIF< ISvcLocator > &svcLocator)
Definition: PrecedenceRulesGraph.h:338
concurrency
Definition: PrecedenceRulesGraph.cpp:38
precedence::VertexName::operator()
std::string operator()(const DecisionHubProps &props) const
Definition: PrecedenceRulesGraph.h:129
concurrency::PrecedenceRulesGraph::m_conditionsRealmEnabled
bool m_conditionsRealmEnabled
Enable conditions realm of precedence rules.
Definition: PrecedenceRulesGraph.h:721
precedence::AlgoProps
Definition: PrecedenceRulesGraph.h:67
concurrency::DataNode::getConsumers
const std::vector< AlgorithmNode * > & getConsumers() const
Get all data object consumers.
Definition: PrecedenceRulesGraph.h:582
concurrency::IGraphVisitor::visitEnter
virtual bool visitEnter(DecisionNode &) const
Definition: IGraphVisitor.h:25
precedence::EntityState::operator()
std::string operator()(const CondDataProps &props) const
Definition: PrecedenceRulesGraph.h:242
concurrency::AlgorithmNode::m_algorithm
Gaudi::Algorithm * m_algorithm
Algorithm representative behind the AlgorithmNode.
Definition: PrecedenceRulesGraph.h:538
TimelineEvent.h
concurrency::DecisionNode
Definition: PrecedenceRulesGraph.h:441
concurrency::PrecedenceRulesGraph::m_precTrace
precedence::PrecTrace m_precTrace
facilities for algorithm precedence tracing
Definition: PrecedenceRulesGraph.h:714
concurrency::DataNode::addProducerNode
void addProducerNode(AlgorithmNode *node)
Add relationship to producer AlgorithmNode.
Definition: PrecedenceRulesGraph.h:570
precedence::EntityState::EntityState
EntityState(const EventSlot &slot, SmartIF< ISvcLocator > &svcLocator, bool conditionsEnabled)
Definition: PrecedenceRulesGraph.h:197
concurrency::PrecedenceRulesGraph::m_algoNameToAlgoInputsMap
std::unordered_map< std::string, DataObjIDColl > m_algoNameToAlgoInputsMap
Indexes: maps of algorithm's name to algorithm's inputs/outputs.
Definition: PrecedenceRulesGraph.h:701
concurrency::AlgorithmNode::m_inputs
std::vector< DataNode * > m_inputs
Algorithm inputs (DataNodes)
Definition: PrecedenceRulesGraph.h:551
concurrency::ControlFlowNode::m_nodeName
std::string m_nodeName
Definition: PrecedenceRulesGraph.h:438
concurrency::DecisionNode::m_allPass
bool m_allPass
Whether always passing regardless of daughter results.
Definition: PrecedenceRulesGraph.h:474
concurrency::PrecedenceRulesGraph::getAlgorithmNode
AlgorithmNode * getAlgorithmNode(const std::string &algoName) const
Get the AlgorithmNode from by algorithm name using graph index.
Definition: PrecedenceRulesGraph.h:653
concurrency::PrecedenceRulesGraph::m_PRGraph
precedence::PRGraph m_PRGraph
BGL-based graph of precedence rules.
Definition: PrecedenceRulesGraph.h:718
precedence::EntityState::operator()
std::string operator()(const DataProps &props) const
Definition: PrecedenceRulesGraph.h:232
concurrency::PrecedenceRulesGraph::dumpDataFlow
std::string dumpDataFlow() const
Print out all data origins and destinations, as reflected in the EF graph.
Definition: PrecedenceRulesGraph.cpp:591
concurrency::PrecedenceRulesGraph::registerIODataObjects
void registerIODataObjects(const Gaudi::Algorithm *algo)
Register algorithm in the Data Dependency index.
Definition: PrecedenceRulesGraph.cpp:299
ConditionsStallTest.name
name
Definition: ConditionsStallTest.py:77
Cause::source::Task
@ Task
precedence::AlgoProps::m_name
std::string m_name
Definition: PrecedenceRulesGraph.h:76
DataObject.h
concurrency::DataNode::addConsumerNode
void addConsumerNode(AlgorithmNode *node)
Add relationship to consumer AlgorithmNode.
Definition: PrecedenceRulesGraph.h:575
precedence::DecisionHubProps::m_inverted
bool m_inverted
Whether the selection result is negated or not.
Definition: PrecedenceRulesGraph.h:107
precedence::StartTime::StartTime
StartTime(const EventSlot &slot, SmartIF< ISvcLocator > &svcLocator)
Definition: PrecedenceRulesGraph.h:259
precedence::AlgoTraceProps::m_start
long long int m_start
Definition: PrecedenceRulesGraph.h:59
precedence::GroupLogic
Definition: PrecedenceRulesGraph.h:144
concurrency::AlgorithmNode::m_isAsynchronous
bool m_isAsynchronous
If an algorithm is asynchronous.
Definition: PrecedenceRulesGraph.h:546
concurrency::ControlFlowNode
Definition: PrecedenceRulesGraph.h:416
concurrency::PrecedenceRulesGraph::m_algoNameToAlgoOutputsMap
std::unordered_map< std::string, DataObjIDColl > m_algoNameToAlgoOutputsMap
Definition: PrecedenceRulesGraph.h:702
precedence::DecisionHubProps
Definition: PrecedenceRulesGraph.h:86
concurrency::PrecedenceRulesGraph::addAlgorithmNode
StatusCode addAlgorithmNode(Gaudi::Algorithm *daughterAlgo, const std::string &parentName)
Add algorithm node.
Definition: PrecedenceRulesGraph.cpp:372
concurrency::IPrecedenceRulesGraph
Definition: PrecedenceRulesGraph.h:613
concurrency::PrecedenceRulesGraph::enableAnalysis
void enableAnalysis()
BGL-based facilities.
Definition: PrecedenceRulesGraph.h:675
precedence::GroupExit::operator()
std::string operator()(const AlgoProps &) const
Definition: PrecedenceRulesGraph.h:153
TimelineEvent::algorithm
std::string algorithm
Definition: TimelineEvent.h:24
precedence::EntityState::operator()
std::string operator()(const AlgoProps &props) const
Definition: PrecedenceRulesGraph.h:224
concurrency::PrecedenceRulesGraph::serviceLocator
SmartIF< ISvcLocator > & serviceLocator() const override
Retrieve pointer to service locator.
Definition: PrecedenceRulesGraph.h:669
precedence::StartTime::operator()
std::string operator()(const AlgoProps &props) const
Definition: PrecedenceRulesGraph.h:271
Properties.v
v
Definition: Properties.py:122
precedence::StartTime::operator()
std::string operator()(const DecisionHubProps &) const
Definition: PrecedenceRulesGraph.h:290
concurrency::DataNode
Definition: PrecedenceRulesGraph.h:555
concurrency::CompareNodes
Definition: PrecedenceRulesGraph.h:618
precedence::EntityState
Definition: PrecedenceRulesGraph.h:196
EventSlot::controlFlowState
std::vector< int > controlFlowState
State of the control flow.
Definition: EventSlot.h:87
precedence::GroupMode::operator()
std::string operator()(const DecisionHubProps &props) const
Definition: PrecedenceRulesGraph.h:137
precedence::AlgoTraceVertex
boost::graph_traits< PrecTrace >::vertex_descriptor AlgoTraceVertex
Definition: PrecedenceRulesGraph.h:64
precedence::StartTime::operator()
std::string operator()(const DataProps &) const
Definition: PrecedenceRulesGraph.h:292
concurrency::DecisionNode::m_parents
std::vector< DecisionNode * > m_parents
Direct parent nodes.
Definition: PrecedenceRulesGraph.h:480
precedence::CFDecision::operator()
std::string operator()(const DataProps &) const
Definition: PrecedenceRulesGraph.h:191
concurrency::DecisionNode::accept
bool accept(IGraphVisitor &visitor) override
Visitor entry point.
Definition: PrecedenceRulesGraph.cpp:65
concurrency::AlgorithmNode::addOutputDataNode
void addOutputDataNode(DataNode *node)
Associate an AlgorithmNode, which is a data supplier for this one.
Definition: PrecedenceRulesGraph.cpp:208
precedence::AlgoTraceProps::m_name
std::string m_name
Definition: PrecedenceRulesGraph.h:55
precedence::AllPass
Definition: PrecedenceRulesGraph.h:172
concurrency::ConditionNode::m_condSvc
SmartIF< ICondSvc > m_condSvc
Definition: PrecedenceRulesGraph.h:608
TimelineEvent::end
time_point end
Definition: TimelineEvent.h:27
compareRootHistos.state
state
Definition: compareRootHistos.py:496
precedence::Operations::operator()
std::string operator()(const DecisionHubProps &) const
Definition: PrecedenceRulesGraph.h:380
concurrency::PrecedenceRulesGraph::getHeadNode
DecisionNode * getHeadNode() const
Get head node.
Definition: PrecedenceRulesGraph.h:649
concurrency::PrecedenceRulesGraph::node
PRVertexDesc node(const std::string &) const
Definition: PrecedenceRulesGraph.cpp:529
concurrency::PrecedenceRulesGraph::buildDataDependenciesRealm
StatusCode buildDataDependenciesRealm()
Build data dependency realm WITH data object nodes participating.
Definition: PrecedenceRulesGraph.cpp:318
precedence::GroupExit
Definition: PrecedenceRulesGraph.h:152
concurrency::ConditionNode::ConditionNode
ConditionNode(PrecedenceRulesGraph &graph, const DataObjID &path, SmartIF< ICondSvc > condSvc)
Constructor.
Definition: PrecedenceRulesGraph.h:596
precedence::CFDecision::m_slot
const EventSlot & m_slot
Definition: PrecedenceRulesGraph.h:193
precedence::Operations::operator()
std::string operator()(const AlgoProps &props) const
Definition: PrecedenceRulesGraph.h:376
precedence::GroupLogic::operator()
std::string operator()(const DataProps &) const
Definition: PrecedenceRulesGraph.h:149
concurrency::PrecedenceRulesGraph::m_svcLocator
SmartIF< ISvcLocator > m_svcLocator
Service locator (needed to access the MessageSvc)
Definition: PrecedenceRulesGraph.h:710
concurrency::DataNode::m_data_object_path
DataObjID m_data_object_path
Definition: PrecedenceRulesGraph.h:588
precedence::EntityState::m_slot
const EventSlot & m_slot
Definition: PrecedenceRulesGraph.h:251
precedence::DecisionHubProps::m_allPass
bool m_allPass
Whether always passing regardless of daughter results.
Definition: PrecedenceRulesGraph.h:111
concurrency::PrecedenceRulesGraph::addHeadNode
void addHeadNode(const std::string &headName, concurrency::Concurrent, concurrency::PromptDecision, concurrency::ModeOr, concurrency::AllPass, concurrency::Inverted)
Add a node, which has no parents.
Definition: PrecedenceRulesGraph.cpp:504
precedence::CFDecision::operator()
std::string operator()(const DecisionHubProps &props) const
Definition: PrecedenceRulesGraph.h:187
concurrency::ControlFlowNode::m_graph
PrecedenceRulesGraph * m_graph
Definition: PrecedenceRulesGraph.h:434
precedence::GroupMode::operator()
std::string operator()(const DataProps &) const
Definition: PrecedenceRulesGraph.h:141
EventSlot::algsStates
AlgsExecutionStates algsStates
Vector of algorithms states.
Definition: EventSlot.h:85
precedence::StartTime::m_slot
const EventSlot & m_slot
Definition: PrecedenceRulesGraph.h:294
concurrency::AlgorithmNode::isAsynchronous
bool isAsynchronous() const
Check if algorithm is asynchronous.
Definition: PrecedenceRulesGraph.h:527
Cause
Definition: PrecedenceRulesGraph.h:398
DataObjID_Hasher
Definition: DataObjID.h:119
concurrency::DecisionNode::DecisionNode
DecisionNode(PrecedenceRulesGraph &graph, unsigned int nodeIndex, const std::string &name, Concurrent modeConcurrent, PromptDecision modePromptDecision, ModeOr modeOR, AllPass allPass, Inverted isInverted)
Constructor.
Definition: PrecedenceRulesGraph.h:444
precedence::EndTime::m_slot
const EventSlot & m_slot
Definition: PrecedenceRulesGraph.h:333
precedence::DecisionHubProps::m_modePromptDecision
bool m_modePromptDecision
Whether to evaluate the hub decision ASA its child decisions allow to do that.
Definition: PrecedenceRulesGraph.h:105
concurrency::DataNode::getProducers
const std::vector< AlgorithmNode * > & getProducers() const
Get all data object producers.
Definition: PrecedenceRulesGraph.h:580
ICondSvc.h
concurrency::AlgorithmNode::getAlgorithm
Gaudi::Algorithm * getAlgorithm() const
get Algorithm representatives
Definition: PrecedenceRulesGraph.h:520
concurrency::ControlFlowNode::getNodeIndex
const unsigned int & getNodeIndex() const
Get node index.
Definition: PrecedenceRulesGraph.h:429
Gaudi::ParticleProperties::index
size_t index(const Gaudi::ParticleProperty *property, const Gaudi::Interfaces::IParticlePropertySvc *service)
helper utility for mapping of Gaudi::ParticleProperty object into non-negative integral sequential id...
Definition: IParticlePropertySvc.cpp:39
precedence::GroupLogic::operator()
std::string operator()(const AlgoProps &) const
Definition: PrecedenceRulesGraph.h:145
concurrency::AlgorithmNode::addParentNode
void addParentNode(DecisionNode *node)
Add a parent node.
Definition: PrecedenceRulesGraph.cpp:202
Cause::m_sourceName
std::string m_sourceName
Definition: PrecedenceRulesGraph.h:402
precedence::AlgoProps::AlgoProps
AlgoProps(Gaudi::Algorithm *algo, uint nodeIndex, uint algoIndex)
Definition: PrecedenceRulesGraph.h:69
concurrency::PrecedenceRulesGraph::addEdgeToPrecTrace
void addEdgeToPrecTrace(const AlgorithmNode *u, const AlgorithmNode *v)
set cause-effect connection between two algorithms in the precedence trace
Definition: PrecedenceRulesGraph.cpp:719
precedence::AlgoProps::m_algorithm
Gaudi::Algorithm * m_algorithm
Algorithm representative behind the AlgorithmNode.
Definition: PrecedenceRulesGraph.h:81