GctUnpackCollections

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127
#ifndef GctUnpackCollections_h
#define GctUnpackCollections_h

/*!
* \class GctUnpackCollections
* \brief RAII and useful methods for the many dataformat collections required by the GCT unpacker.
* 
*  Deliberately made non-copyable with const members and private copy ctor, etc.
*
* \author Robert Frazier
*/

// CMSSW headers
#include "FWCore/Framework/interface/Event.h"

// DataFormat headers
#include "DataFormats/L1CaloTrigger/interface/L1CaloCollections.h"
#include "DataFormats/L1GlobalCaloTrigger/interface/L1GctCollections.h"
#include "DataFormats/L1Trigger/interface/L1TriggerError.h"

class GctUnpackCollections {
public:
  /// Construct with an event. The collections get put into the event when the object instance goes out of scope (i.e. in the destructor).
  GctUnpackCollections(edm::Event& event);

  /// deliberately not implemented!
  GctUnpackCollections(const GctUnpackCollections&) = delete;             ///< Copy ctor
  GctUnpackCollections& operator=(const GctUnpackCollections&) = delete;  ///< Assignment op

  /// Destructor - the last action of this object is to put the gct collections into the event provided on construction.
  ~GctUnpackCollections();

  // Collections for storing GCT input data.
  L1GctFibreCollection* const gctFibres() const { return m_gctFibres.get(); }  ///< Raw fibre input to the GCT.
  L1CaloEmCollection* const rctEm() const { return m_rctEm.get(); }  ///< Input electrons from the RCT to the GCT.
  L1CaloRegionCollection* const rctCalo() const {
    return m_rctCalo.get();
  }  ///< Input calo regions from the RCT to the GCT.

  // GCT intermediate data
  L1GctInternEmCandCollection* const gctInternEm() const {
    return m_gctInternEm.get();
  }  ///< Internal EM candidate collection
  L1GctInternJetDataCollection* const gctInternJets() const {
    return m_gctInternJets.get();
  }  ///< Internal Jet candidate collection
  L1GctInternEtSumCollection* const gctInternEtSums() const {
    return m_gctInternEtSums.get();
  }  ///< Internal Et Sum collection
  L1GctInternHFDataCollection* const gctInternHFData() const {
    return m_gctInternHFData.get();
  }  ///< Internal Hadronic-Forward bit-counts/ring-sums data collection
  L1GctInternHtMissCollection* const gctInternHtMiss() const {
    return m_gctInternHtMiss.get();
  }  ///< Internal missing Ht collection

  // GCT output data
  L1GctEmCandCollection* const gctIsoEm() const {
    return m_gctIsoEm.get();
  }  ///< GCT output: Isolated EM candidate collection
  L1GctEmCandCollection* const gctNonIsoEm() const {
    return m_gctNonIsoEm.get();
  }  ///< GCT output: Non-isolated EM candidate collection
  L1GctJetCandCollection* const gctCenJets() const {
    return m_gctCenJets.get();
  }  ///< GCT output: Central Jets collection
  L1GctJetCandCollection* const gctForJets() const {
    return m_gctForJets.get();
  }  ///< GCT output: Forward Jets collection
  L1GctJetCandCollection* const gctTauJets() const { return m_gctTauJets.get(); }  ///< GCT output: Tau Jets collection
  L1GctHFBitCountsCollection* const gctHfBitCounts() const {
    return m_gctHfBitCounts.get();
  }  ///< GCT output: Hadronic-Forward bit-counts collection
  L1GctHFRingEtSumsCollection* const gctHfRingEtSums() const {
    return m_gctHfRingEtSums.get();
  }  ///< GCT output: Hadronic-Forward ring-sums collection
  L1GctEtTotalCollection* const gctEtTot() const { return m_gctEtTot.get(); }  ///< GCT output: Total Et collection
  L1GctEtHadCollection* const gctEtHad() const {
    return m_gctEtHad.get();
  }  ///< GCT output: Hadronic transverse-energy (Ht) collection
  L1GctEtMissCollection* const gctEtMiss() const { return m_gctEtMiss.get(); }  ///< GCT output: Missing Et collection
  L1GctHtMissCollection* const gctHtMiss() const { return m_gctHtMiss.get(); }  ///< GCT output: Missing Ht collection
  L1GctJetCountsCollection* const gctJetCounts() const {
    return m_gctJetCounts.get();
  }  ///< DEPRECATED. ONLY GT NEEDS THIS.

  // Misc
  L1TriggerErrorCollection* const errors() const { return m_errors.get(); }  ///< Unpack error code collection.

private:
  edm::Event&
      m_event;  ///< The event the collections will be put into on destruction of the GctUnpackCollections instance.

  // Collections for storing GCT input data.
  std::unique_ptr<L1GctFibreCollection> m_gctFibres;  ///< Raw fibre input to the GCT.
  std::unique_ptr<L1CaloEmCollection> m_rctEm;        ///< Input electrons.
  std::unique_ptr<L1CaloRegionCollection> m_rctCalo;  ///< Input calo regions.

  // GCT intermediate data
  std::unique_ptr<L1GctInternEmCandCollection> m_gctInternEm;
  std::unique_ptr<L1GctInternJetDataCollection> m_gctInternJets;
  std::unique_ptr<L1GctInternEtSumCollection> m_gctInternEtSums;
  std::unique_ptr<L1GctInternHFDataCollection> m_gctInternHFData;
  std::unique_ptr<L1GctInternHtMissCollection> m_gctInternHtMiss;

  // GCT output data
  std::unique_ptr<L1GctEmCandCollection> m_gctIsoEm;
  std::unique_ptr<L1GctEmCandCollection> m_gctNonIsoEm;
  std::unique_ptr<L1GctJetCandCollection> m_gctCenJets;
  std::unique_ptr<L1GctJetCandCollection> m_gctForJets;
  std::unique_ptr<L1GctJetCandCollection> m_gctTauJets;
  std::unique_ptr<L1GctHFBitCountsCollection> m_gctHfBitCounts;
  std::unique_ptr<L1GctHFRingEtSumsCollection> m_gctHfRingEtSums;
  std::unique_ptr<L1GctEtTotalCollection> m_gctEtTot;
  std::unique_ptr<L1GctEtHadCollection> m_gctEtHad;
  std::unique_ptr<L1GctEtMissCollection> m_gctEtMiss;
  std::unique_ptr<L1GctHtMissCollection> m_gctHtMiss;
  std::unique_ptr<L1GctJetCountsCollection> m_gctJetCounts;  // DEPRECATED. ONLY GT NEEDS THIS.

  // Misc
  std::unique_ptr<L1TriggerErrorCollection> m_errors;
};

// Pretty print for the GctUnpackCollections sub-class
std::ostream& operator<<(std::ostream& os, const GctUnpackCollections& rhs);

#endif /* GctUnpackCollections_h */