HGCSiliconDetIdToROC

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
#ifndef DataFormats_ForwardDetId_HGCSiliconDetIdToROC_H
#define DataFormats_ForwardDetId_HGCSiliconDetIdToROC_H 1

#include "DataFormats/ForwardDetId/interface/HFNoseDetId.h"
#include "DataFormats/ForwardDetId/interface/HFNoseTriggerDetId.h"
#include "DataFormats/ForwardDetId/interface/HGCalTriggerDetId.h"
#include "DataFormats/ForwardDetId/interface/HGCSiliconDetId.h"
#include <iostream>
#include <map>
#include <utility>
#include <vector>
#include <functional>

class HGCSiliconDetIdToROC {
public:
  /** This translated TriggerDetId to ROC and viceversa for HGCSilicon*/
  HGCSiliconDetIdToROC();

  int getROCNumber(HGCalTriggerDetId const& id) const {
    return getROCNumber(id.triggerCellU(), id.triggerCellV(), id.type());
  }
  int getROCNumber(HGCSiliconDetId const& id) const {
    return getROCNumber(id.triggerCellU(), id.triggerCellV(), id.type());
  }
  int getROCNumber(HFNoseDetId const& id) const {
    return getROCNumber(id.triggerCellU(), id.triggerCellV(), id.type());
  }
  int getROCNumber(HFNoseTriggerDetId const& id) const {
    return getROCNumber(id.triggerCellU(), id.triggerCellV(), id.type());
  }
  int getROCNumber(int triggerCellU, int triggerCellV, int type) const;
  std::vector<std::pair<int, int> > getTriggerId(int roc, int type) const;
  void print() const;

private:
  std::map<std::pair<int, int>, int> triggerIdToROC_;
  std::map<int, std::vector<std::pair<int, int> > > triggerIdFromROC_;
};
#endif