CMS 3D CMS Logo

ThinnedAssociationsHelper.h
Go to the documentation of this file.
1 #ifndef DataFormats_Provenance_ThinnedAssociationsHelper_h
2 #define DataFormats_Provenance_ThinnedAssociationsHelper_h
3 
9 
10 #include <map>
11 #include <set>
12 #include <vector>
13 
14 namespace edm {
15 
16  class BranchDescription;
17 
19  public:
21  ThinnedAssociationBranches(BranchID const&, BranchID const&, BranchID const&);
22 
23  BranchID const& parent() const { return parent_; }
24  BranchID const& association() const { return association_; }
25  BranchID const& thinned() const { return thinned_; }
26 
27  bool operator<(ThinnedAssociationBranches const& rhs) const { return parent_ < rhs.parent_; }
28 
29  private:
33  };
34 
36  public:
38 
39  std::vector<ThinnedAssociationBranches>::const_iterator begin() const;
40  std::vector<ThinnedAssociationBranches>::const_iterator end() const;
41 
42  std::vector<ThinnedAssociationBranches>::const_iterator parentBegin(BranchID const&) const;
43  std::vector<ThinnedAssociationBranches>::const_iterator parentEnd(BranchID const&) const;
44 
45  void addAssociation(BranchID const&, BranchID const&, BranchID const&);
46  void addAssociation(ThinnedAssociationBranches const&);
47 
48  std::vector<std::pair<BranchID, ThinnedAssociationBranches const*> > associationToBranches() const;
49 
50  void sort();
51  void clear() { vThinnedAssociationBranches_.clear(); }
52 
53  void selectAssociationProducts(std::vector<BranchDescription const*> const& associationDescriptions,
54  std::set<BranchID> const& keptProductsInEvent,
55  std::map<BranchID, bool>& keepAssociation) const;
56 
57  std::vector<ThinnedAssociationBranches> const& data() const { return vThinnedAssociationBranches_; }
58 
59  void requireMatch(ThinnedAssociationBranches const& input) const;
60 
61  void updateFromPrimaryInput(ThinnedAssociationsHelper const&);
62 
63  void updateFromSecondaryInput(ThinnedAssociationsHelper const&,
64  std::vector<BranchID> const& associationsFromSecondary);
65 
66  void updateFromParentProcess(
67  ThinnedAssociationsHelper const& parentThinnedAssociationsHelper,
68  std::map<BranchID, bool> const& keepAssociation,
69  std::map<BranchID::value_type, BranchID::value_type> const& droppedBranchIDToKeptBranchID);
70 
71  void initAssociationsFromSecondary(std::vector<BranchID> const&, ThinnedAssociationsHelper const&);
72 
73  private:
74  bool shouldKeepAssociation(
75  BranchID const& association,
76  std::vector<std::pair<BranchID, ThinnedAssociationBranches const*> > const& associationToBranches,
77  std::set<BranchID>& branchesInRecursion,
78  std::set<BranchID> const& keptProductsInEvent,
79  std::map<BranchID, bool>& keepAssociation) const;
80 
81  std::vector<ThinnedAssociationBranches> vThinnedAssociationBranches_;
82  };
83 } // namespace edm
84 #endif
std::vector< ThinnedAssociationBranches > const & data() const
bool operator<(ThinnedAssociationBranches const &rhs) const
static std::string const input
Definition: EdmProvDump.cc:48
#define end
Definition: vmac.h:39
std::vector< ThinnedAssociationBranches > vThinnedAssociationBranches_
#define begin
Definition: vmac.h:32
HLT enums.