CMS 3D CMS Logo

List of all members | Classes | Public Member Functions | Private Types | Private Member Functions | Private Attributes | Static Private Attributes
HcalTriggerPrimitiveAlgo Class Reference

#include <HcalTriggerPrimitiveAlgo.h>

Classes

struct  HFDetails
 
struct  HFUpgradeDetails
 

Public Member Functions

template<typename T , typename... Args>
void addDigis (const T &collection, const Args &... digis)
 
template<typename T >
void addDigis (const T &collection)
 
template<typename D >
void addDigis (const HcalDataFrameContainer< D > &collection)
 
 HcalTriggerPrimitiveAlgo (bool pf, const std::vector< double > &w, int latency, uint32_t FG_threshold, const std::vector< uint32_t > &FG_HF_thresholds, uint32_t ZS_threshold, int numberOfSamples, int numberOfPresamples, int numberOfFilterPresamplesHBQIE11, int numberOfFilterPresamplesHEQIE11, int numberOfSamplesHF, int numberOfPresamplesHF, int numberOfSamplesZDC, int numberOfPresamplesZDC, bool useTDCInMinBiasBits, uint32_t minSignalThreshold=0, uint32_t PMT_NoiseThreshold=0)
 
void overrideParameters (const edm::ParameterSet &ps)
 
template<typename... Digis>
void run (const HcalTPGCoder *incoder, const HcalTPGCompressor *outcoder, const HcalDbService *conditions, HcalTrigPrimDigiCollection &result, const HcalTrigTowerGeometry *trigTowerGeometry, float rctlsb, const HcalFeatureBit *LongvrsShortCut, const Digis &... digis)
 
void runFEFormatError (const FEDRawDataCollection *rawraw, const HcalElectronicsMap *emap, HcalTrigPrimDigiCollection &result)
 
void runZS (HcalTrigPrimDigiCollection &tp)
 
void setCodedVetoThreshold (int aieta, int codedVetoThreshold)
 
void setCodedVetoThresholds (const edm::ParameterSet &codedVetoThresholds)
 
void setFixSaturationFlag (bool fix_saturation)
 
void setNCTScaleShift (int)
 
void setNumFilterPresamplesHBQIE11 (int presamples)
 
void setNumFilterPresamplesHEQIE11 (int presamples)
 
void setPeakFinderAlgorithm (int algo)
 
void setRCTScaleShift (int)
 
void setUpgradeFlags (bool hb, bool he, bool hf)
 
void setWeightQIE11 (int aieta, int weight)
 
void setWeightsQIE11 (const edm::ParameterSet &weightsQIE11)
 
 ~HcalTriggerPrimitiveAlgo ()
 

Private Types

typedef std::map< HcalTrigTowerDetId, std::vector< bool > > FGbitMap
 
typedef std::vector< HcalFinegrainBit::TowerFGUpgradeContainer
 
typedef std::map< HcalTrigTowerDetId, FGUpgradeContainerFGUpgradeMap
 
typedef std::vector< HcalFinegrainBit::TowerTDCFGUpgradeTDCContainer
 
typedef std::map< HcalTrigTowerDetId, FGUpgradeTDCContainerFGUpgradeTDCMap
 
typedef std::map< HcalTrigTowerDetId, std::map< uint32_t, HFDetails > > HFDetailMap
 
typedef std::map< HcalTrigTowerDetId, std::map< uint32_t, std::array< HFUpgradeDetails, 4 > > > HFUpgradeDetailMap
 
typedef std::map< HcalTrigTowerDetId, std::vector< bool > > SatMap
 
typedef std::vector< IntegerCaloSamplesSumFGContainer
 
typedef std::map< HcalTrigTowerDetId, IntegerCaloSamplesSumMap
 
typedef std::map< HcalTrigTowerDetId, SumFGContainerTowerMapFGSum
 
typedef std::map< uint32_t, std::vector< bool > > TowerMapVeto
 

Private Member Functions

void addFG (const HcalTrigTowerDetId &id, std::vector< bool > &msb)
 
void addSignal (const HBHEDataFrame &frame)
 adds the signal to the map More...
 
void addSignal (const HFDataFrame &frame)
 
void addSignal (const QIE10DataFrame &frame)
 
void addSignal (const QIE11DataFrame &frame)
 
void addSignal (const IntegerCaloSamples &samples)
 
void addUpgradeFG (const HcalTrigTowerDetId &id, int depth, const std::vector< std::bitset< 2 >> &bits)
 
void addUpgradeTDCFG (const HcalTrigTowerDetId &id, const QIE11DataFrame &frame)
 
void analyze (IntegerCaloSamples &samples, HcalTriggerPrimitiveDigi &result)
 adds the actual digis More...
 
void analyzeHF (IntegerCaloSamples &samples, HcalTriggerPrimitiveDigi &result, const int hf_lumi_shift)
 
void analyzeHF2016 (const IntegerCaloSamples &SAMPLES, HcalTriggerPrimitiveDigi &result, const int HF_LUMI_SHIFT, const HcalFeatureBit *HCALFEM)
 
void analyzeHFQIE10 (const IntegerCaloSamples &SAMPLES, HcalTriggerPrimitiveDigi &result, const int HF_LUMI_SHIFT, const HcalFeatureBit *HCALFEM)
 
void analyzeQIE11 (IntegerCaloSamples &samples, std::vector< bool > sample_saturation, HcalTriggerPrimitiveDigi &result, const HcalFinegrainBit &fg_algo)
 
void analyzeZDC (IntegerCaloSamples &samples, HcalTriggerPrimitiveDigi &result)
 
bool needLegacyFG (const HcalTrigTowerDetId &id) const
 
bool needUpgradeID (const HcalTrigTowerDetId &id, int depth) const
 
bool passTDC (const QIE10DataFrame &digi, int ts) const
 
bool validChannel (const QIE10DataFrame &digi, int ts) const
 
bool validUpgradeFG (const HcalTrigTowerDetId &id, int depth) const
 

Private Attributes

std::array< int, 29 > codedVetoThresholds_
 
const HcalDbServiceconditions_
 
std::vector< uint32_t > FG_HF_thresholds_
 
uint32_t FG_threshold_
 
FGbitMap fgMap_
 
FGUpgradeMap fgUpgradeMap_
 
FGUpgradeTDCMap fgUpgradeTDCMap_
 
bool fix_saturation_ = false
 
TowerMapVeto HF_Veto
 
const HcaluLUTTPGCoderincoder_
 
int latency_
 
HcalFeatureBitLongvrsShortCut
 
uint32_t minSignalThreshold_
 
int NCTScaleShift
 
int numberOfFilterPresamplesHBQIE11_
 
int numberOfFilterPresamplesHEQIE11_
 
int numberOfPresamples_
 
int numberOfPresamplesHF_
 
int numberOfPresamplesZDC_
 
int numberOfSamples_
 
int numberOfSamplesHF_
 
int numberOfSamplesZDC_
 
const HcalTPGCompressoroutcoder_
 
bool override_adc_hf_ = false
 
uint32_t override_adc_hf_value_
 
edm::ParameterSet override_parameters_
 
bool override_tdc_hf_ = false
 
unsigned long long override_tdc_hf_value_
 
int peak_finder_algorithm_
 
bool peakfind_
 
uint32_t PMT_NoiseThreshold_
 
int RCTScaleShift
 
HFDetailMap theHFDetailMap
 
HFUpgradeDetailMap theHFUpgradeDetailMap
 
SatMap theSatMap
 
SumMap theSumMap
 
double theThreshold
 
TowerMapFGSum theTowerMapFGSum
 
const HcalTrigTowerGeometrytheTrigTowerGeometry
 
bool upgrade_hb_ = false
 
bool upgrade_he_ = false
 
bool upgrade_hf_ = false
 
bool useTDCInMinBiasBits_
 
std::vector< double > weights_
 
std::array< std::array< int, 2 >, 29 > weightsQIE11_
 
uint32_t ZS_threshold_
 
int ZS_threshold_I_
 

Static Private Attributes

static const int FIRST_DEPTH7_TOWER = 26
 
static const int FIRST_FINEGRAIN_TOWER = 30
 
static const int HBHE_OVERLAP_TOWER = 16
 
static const int LAST_FINEGRAIN_DEPTH = 6
 
static const int LAST_FINEGRAIN_TOWER = 28
 
static const int QIE10_LINEARIZATION_ET = HcaluLUTTPGCoder::QIE10_LUT_BITMASK
 
static const int QIE10_MAX_LINEARIZATION_ET = 0x7FF
 
static const int QIE10_ZDC_MAX_LINEARIZATION_ET = 0x3FF
 
static const int QIE11_LINEARIZATION_ET = HcaluLUTTPGCoder::QIE11_LUT_BITMASK
 
static const int QIE11_MAX_LINEARIZATION_ET = 0x7FF
 
static const int QIE8_LINEARIZATION_ET = HcaluLUTTPGCoder::QIE8_LUT_BITMASK
 

Detailed Description

Definition at line 27 of file HcalTriggerPrimitiveAlgo.h.

Member Typedef Documentation

◆ FGbitMap

typedef std::map<HcalTrigTowerDetId, std::vector<bool> > HcalTriggerPrimitiveAlgo::FGbitMap
private

Definition at line 220 of file HcalTriggerPrimitiveAlgo.h.

◆ FGUpgradeContainer

Definition at line 223 of file HcalTriggerPrimitiveAlgo.h.

◆ FGUpgradeMap

Definition at line 224 of file HcalTriggerPrimitiveAlgo.h.

◆ FGUpgradeTDCContainer

Definition at line 227 of file HcalTriggerPrimitiveAlgo.h.

◆ FGUpgradeTDCMap

Definition at line 228 of file HcalTriggerPrimitiveAlgo.h.

◆ HFDetailMap

typedef std::map<HcalTrigTowerDetId, std::map<uint32_t, HFDetails> > HcalTriggerPrimitiveAlgo::HFDetailMap
private

Definition at line 190 of file HcalTriggerPrimitiveAlgo.h.

◆ HFUpgradeDetailMap

typedef std::map<HcalTrigTowerDetId, std::map<uint32_t, std::array<HFUpgradeDetails, 4> > > HcalTriggerPrimitiveAlgo::HFUpgradeDetailMap
private

Definition at line 200 of file HcalTriggerPrimitiveAlgo.h.

◆ SatMap

typedef std::map<HcalTrigTowerDetId, std::vector<bool> > HcalTriggerPrimitiveAlgo::SatMap
private

Definition at line 181 of file HcalTriggerPrimitiveAlgo.h.

◆ SumFGContainer

Definition at line 203 of file HcalTriggerPrimitiveAlgo.h.

◆ SumMap

Definition at line 178 of file HcalTriggerPrimitiveAlgo.h.

◆ TowerMapFGSum

Definition at line 204 of file HcalTriggerPrimitiveAlgo.h.

◆ TowerMapVeto

typedef std::map<uint32_t, std::vector<bool> > HcalTriggerPrimitiveAlgo::TowerMapVeto
private

Definition at line 217 of file HcalTriggerPrimitiveAlgo.h.

Constructor & Destructor Documentation

◆ HcalTriggerPrimitiveAlgo()

HcalTriggerPrimitiveAlgo::HcalTriggerPrimitiveAlgo ( bool  pf,
const std::vector< double > &  w,
int  latency,
uint32_t  FG_threshold,
const std::vector< uint32_t > &  FG_HF_thresholds,
uint32_t  ZS_threshold,
int  numberOfSamples,
int  numberOfPresamples,
int  numberOfFilterPresamplesHBQIE11,
int  numberOfFilterPresamplesHEQIE11,
int  numberOfSamplesHF,
int  numberOfPresamplesHF,
int  numberOfSamplesZDC,
int  numberOfPresamplesZDC,
bool  useTDCInMinBiasBits,
uint32_t  minSignalThreshold = 0,
uint32_t  PMT_NoiseThreshold = 0 
)

Definition at line 23 of file HcalTriggerPrimitiveAlgo.cc.

References numberOfPresamples_, numberOfPresamplesHF_, numberOfPresamplesZDC_, numberOfSamples_, numberOfSamplesHF_, numberOfSamplesZDC_, peakfind_, ZS_threshold_, and ZS_threshold_I_.

40  : incoder_(nullptr),
41  outcoder_(nullptr),
42  theThreshold(0),
43  peakfind_(pf),
44  weights_(w),
55  numberOfSamplesZDC_(numberOfSamplesZDC),
56  numberOfPresamplesZDC_(numberOfPresamplesZDC),
58  minSignalThreshold_(minSignalThreshold),
59  PMT_NoiseThreshold_(PMT_NoiseThreshold),
60  NCTScaleShift(0),
61  RCTScaleShift(0),
64  //No peak finding setting (for Fastsim)
65  if (!peakfind_) {
66  numberOfSamples_ = 1;
72  }
73  // Switch to integer for comparisons - remove compiler warning
75 }
std::vector< uint32_t > FG_HF_thresholds_
T w() const
const HcalTPGCompressor * outcoder_
const HcaluLUTTPGCoder * incoder_

◆ ~HcalTriggerPrimitiveAlgo()

HcalTriggerPrimitiveAlgo::~HcalTriggerPrimitiveAlgo ( )

Definition at line 77 of file HcalTriggerPrimitiveAlgo.cc.

77 {}

Member Function Documentation

◆ addDigis() [1/3]

template<typename T , typename... Args>
void HcalTriggerPrimitiveAlgo::addDigis ( const T collection,
const Args &...  digis 
)
inline

Definition at line 59 of file HcalTriggerPrimitiveAlgo.h.

References universalConfigTemplate::collection.

Referenced by run().

59  {
61  addDigis(digis...);
62  };
void addDigis(const T &collection, const Args &... digis)

◆ addDigis() [2/3]

template<typename T >
void HcalTriggerPrimitiveAlgo::addDigis ( const T collection)
inline

Definition at line 65 of file HcalTriggerPrimitiveAlgo.h.

References addSignal(), and universalConfigTemplate::collection.

65  {
66  for (const auto& digi : collection) {
67  addSignal(digi);
68  }
69  };
void addSignal(const HBHEDataFrame &frame)
adds the signal to the map

◆ addDigis() [3/3]

template<typename D >
void HcalTriggerPrimitiveAlgo::addDigis ( const HcalDataFrameContainer< D > &  collection)
inline

Definition at line 72 of file HcalTriggerPrimitiveAlgo.h.

References addSignal(), universalConfigTemplate::collection, and mps_fire::i.

72  {
73  for (auto i = collection.begin(); i != collection.end(); ++i) {
74  D digi(*i);
75  addSignal(digi);
76  }
77  };
DecomposeProduct< arg, typename Div::arg > D
Definition: Factorize.h:141
void addSignal(const HBHEDataFrame &frame)
adds the signal to the map

◆ addFG()

void HcalTriggerPrimitiveAlgo::addFG ( const HcalTrigTowerDetId id,
std::vector< bool > &  msb 
)
private

Definition at line 980 of file HcalTriggerPrimitiveAlgo.cc.

References fgMap_, mps_fire::i, and l1ctLayer2EG_cff::id.

Referenced by addSignal(), and addUpgradeFG().

980  {
981  FGbitMap::iterator itr = fgMap_.find(id);
982  if (itr != fgMap_.end()) {
983  std::vector<bool>& _msb = itr->second;
984  for (size_t i = 0; i < msb.size(); ++i)
985  _msb[i] = _msb[i] || msb[i];
986  } else
987  fgMap_[id] = msb;
988 }

◆ addSignal() [1/5]

void HcalTriggerPrimitiveAlgo::addSignal ( const HBHEDataFrame frame)
private

adds the signal to the map

Definition at line 100 of file HcalTriggerPrimitiveAlgo.cc.

References HcaluLUTTPGCoder::adc2Linear(), addFG(), cms::cuda::assert(), mps_fire::i, incoder_, HcaluLUTTPGCoder::lookupMSB(), theTrigTowerGeometry, and HcalTrigTowerGeometry::towerIds().

Referenced by addDigis(), and addSignal().

100  {
101  // TODO: Need to add support for seperate 28, 29 in HE
102  //Hack for 300_pre10, should be removed.
103  if (frame.id().depth() == 5)
104  return;
105 
106  std::vector<HcalTrigTowerDetId> ids = theTrigTowerGeometry->towerIds(frame.id());
107  assert(ids.size() == 1 || ids.size() == 2);
108  IntegerCaloSamples samples1(ids[0], int(frame.size()));
109 
110  samples1.setPresamples(frame.presamples());
111  incoder_->adc2Linear(frame, samples1);
112 
113  std::vector<bool> msb;
114  incoder_->lookupMSB(frame, msb);
115 
116  if (ids.size() == 2) {
117  // make a second trigprim for the other one, and split the energy
118  IntegerCaloSamples samples2(ids[1], samples1.size());
119  for (int i = 0; i < samples1.size(); ++i) {
120  samples1[i] = uint32_t(samples1[i] * 0.5);
121  samples2[i] = samples1[i];
122  }
123  samples2.setPresamples(frame.presamples());
124  addSignal(samples2);
125  addFG(ids[1], msb);
126  }
127  addSignal(samples1);
128  addFG(ids[0], msb);
129 }
void lookupMSB(const HBHEDataFrame &df, std::vector< bool > &msb) const
void addFG(const HcalTrigTowerDetId &id, std::vector< bool > &msb)
assert(be >=bs)
const HcalTrigTowerGeometry * theTrigTowerGeometry
void adc2Linear(const HBHEDataFrame &df, IntegerCaloSamples &ics) const override
const HcaluLUTTPGCoder * incoder_
void addSignal(const HBHEDataFrame &frame)
adds the signal to the map
std::vector< HcalTrigTowerDetId > towerIds(const HcalDetId &cellId) const
the mapping to and from DetIds

◆ addSignal() [2/5]

void HcalTriggerPrimitiveAlgo::addSignal ( const HFDataFrame frame)
private

Definition at line 131 of file HcalTriggerPrimitiveAlgo.cc.

References HcaluLUTTPGCoder::adc2Linear(), addSignal(), amptDefault_cfi::frame, HF_Veto, mps_fire::i, incoder_, ALPAKA_ACCELERATOR_NAMESPACE::vertexFinder::it, minSignalThreshold_, EgammaValidation_cff::samples, IntegerCaloSamples::setPresamples(), theHFDetailMap, theTowerMapFGSum, theTrigTowerGeometry, HcalTrigTowerGeometry::towerIds(), and HcalTrigTowerDetId::version().

131  {
132  if (frame.id().depth() == 1 || frame.id().depth() == 2) {
133  std::vector<HcalTrigTowerDetId> ids = theTrigTowerGeometry->towerIds(frame.id());
134  std::vector<HcalTrigTowerDetId>::const_iterator it;
135  for (it = ids.begin(); it != ids.end(); ++it) {
136  HcalTrigTowerDetId trig_tower_id = *it;
137  IntegerCaloSamples samples(trig_tower_id, frame.size());
138  samples.setPresamples(frame.presamples());
140 
141  // Don't add to final collection yet
142  // HF PMT veto sum is calculated in analyzerHF()
143  IntegerCaloSamples zero_samples(trig_tower_id, frame.size());
144  zero_samples.setPresamples(frame.presamples());
145  addSignal(zero_samples);
146 
147  // Pre-LS1 Configuration
148  if (trig_tower_id.version() == 0) {
149  // Mask off depths: fgid is the same for both depths
150  uint32_t fgid = (frame.id().maskDepth());
151 
152  if (theTowerMapFGSum.find(trig_tower_id) == theTowerMapFGSum.end()) {
153  SumFGContainer sumFG;
154  theTowerMapFGSum.insert(std::pair<HcalTrigTowerDetId, SumFGContainer>(trig_tower_id, sumFG));
155  }
156 
157  SumFGContainer& sumFG = theTowerMapFGSum[trig_tower_id];
158  SumFGContainer::iterator sumFGItr;
159  for (sumFGItr = sumFG.begin(); sumFGItr != sumFG.end(); ++sumFGItr) {
160  if (sumFGItr->id() == fgid) {
161  break;
162  }
163  }
164  // If find
165  if (sumFGItr != sumFG.end()) {
166  for (int i = 0; i < samples.size(); ++i) {
167  (*sumFGItr)[i] += samples[i];
168  }
169  } else {
170  //Copy samples (change to fgid)
171  IntegerCaloSamples sumFGSamples(DetId(fgid), samples.size());
172  sumFGSamples.setPresamples(samples.presamples());
173  for (int i = 0; i < samples.size(); ++i) {
174  sumFGSamples[i] = samples[i];
175  }
176  sumFG.push_back(sumFGSamples);
177  }
178 
179  // set veto to true if Long or Short less than threshold
180  if (HF_Veto.find(fgid) == HF_Veto.end()) {
181  vector<bool> vetoBits(samples.size(), false);
182  HF_Veto[fgid] = vetoBits;
183  }
184  for (int i = 0; i < samples.size(); ++i) {
185  if (samples[i] < minSignalThreshold_) {
186  HF_Veto[fgid][i] = true;
187  }
188  }
189  }
190  // HF 1x1
191  else if (trig_tower_id.version() == 1) {
192  uint32_t fgid = (frame.id().maskDepth());
193  HFDetails& details = theHFDetailMap[trig_tower_id][fgid];
194  // Check the frame type to determine long vs short
195  if (frame.id().depth() == 1) { // Long
196  details.long_fiber = samples;
197  details.LongDigi = frame;
198  } else if (frame.id().depth() == 2) { // Short
199  details.short_fiber = samples;
200  details.ShortDigi = frame;
201  } else {
202  // Neither long nor short... So we have no idea what to do
203  edm::LogWarning("HcalTPAlgo") << "Unable to figure out what to do with data frame for " << frame.id();
204  return;
205  }
206  }
207  // Uh oh, we are in a bad/unknown state! Things will start crashing.
208  else {
209  return;
210  }
211  }
212  }
213 }
void setPresamples(int pre)
set presample information
std::vector< IntegerCaloSamples > SumFGContainer
const HcalTrigTowerGeometry * theTrigTowerGeometry
Definition: helper.h:56
Definition: DetId.h:17
void adc2Linear(const HBHEDataFrame &df, IntegerCaloSamples &ics) const override
const HcaluLUTTPGCoder * incoder_
Log< level::Warning, false > LogWarning
int version() const
get the version code for the trigger tower
void addSignal(const HBHEDataFrame &frame)
adds the signal to the map
std::vector< HcalTrigTowerDetId > towerIds(const HcalDetId &cellId) const
the mapping to and from DetIds

◆ addSignal() [3/5]

void HcalTriggerPrimitiveAlgo::addSignal ( const QIE10DataFrame frame)
private

Definition at line 215 of file HcalTriggerPrimitiveAlgo.cc.

References HcaluLUTTPGCoder::adc2Linear(), addSignal(), DetId::Calo, hcalRecHitTable_cff::detId, HcalZDCDetId::EM, amptDefault_cfi::frame, HcalZDCDetId::HAD, DetId::Hcal, HcalForward, mps_fire::i, l1ctLayer2EG_cff::id, heavyIonCSV_trainingSettings::idx, incoder_, HcaluLUTTPGCoder::lookupMSB(), passTDC(), EgammaValidation_cff::samples, IntegerCaloSamples::setPresamples(), HcalZDCDetId::SubdetectorId, theHFUpgradeDetailMap, theTrigTowerGeometry, HcalTrigTowerGeometry::towerIds(), HcalTrigTowerGeometry::towerIds_ZDC(), validChannel(), and BeamSplash_cfg::version.

215  {
216  //HcalDetId detId = frame.detid();
217  DetId detId = DetId(frame.detid());
218  if (detId.det() == DetId::Hcal) {
219  HcalDetId detId = frame.detid();
220  // prevent QIE10 calibration channels from entering TP emulation
221  if (detId.subdet() != HcalForward)
222  return;
223 
224  auto ids = theTrigTowerGeometry->towerIds(frame.id());
225  for (const auto& id : ids) {
226  if (id.version() == 0) {
227  edm::LogError("HcalTPAlgo") << "Encountered QIE10 data frame mapped to TP version 0:" << id;
228  continue;
229  }
230  int nsamples = frame.samples();
231 
232  IntegerCaloSamples samples(id, nsamples);
233  samples.setPresamples(frame.presamples());
234  incoder_->adc2Linear(frame, samples, false);
235 
236  // Don't add to final collection yet
237  // HF PMT veto sum is calculated in analyzerHF()
238  IntegerCaloSamples zero_samples(id, nsamples);
239  zero_samples.setPresamples(frame.presamples());
240  addSignal(zero_samples);
241 
242  auto fid = HcalDetId(frame.id());
243  auto& details = theHFUpgradeDetailMap[id][fid.maskDepth()];
244  auto& detail = details[fid.depth() - 1];
245  detail.samples = samples;
246  detail.digi = frame;
247  detail.validity.resize(nsamples);
248  detail.passTDC.resize(nsamples);
249  incoder_->lookupMSB(frame, detail.fgbits);
250  for (int idx = 0; idx < nsamples; ++idx) {
251  detail.validity[idx] = validChannel(frame, idx);
252  detail.passTDC[idx] = passTDC(frame, idx);
253  }
254  }
255  } else if (detId.det() == DetId::Calo && detId.subdetId() == HcalZDCDetId::SubdetectorId) {
256  HcalZDCDetId detId = frame.detid();
257  if (detId.section() != HcalZDCDetId::EM && detId.section() != HcalZDCDetId::HAD) {
258  return;
259  }
260 
261  auto ids = theTrigTowerGeometry->towerIds_ZDC(frame.id());
262  for (const auto& id : ids) {
263  int nsamples = frame.samples();
264 
265  IntegerCaloSamples samples(id, nsamples);
266  IntegerCaloSamples samples_PUsub(id, nsamples);
267 
268  samples.setPresamples(frame.presamples());
269  samples_PUsub.setPresamples(frame.presamples());
270 
271  incoder_->adc2Linear(frame, samples, false);
272  incoder_->adc2Linear(frame, samples_PUsub, true);
273 
274  for (int i = 1; i < samples.size(); ++i) {
275  if (samples_PUsub[i - 1] > samples[i])
276  samples[i] = 0;
277  else
278  samples[i] -= samples_PUsub[i - 1];
279  }
280 
282  }
283  }
284 }
HFUpgradeDetailMap theHFUpgradeDetailMap
void lookupMSB(const HBHEDataFrame &df, std::vector< bool > &msb) const
Log< level::Error, false > LogError
const HcalTrigTowerGeometry * theTrigTowerGeometry
Definition: helper.h:56
Definition: DetId.h:17
void adc2Linear(const HBHEDataFrame &df, IntegerCaloSamples &ics) const override
const HcaluLUTTPGCoder * incoder_
bool passTDC(const QIE10DataFrame &digi, int ts) const
static constexpr int32_t SubdetectorId
Definition: HcalZDCDetId.h:35
bool validChannel(const QIE10DataFrame &digi, int ts) const
void addSignal(const HBHEDataFrame &frame)
adds the signal to the map
std::vector< HcalTrigTowerDetId > towerIds(const HcalDetId &cellId) const
the mapping to and from DetIds
std::vector< HcalTrigTowerDetId > towerIds_ZDC(const HcalZDCDetId &cellId) const

◆ addSignal() [4/5]

void HcalTriggerPrimitiveAlgo::addSignal ( const QIE11DataFrame frame)
private

Definition at line 286 of file HcalTriggerPrimitiveAlgo.cc.

References HcaluLUTTPGCoder::adc2Linear(), addSignal(), addUpgradeFG(), addUpgradeTDCFG(), cms::cuda::assert(), hcalRecHitTable_cff::detId, HcalBarrel, HcalEndcap, mps_fire::i, incoder_, HcaluLUTTPGCoder::lookupMSB(), theTrigTowerGeometry, and HcalTrigTowerGeometry::towerIds().

286  {
287  HcalDetId detId(frame.id());
288  // prevent QIE11 calibration channels from entering TP emulation
289  if (detId.subdet() != HcalEndcap && detId.subdet() != HcalBarrel)
290  return;
291 
292  std::vector<HcalTrigTowerDetId> ids = theTrigTowerGeometry->towerIds(detId);
293  assert(ids.size() == 1 || ids.size() == 2);
294  IntegerCaloSamples samples1(ids[0], int(frame.samples()));
295 
296  samples1.setPresamples(frame.presamples());
297  incoder_->adc2Linear(frame, samples1);
298 
299  std::vector<std::bitset<2>> msb(frame.samples(), 0);
300  incoder_->lookupMSB(frame, msb);
301 
302  if (ids.size() == 2) {
303  // make a second trigprim for the other one, and share the energy
304  IntegerCaloSamples samples2(ids[1], samples1.size());
305  for (int i = 0; i < samples1.size(); ++i) {
306  samples1[i] = uint32_t(samples1[i]);
307  samples2[i] = samples1[i];
308  }
309  samples2.setPresamples(frame.presamples());
310  addSignal(samples2);
311  addUpgradeFG(ids[1], detId.depth(), msb);
312  addUpgradeTDCFG(ids[1], frame);
313  }
314  addSignal(samples1);
315  addUpgradeFG(ids[0], detId.depth(), msb);
316  addUpgradeTDCFG(ids[0], frame);
317 }
void addUpgradeTDCFG(const HcalTrigTowerDetId &id, const QIE11DataFrame &frame)
void lookupMSB(const HBHEDataFrame &df, std::vector< bool > &msb) const
assert(be >=bs)
const HcalTrigTowerGeometry * theTrigTowerGeometry
void adc2Linear(const HBHEDataFrame &df, IntegerCaloSamples &ics) const override
void addUpgradeFG(const HcalTrigTowerDetId &id, int depth, const std::vector< std::bitset< 2 >> &bits)
const HcaluLUTTPGCoder * incoder_
void addSignal(const HBHEDataFrame &frame)
adds the signal to the map
std::vector< HcalTrigTowerDetId > towerIds(const HcalDetId &cellId) const
the mapping to and from DetIds

◆ addSignal() [5/5]

void HcalTriggerPrimitiveAlgo::addSignal ( const IntegerCaloSamples samples)
private

Definition at line 319 of file HcalTriggerPrimitiveAlgo.cc.

References cms::cuda::assert(), fix_saturation_, mps_fire::i, l1ctLayer2EG_cff::id, QIE11_LINEARIZATION_ET, EgammaValidation_cff::samples, theSatMap, and theSumMap.

319  {
321  SumMap::iterator itr = theSumMap.find(id);
322 
323  if (itr == theSumMap.end()) {
324  theSumMap.insert(std::make_pair(id, samples));
325  } else {
326  // wish CaloSamples had a +=
327  for (int i = 0; i < samples.size(); ++i) {
328  (itr->second)[i] += samples[i];
329  }
330  }
331 
332  // if fix_saturation == true, keep track of tower with saturated input LUT
333  if (fix_saturation_) {
334  SatMap::iterator itr_sat = theSatMap.find(id);
335 
336  assert((itr == theSumMap.end()) == (itr_sat == theSatMap.end()));
337 
338  if (itr_sat == theSatMap.end()) {
339  vector<bool> check_sat;
340  for (int i = 0; i < samples.size(); ++i) {
341  if (!(samples[i] < QIE11_LINEARIZATION_ET)) {
342  check_sat.push_back(true);
343  } else
344  check_sat.push_back(false);
345  }
346  theSatMap.insert(std::make_pair(id, check_sat));
347  } else {
348  for (int i = 0; i < samples.size(); ++i) {
349  if (!(samples[i] < QIE11_LINEARIZATION_ET))
350  (itr_sat->second)[i] = true;
351  }
352  }
353  }
354 }
assert(be >=bs)

◆ addUpgradeFG()

void HcalTriggerPrimitiveAlgo::addUpgradeFG ( const HcalTrigTowerDetId id,
int  depth,
const std::vector< std::bitset< 2 >> &  bits 
)
private

Definition at line 1019 of file HcalTriggerPrimitiveAlgo.cc.

References addFG(), ALPAKA_ACCELERATOR_NAMESPACE::pixelClustering::pixelStatus::bits, hcalRecHitTable_cff::depth, fgUpgradeMap_, mps_fire::i, ALPAKA_ACCELERATOR_NAMESPACE::vertexFinder::it, needLegacyFG(), needUpgradeID(), and validUpgradeFG().

Referenced by addSignal().

1021  {
1022  if (not validUpgradeFG(id, depth)) {
1023  if (needLegacyFG(id)) {
1024  std::vector<bool> pseudo(bits.size(), false);
1025  addFG(id, pseudo);
1026  } else if (needUpgradeID(id, depth)) {
1027  // If the tower id is not in the map yet
1028  // then for safety's sake add it, otherwise, no need
1029  // Likewise, we're here with non-fg depth 7 so the bits are not to be added
1030  auto it = fgUpgradeMap_.find(id);
1031  if (it == fgUpgradeMap_.end()) {
1032  FGUpgradeContainer element;
1033  element.resize(bits.size());
1034  fgUpgradeMap_.insert(std::make_pair(id, element));
1035  }
1036  }
1037 
1038  return;
1039  }
1040 
1041  auto it = fgUpgradeMap_.find(id);
1042  if (it == fgUpgradeMap_.end()) {
1043  FGUpgradeContainer element;
1044  element.resize(bits.size());
1045  it = fgUpgradeMap_.insert(std::make_pair(id, element)).first;
1046  }
1047  for (unsigned int i = 0; i < bits.size(); ++i) {
1048  it->second[i][0][depth - 1] = bits[i][0];
1049  it->second[i][1][depth - 1] = bits[i][1];
1050  }
1051 }
bool validUpgradeFG(const HcalTrigTowerDetId &id, int depth) const
bool needLegacyFG(const HcalTrigTowerDetId &id) const
void addFG(const HcalTrigTowerDetId &id, std::vector< bool > &msb)
bool needUpgradeID(const HcalTrigTowerDetId &id, int depth) const
std::vector< HcalFinegrainBit::Tower > FGUpgradeContainer

◆ addUpgradeTDCFG()

void HcalTriggerPrimitiveAlgo::addUpgradeTDCFG ( const HcalTrigTowerDetId id,
const QIE11DataFrame frame 
)
private

Definition at line 1053 of file HcalTriggerPrimitiveAlgo.cc.

References HcaluLUTTPGCoder::adc2Linear(), cms::cuda::assert(), hcalRecHitTable_cff::detId, fgUpgradeTDCMap_, HcaluLUTTPGCoder::group0FGbits(), HcalBarrel, HcalEndcap, mps_fire::i, incoder_, ALPAKA_ACCELERATOR_NAMESPACE::vertexFinder::it, theTrigTowerGeometry, and HcalTrigTowerGeometry::towerIds().

Referenced by addSignal().

1053  {
1054  HcalDetId detId(frame.id());
1055  if (detId.subdet() != HcalEndcap && detId.subdet() != HcalBarrel)
1056  return;
1057 
1058  std::vector<HcalTrigTowerDetId> ids = theTrigTowerGeometry->towerIds(detId);
1059  assert(ids.size() == 1 || ids.size() == 2);
1060  IntegerCaloSamples samples1(ids[0], int(frame.samples()));
1061  samples1.setPresamples(frame.presamples());
1062  incoder_->adc2Linear(frame, samples1); // use linearization LUT
1063  std::vector<unsigned short> bits12_15 = incoder_->group0FGbits(frame); // get 4 energy bits (12-15) from group 0 LUT
1064 
1065  bool is_compressed = false;
1066  if (detId.subdet() == HcalBarrel) {
1067  is_compressed = (frame.flavor() == 3);
1068  // 0 if frame.flavor is 0 (uncompressed), 1 if frame.flavor is 3 (compressed)
1069  }
1070 
1071  auto it = fgUpgradeTDCMap_.find(id);
1072  if (it == fgUpgradeTDCMap_.end()) {
1073  FGUpgradeTDCContainer element;
1074  element.resize(frame.samples());
1075  it = fgUpgradeTDCMap_.insert(std::make_pair(id, element)).first;
1076  }
1077  for (int i = 0; i < frame.samples(); i++) {
1078  it->second[i][detId.depth() - 1] =
1079  std::make_pair(std::make_pair(bits12_15[i], is_compressed), std::make_pair(frame[i].tdc(), samples1[i]));
1080  }
1081 }
std::vector< unsigned short > group0FGbits(const QIE11DataFrame &df) const
assert(be >=bs)
const HcalTrigTowerGeometry * theTrigTowerGeometry
std::vector< HcalFinegrainBit::TowerTDC > FGUpgradeTDCContainer
void adc2Linear(const HBHEDataFrame &df, IntegerCaloSamples &ics) const override
const HcaluLUTTPGCoder * incoder_
std::vector< HcalTrigTowerDetId > towerIds(const HcalDetId &cellId) const
the mapping to and from DetIds

◆ analyze()

void HcalTriggerPrimitiveAlgo::analyze ( IntegerCaloSamples samples,
HcalTriggerPrimitiveDigi result 
)
private

adds the actual digis

Definition at line 356 of file HcalTriggerPrimitiveAlgo.cc.

References HcalTPGCompressor::compress(), fgMap_, mps_fire::i, heavyIonCSV_trainingSettings::idx, createfilelist::int, numberOfPresamples_, numberOfSamples_, outcoder_, convertSQLitetoXML_cfg::output, peak_finder_algorithm_, peakfind_, QIE8_LINEARIZATION_ET, mps_fire::result, EgammaValidation_cff::samples, edm::shift, theThreshold, and weights_.

Referenced by run().

356  {
357  int shrink = weights_.size() - 1;
358  std::vector<bool>& msb = fgMap_[samples.id()];
359  IntegerCaloSamples sum(samples.id(), samples.size());
360 
361  //slide algo window
362  for (int ibin = 0; ibin < int(samples.size()) - shrink; ++ibin) {
363  int algosumvalue = 0;
364  for (unsigned int i = 0; i < weights_.size(); i++) {
365  //add up value * scale factor
366  algosumvalue += int(samples[ibin + i] * weights_[i]);
367  }
368  if (algosumvalue < 0)
369  sum[ibin] = 0; // low-side
370  //high-side
371  //else if (algosumvalue>QIE8_LINEARIZATION_ET) sum[ibin]=QIE8_LINEARIZATION_ET;
372  else
373  sum[ibin] = algosumvalue; //assign value to sum[]
374  }
375 
376  // Align digis and TP
377  int dgPresamples = samples.presamples();
378  int tpPresamples = numberOfPresamples_;
379  int shift = dgPresamples - tpPresamples;
380  int dgSamples = samples.size();
381  int tpSamples = numberOfSamples_;
382  if (peakfind_) {
383  if ((shift < shrink) || (shift + tpSamples + shrink > dgSamples - (peak_finder_algorithm_ - 1))) {
384  edm::LogInfo("HcalTriggerPrimitiveAlgo::analyze")
385  << "TP presample or size from the configuration file is out of the accessible range. Using digi values from "
386  "data instead...";
387  shift = shrink;
388  tpPresamples = dgPresamples - shrink;
389  tpSamples = dgSamples - (peak_finder_algorithm_ - 1) - shrink - shift;
390  }
391  }
392 
393  std::vector<int> finegrain(tpSamples, false);
394 
395  IntegerCaloSamples output(samples.id(), tpSamples);
396  output.setPresamples(tpPresamples);
397 
398  for (int ibin = 0; ibin < tpSamples; ++ibin) {
399  // ibin - index for output TP
400  // idx - index for samples + shift
401  int idx = ibin + shift;
402 
403  //Peak finding
404  if (peakfind_) {
405  bool isPeak = false;
406  switch (peak_finder_algorithm_) {
407  case 1:
408  isPeak = (samples[idx] > samples[idx - 1] && samples[idx] >= samples[idx + 1] && samples[idx] > theThreshold);
409  break;
410  case 2:
411  isPeak = (sum[idx] > sum[idx - 1] && sum[idx] >= sum[idx + 1] && sum[idx] > theThreshold);
412  break;
413  default:
414  break;
415  }
416 
417  if (isPeak) {
418  output[ibin] = std::min<unsigned int>(sum[idx], QIE8_LINEARIZATION_ET);
419  finegrain[ibin] = msb[idx];
420  }
421  // Not a peak
422  else
423  output[ibin] = 0;
424  } else { // No peak finding, just output running sum
425  output[ibin] = std::min<unsigned int>(sum[idx], QIE8_LINEARIZATION_ET);
426  finegrain[ibin] = msb[idx];
427  }
428 
429  // Only Pegged for 1-TS algo.
430  if (peak_finder_algorithm_ == 1) {
433  }
434  }
435  outcoder_->compress(output, finegrain, result);
436 }
const HcalTPGCompressor * outcoder_
void compress(const IntegerCaloSamples &ics, const std::vector< int > &fineGrain, HcalTriggerPrimitiveDigi &digi) const
Log< level::Info, false > LogInfo
static unsigned int const shift
Definition: output.py:1

◆ analyzeHF()

void HcalTriggerPrimitiveAlgo::analyzeHF ( IntegerCaloSamples samples,
HcalTriggerPrimitiveDigi result,
const int  hf_lumi_shift 
)
private

Definition at line 655 of file HcalTriggerPrimitiveAlgo.cc.

References cms::cuda::assert(), HcalTPGCompressor::compress(), hcalRecHitTable_cff::detId, FG_threshold_, HF_Veto, heavyIonCSV_trainingSettings::idx, createfilelist::int, numberOfPresamplesHF_, numberOfSamplesHF_, outcoder_, convertSQLitetoXML_cfg::output, PMT_NoiseThreshold_, QIE8_LINEARIZATION_ET, mps_fire::result, EgammaValidation_cff::samples, edm::shift, theTowerMapFGSum, and PbPb_ZMuSkimMuonDPG_cff::veto.

Referenced by run().

657  {
659 
660  // Align digis and TP
661  int dgPresamples = samples.presamples();
662  int tpPresamples = numberOfPresamplesHF_;
663  int shift = dgPresamples - tpPresamples;
664  int dgSamples = samples.size();
665  int tpSamples = numberOfSamplesHF_;
666  if (shift < 0 || shift + tpSamples > dgSamples) {
667  edm::LogInfo("HcalTriggerPrimitiveAlgo::analyzeHF")
668  << "TP presample or size from the configuration file is out of the accessible range. Using digi values from "
669  "data instead...";
670  tpPresamples = dgPresamples;
671  shift = 0;
672  tpSamples = dgSamples;
673  }
674 
675  std::vector<int> finegrain(tpSamples, false);
676 
677  TowerMapFGSum::const_iterator tower2fg = theTowerMapFGSum.find(detId);
678  assert(tower2fg != theTowerMapFGSum.end());
679 
680  const SumFGContainer& sumFG = tower2fg->second;
681  // Loop over all L+S pairs that mapped from samples.id()
682  // Note: 1 samples.id() = 6 x (L+S) without noZS
683  for (SumFGContainer::const_iterator sumFGItr = sumFG.begin(); sumFGItr != sumFG.end(); ++sumFGItr) {
684  const std::vector<bool>& veto = HF_Veto[sumFGItr->id().rawId()];
685  for (int ibin = 0; ibin < tpSamples; ++ibin) {
686  int idx = ibin + shift;
687  // if not vetod, add L+S to total sum and calculate FG
688  bool vetoed = idx < int(veto.size()) && veto[idx];
689  if (!(vetoed && (*sumFGItr)[idx] > PMT_NoiseThreshold_)) {
690  samples[idx] += (*sumFGItr)[idx];
691  finegrain[ibin] = (finegrain[ibin] || (*sumFGItr)[idx] >= FG_threshold_);
692  }
693  }
694  }
695 
696  IntegerCaloSamples output(samples.id(), tpSamples);
697  output.setPresamples(tpPresamples);
698 
699  for (int ibin = 0; ibin < tpSamples; ++ibin) {
700  int idx = ibin + shift;
701  output[ibin] = samples[idx] >> hf_lumi_shift;
702  static const int MAX_OUTPUT = QIE8_LINEARIZATION_ET; // QIE8_LINEARIZATION_ET = 1023
703  if (output[ibin] > MAX_OUTPUT)
704  output[ibin] = MAX_OUTPUT;
705  }
706  outcoder_->compress(output, finegrain, result);
707 }
const HcalTPGCompressor * outcoder_
assert(be >=bs)
std::vector< IntegerCaloSamples > SumFGContainer
void compress(const IntegerCaloSamples &ics, const std::vector< int > &fineGrain, HcalTriggerPrimitiveDigi &digi) const
Log< level::Info, false > LogInfo
static unsigned int const shift
Definition: output.py:1

◆ analyzeHF2016()

void HcalTriggerPrimitiveAlgo::analyzeHF2016 ( const IntegerCaloSamples SAMPLES,
HcalTriggerPrimitiveDigi result,
const int  HF_LUMI_SHIFT,
const HcalFeatureBit HCALFEM 
)
private

Definition at line 709 of file HcalTriggerPrimitiveAlgo.cc.

References cms::cuda::assert(), newFWLiteAna::bin, HcalTPGCompressor::compress(), hcalRecHitTable_cff::detId, FG_HF_thresholds_, HcalFeatureBit::fineGrainbit(), FIRST_FINEGRAIN_TOWER, ALPAKA_ACCELERATOR_NAMESPACE::vertexFinder::it, B2GTnPMonitor_cfi::item, SiStripPI::min, numberOfPresamplesHF_, numberOfSamplesHF_, outcoder_, convertSQLitetoXML_cfg::output, QIE8_LINEARIZATION_ET, mps_fire::result, EgammaValidation_cff::samples, and theHFDetailMap.

Referenced by run().

712  {
713  // Align digis and TP
714  const int SHIFT = samples.presamples() - numberOfPresamplesHF_;
715  assert(SHIFT >= 0);
716  assert((SHIFT + numberOfSamplesHF_) <= samples.size());
717 
718  // Try to find the HFDetails from the map corresponding to our samples
719  const HcalTrigTowerDetId detId(samples.id());
720  HFDetailMap::const_iterator it = theHFDetailMap.find(detId);
721  // Missing values will give an empty digi
722  if (it == theHFDetailMap.end()) {
723  return;
724  }
725 
726  std::vector<std::bitset<2>> finegrain(numberOfSamplesHF_, false);
727 
728  // Set up out output of IntergerCaloSamples
730  output.setPresamples(numberOfPresamplesHF_);
731 
732  for (const auto& item : it->second) {
733  auto& details = item.second;
734  for (int ibin = 0; ibin < numberOfSamplesHF_; ++ibin) {
735  const int IDX = ibin + SHIFT;
736  int long_fiber_val = 0;
737  if (IDX < details.long_fiber.size()) {
738  long_fiber_val = details.long_fiber[IDX];
739  }
740  int short_fiber_val = 0;
741  if (IDX < details.short_fiber.size()) {
742  short_fiber_val = details.short_fiber[IDX];
743  }
744  output[ibin] += (long_fiber_val + short_fiber_val);
745 
746  uint32_t ADCLong = details.LongDigi[ibin].adc();
747  uint32_t ADCShort = details.ShortDigi[ibin].adc();
748 
749  if (details.LongDigi.id().ietaAbs() >= FIRST_FINEGRAIN_TOWER) {
750  finegrain[ibin][1] = (ADCLong > FG_HF_thresholds_[0] || ADCShort > FG_HF_thresholds_[0]);
751 
752  if (embit != nullptr)
753  finegrain[ibin][0] = embit->fineGrainbit(details.ShortDigi, details.LongDigi, ibin);
754  }
755  }
756  }
757 
758  for (int bin = 0; bin < numberOfSamplesHF_; ++bin) {
759  static const unsigned int MAX_OUTPUT = QIE8_LINEARIZATION_ET; // QIE8_LINEARIZATION_ET = 1023
760  output[bin] = min({MAX_OUTPUT, output[bin] >> hf_lumi_shift});
761  }
762 
763  std::vector<int> finegrain_converted;
764  finegrain_converted.reserve(finegrain.size());
765  for (const auto& fg : finegrain)
766  finegrain_converted.push_back(fg.to_ulong());
767  outcoder_->compress(output, finegrain_converted, result);
768 }
std::vector< uint32_t > FG_HF_thresholds_
const HcalTPGCompressor * outcoder_
assert(be >=bs)
void compress(const IntegerCaloSamples &ics, const std::vector< int > &fineGrain, HcalTriggerPrimitiveDigi &digi) const
Definition: helper.h:56
Definition: output.py:1

◆ analyzeHFQIE10()

void HcalTriggerPrimitiveAlgo::analyzeHFQIE10 ( const IntegerCaloSamples SAMPLES,
HcalTriggerPrimitiveDigi result,
const int  HF_LUMI_SHIFT,
const HcalFeatureBit HCALFEM 
)
private

Definition at line 798 of file HcalTriggerPrimitiveAlgo.cc.

References cms::cuda::assert(), newFWLiteAna::bin, HcalTPGCompressor::compress(), hcalRecHitTable_cff::detId, FG_HF_thresholds_, HcalFeatureBit::fineGrainbit(), FIRST_FINEGRAIN_TOWER, mps_fire::i, heavyIonCSV_trainingSettings::idx, ALPAKA_ACCELERATOR_NAMESPACE::ecal::reconstruction::internal::barrel::ietaAbs(), createfilelist::int, ALPAKA_ACCELERATOR_NAMESPACE::vertexFinder::it, B2GTnPMonitor_cfi::item, SiStripPI::min, numberOfPresamplesHF_, numberOfSamplesHF_, or, outcoder_, convertSQLitetoXML_cfg::output, QIE10_LINEARIZATION_ET, QIE10_MAX_LINEARIZATION_ET, mps_fire::result, EgammaValidation_cff::samples, edm::shift, theHFUpgradeDetailMap, and useTDCInMinBiasBits_.

Referenced by run().

801  {
802  // Align digis and TP
803  const int shift = samples.presamples() - numberOfPresamplesHF_;
804  assert(shift >= 0);
805  assert((shift + numberOfSamplesHF_) <= samples.size());
806  assert(hf_lumi_shift >= 2);
807 
808  // Try to find the HFDetails from the map corresponding to our samples
809  const HcalTrigTowerDetId detId(samples.id());
810  auto it = theHFUpgradeDetailMap.find(detId);
811  // Missing values will give an empty digi
812  if (it == theHFUpgradeDetailMap.end()) {
813  return;
814  }
815 
816  std::vector<std::bitset<2>> finegrain(numberOfSamplesHF_, false);
817 
818  // Set up out output of IntergerCaloSamples
820  output.setPresamples(numberOfPresamplesHF_);
821 
822  for (const auto& item : it->second) {
823  auto& details = item.second;
824  for (int ibin = 0; ibin < numberOfSamplesHF_; ++ibin) {
825  const int idx = ibin + shift;
826 
827  int long_fiber_val = 0;
828  int long_fiber_count = 0;
829  int short_fiber_val = 0;
830  int short_fiber_count = 0;
831 
832  bool saturated = false;
833 
834  for (auto i : {0, 2}) {
835  if (idx < details[i].samples.size() and details[i].validity[idx] and details[i].passTDC[idx]) {
836  long_fiber_val += details[i].samples[idx];
837  saturated = saturated || (details[i].samples[idx] == QIE10_LINEARIZATION_ET);
838  ++long_fiber_count;
839  }
840  }
841  for (auto i : {1, 3}) {
842  if (idx < details[i].samples.size() and details[i].validity[idx] and details[i].passTDC[idx]) {
843  short_fiber_val += details[i].samples[idx];
844  saturated = saturated || (details[i].samples[idx] == QIE10_LINEARIZATION_ET);
845  ++short_fiber_count;
846  }
847  }
848 
849  if (saturated) {
851  } else {
852  // For details of the energy handling, see:
853  // https://cms-docdb.cern.ch/cgi-bin/DocDB/ShowDocument?docid=12306
854  // If both readouts are valid, average of the two energies is taken
855  // division by 2 is compensated by adjusting the total scale shift in the end
856  if (long_fiber_count == 2)
857  long_fiber_val >>= 1;
858  if (short_fiber_count == 2)
859  short_fiber_val >>= 1;
860 
861  auto sum = long_fiber_val + short_fiber_val;
862  // Similar to above, if both channels are valid,
863  // average of the two energies is calculated
864  // division by 2 here is also compensated by adjusting the total scale shift in the end
865  if (long_fiber_count > 0 and short_fiber_count > 0)
866  sum >>= 1;
867 
868  output[ibin] += sum;
869  }
870 
871  for (const auto& detail : details) {
872  if (idx < int(detail.digi.size()) and detail.validity[idx] and
873  HcalDetId(detail.digi.id()).ietaAbs() >= FIRST_FINEGRAIN_TOWER) {
874  if (useTDCInMinBiasBits_ && !detail.passTDC[idx])
875  continue;
876  finegrain[ibin][1] = finegrain[ibin][1] or detail.fgbits[idx][0];
877  // what is commonly called the "second" HF min-bias bit is
878  // actually the 0-th bit, which can also be used instead for the EM bit
879  // (called finegrain[ibin][0] below) in non-HI running
880  finegrain[ibin][0] = finegrain[ibin][0] or detail.fgbits[idx][1];
881  }
882  }
883  // the EM bit is only used if the "second" FG bit is disabled
884  if (embit != nullptr and FG_HF_thresholds_.at(1) != 255) {
885  finegrain[ibin][0] = embit->fineGrainbit(details[1].digi,
886  details[3].digi,
887  details[0].digi,
888  details[2].digi,
889  details[1].validity[idx],
890  details[3].validity[idx],
891  details[0].validity[idx],
892  details[2].validity[idx],
893  idx);
894  }
895  }
896  }
897 
898  for (int bin = 0; bin < numberOfSamplesHF_; ++bin) {
899  output[bin] = min({(unsigned int)QIE10_MAX_LINEARIZATION_ET, output[bin] >> (hf_lumi_shift - 2)});
900  }
901  std::vector<int> finegrain_converted;
902  finegrain_converted.reserve(finegrain.size());
903  for (const auto& fg : finegrain)
904  finegrain_converted.push_back(fg.to_ulong());
905  outcoder_->compress(output, finegrain_converted, result);
906 }
std::vector< uint32_t > FG_HF_thresholds_
HFUpgradeDetailMap theHFUpgradeDetailMap
static const int QIE10_MAX_LINEARIZATION_ET
const HcalTPGCompressor * outcoder_
assert(be >=bs)
ALPAKA_FN_ACC ALPAKA_FN_INLINE uint32_t ietaAbs(uint32_t id)
void compress(const IntegerCaloSamples &ics, const std::vector< int > &fineGrain, HcalTriggerPrimitiveDigi &digi) const
The Signals That Services Can Subscribe To This is based on ActivityRegistry and is current per Services can connect to the signals distributed by the ActivityRegistry in order to monitor the activity of the application Each possible callback has some defined which we here list in angle e< void, edm::EventID const &, edm::Timestamp const & > We also list in braces which AR_WATCH_USING_METHOD_ is used for those or
Definition: Activities.doc:12
Definition: helper.h:56
static unsigned int const shift
Definition: output.py:1

◆ analyzeQIE11()

void HcalTriggerPrimitiveAlgo::analyzeQIE11 ( IntegerCaloSamples samples,
std::vector< bool >  sample_saturation,
HcalTriggerPrimitiveDigi result,
const HcalFinegrainBit fg_algo 
)
private

Definition at line 438 of file HcalTriggerPrimitiveAlgo.cc.

References codedVetoThresholds_, HcalTPGCompressor::compress(), HcalFinegrainBit::compute(), hcalRecHitTable_cff::detId, fgUpgradeMap_, fgUpgradeTDCMap_, fix_saturation_, mps_fire::i, heavyIonCSV_trainingSettings::idx, createfilelist::int, HcalTopology::lastHBRing(), numberOfFilterPresamplesHBQIE11_, numberOfFilterPresamplesHEQIE11_, numberOfPresamples_, numberOfSamples_, outcoder_, convertSQLitetoXML_cfg::output, QIE11_MAX_LINEARIZATION_ET, mps_fire::result, ecalGpuTask_cfi::sample, EgammaValidation_cff::samples, edm::shift, theThreshold, theTrigTowerGeometry, HcalTrigTowerGeometry::topology(), HcalTrigTowerGeometry::towerIds(), and weightsQIE11_.

Referenced by run().

441  {
442  HcalDetId detId(samples.id());
443 
444  // Get the |ieta| for current sample
445  int theIeta = detId.ietaAbs();
446 
447  unsigned int dgSamples = samples.size();
448  unsigned int dgPresamples = samples.presamples();
449 
450  unsigned int tpSamples = numberOfSamples_;
451  unsigned int tpPresamples = numberOfPresamples_;
452 
453  unsigned int filterSamples = weightsQIE11_[theIeta].size();
454  unsigned int filterPresamples = theIeta > theTrigTowerGeometry->topology().lastHBRing()
457 
458  unsigned int shift = dgPresamples - tpPresamples;
459 
460  // shrink keeps the FIR filter from going off the end of the 8TS vector
461  unsigned int shrink = filterSamples - 1;
462 
463  auto& msb = fgUpgradeMap_[samples.id()];
464  auto& timingTDC = fgUpgradeTDCMap_[samples.id()];
465  IntegerCaloSamples sum(samples.id(), samples.size());
466 
467  std::vector<HcalTrigTowerDetId> ids = theTrigTowerGeometry->towerIds(detId);
468 
469  // keep track of tower with saturated energy and force the total TP saturated
470  bool force_saturation[samples.size()];
471  for (int i = 0; i < samples.size(); i++) {
472  force_saturation[i] = false;
473  }
474 
475  //slide algo window
476  for (unsigned int ibin = 0; ibin < dgSamples - shrink; ++ibin) {
477  int algosumvalue = 0;
478  bool check_sat = false;
479  //TP energy calculation for PFA2
480  if (weightsQIE11_[theIeta][0] == 255) {
481  for (unsigned int i = 0; i < filterSamples; i++) {
482  //add up value * scale factor
483  // In addition, divide by two in the 10 degree phi segmentation region
484  // to mimic 5 degree segmentation for the trigger
485  unsigned int sample = samples[ibin + i];
486 
487  if (fix_saturation_ && (sample_saturation.size() > ibin + i))
488  check_sat = (check_sat | sample_saturation[ibin + i] | (sample > QIE11_MAX_LINEARIZATION_ET));
489 
492 
493  // Usually use a segmentation factor of 1.0 but for ieta >= 21 use 2
494  int segmentationFactor = 1;
495  if (ids.size() == 2) {
496  segmentationFactor = 2;
497  }
498 
499  algosumvalue += int(sample / segmentationFactor);
500  }
501  if (algosumvalue < 0)
502  sum[ibin] = 0; // low-side
503  //high-side
504  //else if (algosumvalue>QIE11_LINEARIZATION_ET) sum[ibin]=QIE11_LINEARIZATION_ET;
505  else
506  sum[ibin] = algosumvalue; //assign value to sum[]
507 
508  if (check_sat)
509  force_saturation[ibin] = true;
510  //TP energy calculation for PFA1' and PFA1
511  } else {
512  //add up value * scale factor
513  // In addition, divide by two in the 10 degree phi segmentation region
514  // to mimic 5 degree segmentation for the trigger
515  int sampleTS = samples[ibin + 1];
516  int sampleTSminus1 = samples[ibin];
517 
518  if (fix_saturation_ && (sample_saturation.size() > ibin + 1))
519  check_sat |= sample_saturation[ibin + 1] | (sampleTS >= QIE11_MAX_LINEARIZATION_ET);
520 
521  if (sampleTS > QIE11_MAX_LINEARIZATION_ET)
522  sampleTS = QIE11_MAX_LINEARIZATION_ET;
523 
524  if (sampleTSminus1 > QIE11_MAX_LINEARIZATION_ET || sample_saturation[ibin])
525  sampleTSminus1 = QIE11_MAX_LINEARIZATION_ET;
526 
527  // Usually use a segmentation factor of 1.0 but for ieta >= 21 use 2
528  int segmentationFactor = 1;
529  if (ids.size() == 2) {
530  segmentationFactor = 2;
531  }
532 
533  // Based on the |ieta| of the sample, retrieve the correct region weight
534  int theWeight = weightsQIE11_[theIeta][0];
535 
536  algosumvalue = ((sampleTS << 8) - (sampleTSminus1 * theWeight)) / 256 / segmentationFactor;
537 
538  if (algosumvalue < 0)
539  sum[ibin] = 0; // low-side
540  //high-side
541  //else if (algosumvalue>QIE11_LINEARIZATION_ET) sum[ibin]=QIE11_LINEARIZATION_ET;
542  else
543  sum[ibin] = algosumvalue; //assign value to sum[]
544 
545  if (check_sat)
546  force_saturation[ibin] = true;
547  }
548  }
549 
550  std::vector<int> finegrain(tpSamples, false);
551 
552  IntegerCaloSamples output(samples.id(), tpSamples);
553  output.setPresamples(tpPresamples);
554 
555  // Based on the |ieta| of the sample, retrieve the correct region "coded" veto threshold
556  // where two of the possible values have special meaning
557  unsigned int codedVetoThreshold = codedVetoThresholds_[theIeta];
558 
559  // Anything in range (1, 2048) inclusive shall activate the veto
560  unsigned int actualVetoThreshold = codedVetoThreshold;
561  bool applyVetoThreshold = codedVetoThreshold > 0 && codedVetoThreshold <= 2048;
562 
563  // Special value to disable vetoing in the PFA1' algo is 0
564  if (codedVetoThreshold > 0) {
565  if (codedVetoThreshold <= 2048) {
566  // Special value to run the veto in PFA1' with no threshold
567  if (codedVetoThreshold == 2048)
568  actualVetoThreshold = 0;
569  } else {
570  edm::LogWarning("HcalTPAlgo") << "Specified veto threshold value " << codedVetoThreshold
571  << " is not in range (1, 2048) ! Vetoing in PFA1' will not be enabled !";
572  }
573  }
574 
575  for (unsigned int ibin = 0; ibin < tpSamples; ++ibin) {
576  // ibin - index for output TP
577  // idx - index for samples + shift - filterPresamples
578  int idx = ibin + shift - filterPresamples;
579 
580  // When idx is <= 0 peakfind would compare out-of-bounds of the vector. Avoid this ambiguity
581  if (idx <= 0) {
582  output[ibin] = 0;
583  continue;
584  }
585 
586  //Only run the peak-finder when the PFA2 FIR filter is running, which corresponds to weights = 1
587  if (weightsQIE11_[theIeta][0] == 255) {
588  bool isPeak = (sum[idx] > sum[idx - 1] && sum[idx] >= sum[idx + 1] && sum[idx] > theThreshold);
589  if (isPeak) {
590  output[ibin] = std::min<unsigned int>(sum[idx], QIE11_MAX_LINEARIZATION_ET);
591 
592  if (fix_saturation_ && force_saturation[idx] && ids.size() == 2)
594  else if (fix_saturation_ && force_saturation[idx])
596 
597  } else {
598  // Not a peak
599  output[ibin] = 0;
600  }
601  } else {
602  // Only if the sum for the future time sample is above the veto
603  // threshold and the now sum is not a peak and the now sum is not
604  // saturated does the current sum get zeroed
605  if (applyVetoThreshold && sum[idx + 1] >= actualVetoThreshold &&
606  (sum[idx] < sum[idx + 1] || force_saturation[idx + 1]) && !force_saturation[idx])
607  output[ibin] = 0;
608  else {
609  // Here, either the "now" sum is a peak or the vetoing criteria are not satisfied
610  // so assign the appropriate sum to the output
611  output[ibin] = std::min<unsigned int>(sum[idx], QIE11_MAX_LINEARIZATION_ET);
612  if (fix_saturation_ && force_saturation[idx]) {
614  if (ids.size() == 2)
615  output[ibin] /= 2;
616  }
617  }
618  }
619  // peak-finding is not applied for FG bits
620  // compute(msb) returns two bits (MIP). compute(timingTDC,ids) returns 6 bits (1 depth, 1 prompt, 1 delayed 01, 1 delayed 10, 2 reserved)
621  finegrain[ibin] = fg_algo.compute(timingTDC[idx + filterPresamples], ids[0]).to_ulong() |
622  fg_algo.compute(msb[idx + filterPresamples]).to_ulong() << 4;
623  if (ibin == tpPresamples && (idx + filterPresamples) != dgPresamples)
624  edm::LogError("HcalTriggerPritimveAlgo")
625  << "TP SOI (tpPresamples = " << tpPresamples
626  << ") is not aligned with digi SOI (dgPresamples = " << dgPresamples << ")";
627  }
628  outcoder_->compress(output, finegrain, result);
629 }
const HcalTPGCompressor * outcoder_
Log< level::Error, false > LogError
std::array< std::array< int, 2 >, 29 > weightsQIE11_
const HcalTopology & topology() const
std::array< int, 29 > codedVetoThresholds_
void compress(const IntegerCaloSamples &ics, const std::vector< int > &fineGrain, HcalTriggerPrimitiveDigi &digi) const
const HcalTrigTowerGeometry * theTrigTowerGeometry
int lastHBRing() const
Definition: HcalTopology.h:92
std::bitset< 2 > compute(const Tower &) const
static const int QIE11_MAX_LINEARIZATION_ET
static unsigned int const shift
Definition: output.py:1
Log< level::Warning, false > LogWarning
std::vector< HcalTrigTowerDetId > towerIds(const HcalDetId &cellId) const
the mapping to and from DetIds

◆ analyzeZDC()

void HcalTriggerPrimitiveAlgo::analyzeZDC ( IntegerCaloSamples samples,
HcalTriggerPrimitiveDigi result 
)
private

Definition at line 631 of file HcalTriggerPrimitiveAlgo.cc.

References hcalRecHitTable_cff::detId, mps_fire::i, convertSQLitetoXML_cfg::output, QIE10_ZDC_MAX_LINEARIZATION_ET, mps_fire::result, and EgammaValidation_cff::samples.

Referenced by run().

631  {
633 
634  unsigned int tpSamples;
635  unsigned int tpPresamples;
636 
637  tpSamples = samples.size();
638  tpPresamples = samples.presamples();
639  result.setSize(tpSamples);
640  result.setPresamples(tpPresamples);
641 
642  IntegerCaloSamples output(samples.id(), tpSamples);
643  output.setPresamples(tpPresamples);
644 
645  for (int i = 0; i < samples.size(); i++) {
648  else
649  output[i] = samples[i];
650  HcalTriggerPrimitiveSample zdcSample(output[i]);
651  result.setSample(i, zdcSample);
652  }
653 }
static const int QIE10_ZDC_MAX_LINEARIZATION_ET
Definition: output.py:1

◆ needLegacyFG()

bool HcalTriggerPrimitiveAlgo::needLegacyFG ( const HcalTrigTowerDetId id) const
private

Definition at line 1000 of file HcalTriggerPrimitiveAlgo.cc.

References HBHE_OVERLAP_TOWER, ALPAKA_ACCELERATOR_NAMESPACE::ecal::reconstruction::internal::barrel::ietaAbs(), and upgrade_hb_.

Referenced by addUpgradeFG().

1000  {
1001  // This tower (ietaAbs == 16) does not accept upgraded FG bits,
1002  // but needs pseudo legacy ones to ensure that the tower is processed
1003  // even when the QIE8 depths in front of it do not have energy deposits.
1004  if (id.ietaAbs() == HBHE_OVERLAP_TOWER and not upgrade_hb_)
1005  return true;
1006  return false;
1007 }
ALPAKA_FN_ACC ALPAKA_FN_INLINE uint32_t ietaAbs(uint32_t id)

◆ needUpgradeID()

bool HcalTriggerPrimitiveAlgo::needUpgradeID ( const HcalTrigTowerDetId id,
int  depth 
) const
private

Definition at line 1009 of file HcalTriggerPrimitiveAlgo.cc.

References FIRST_DEPTH7_TOWER, and LAST_FINEGRAIN_DEPTH.

Referenced by addUpgradeFG().

1009  {
1010  // Depth 7 for TT 26, 27, and 28 is not considered a fine grain depth.
1011  // However, the trigger tower for these ieta should still be added to the fgUpgradeMap_
1012  // Otherwise, depth 7-only signal will not be analyzed.
1013  unsigned int aieta = id.ietaAbs();
1014  if (aieta >= FIRST_DEPTH7_TOWER and aieta <= LAST_FINEGRAIN_TOWER and depth > LAST_FINEGRAIN_DEPTH)
1015  return true;
1016  return false;
1017 }

◆ overrideParameters()

void HcalTriggerPrimitiveAlgo::overrideParameters ( const edm::ParameterSet ps)

Definition at line 87 of file HcalTriggerPrimitiveAlgo.cc.

References edm::ParameterSet::exists(), edm::ParameterSet::getParameter(), override_adc_hf_, override_adc_hf_value_, override_parameters_, override_tdc_hf_, and override_tdc_hf_value_.

Referenced by HcalTrigPrimDigiProducer::HcalTrigPrimDigiProducer().

87  {
89 
90  if (override_parameters_.exists("ADCThresholdHF")) {
91  override_adc_hf_ = true;
92  override_adc_hf_value_ = override_parameters_.getParameter<uint32_t>("ADCThresholdHF");
93  }
94  if (override_parameters_.exists("TDCMaskHF")) {
95  override_tdc_hf_ = true;
96  override_tdc_hf_value_ = override_parameters_.getParameter<unsigned long long>("TDCMaskHF");
97  }
98 }
T getParameter(std::string const &) const
Definition: ParameterSet.h:307
bool exists(std::string const &parameterName) const
checks if a parameter exists
unsigned long long override_tdc_hf_value_

◆ passTDC()

bool HcalTriggerPrimitiveAlgo::passTDC ( const QIE10DataFrame digi,
int  ts 
) const
private

Definition at line 770 of file HcalTriggerPrimitiveAlgo.cc.

References gpuClustering::adc, conditions_, HcalDbService::getHcalTPParameters(), override_adc_hf_, override_adc_hf_value_, override_tdc_hf_, and override_tdc_hf_value_.

Referenced by addSignal().

770  {
772  auto adc_threshold = parameters->getADCThresholdHF();
773  auto tdc_mask = parameters->getTDCMaskHF();
774 
775  if (override_adc_hf_)
776  adc_threshold = override_adc_hf_value_;
777  if (override_tdc_hf_)
778  tdc_mask = override_tdc_hf_value_;
779 
780  if (digi[ts].adc() < adc_threshold)
781  return true;
782 
783  return (1ul << digi[ts].le_tdc()) & tdc_mask;
784 }
const HcalDbService * conditions_
const HcalTPParameters * getHcalTPParameters() const
unsigned long long override_tdc_hf_value_
uint16_t *__restrict__ uint16_t const *__restrict__ adc

◆ run()

template<typename... Digis>
void HcalTriggerPrimitiveAlgo::run ( const HcalTPGCoder incoder,
const HcalTPGCompressor outcoder,
const HcalDbService conditions,
HcalTrigPrimDigiCollection result,
const HcalTrigTowerGeometry trigTowerGeometry,
float  rctlsb,
const HcalFeatureBit LongvrsShortCut,
const Digis &...  digis 
)

Definition at line 263 of file HcalTriggerPrimitiveAlgo.h.

References addDigis(), analyze(), analyzeHF(), analyzeHF2016(), analyzeHFQIE10(), analyzeQIE11(), analyzeZDC(), submitPVValidationJobs::conditions, conditions_, hcalRecHitTable_cff::detId, edm::ParameterSet::exists(), fgMap_, fgUpgradeMap_, fgUpgradeTDCMap_, HcalTrigTowerGeometry::firstHFTower(), HcalTPParameters::getFGVersionHBHE(), HcalDbService::getHcalTPParameters(), edm::ParameterSet::getParameter(), HF_Veto, incoder_, B2GTnPMonitor_cfi::item, LongvrsShortCut, NCTScaleShift, or, outcoder_, override_parameters_, RCTScaleShift, mps_fire::result, theHFDetailMap, theHFUpgradeDetailMap, theSatMap, theSumMap, theTowerMapFGSum, theTrigTowerGeometry, upgrade_hb_, upgrade_he_, upgrade_hf_, and BeamSplash_cfg::version.

Referenced by HcalTrigPrimDigiProducer::produce().

270  {
271  theTrigTowerGeometry = trigTowerGeometry;
272 
273  incoder_ = dynamic_cast<const HcaluLUTTPGCoder*>(incoder);
274  outcoder_ = outcoder;
276 
277  theSumMap.clear();
278  theSatMap.clear();
279  theTowerMapFGSum.clear();
280  HF_Veto.clear();
281  fgMap_.clear();
282  fgUpgradeMap_.clear();
283  fgUpgradeTDCMap_.clear();
284  theHFDetailMap.clear();
285  theHFUpgradeDetailMap.clear();
286 
287  // Add all digi collections
288  addDigis(digis...);
289 
290  // Prepare the fine-grain calculation algorithm for HB/HE
291  int version = 0;
294  if (override_parameters_.exists("FGVersionHBHE"))
295  version = override_parameters_.getParameter<uint32_t>("FGVersionHBHE");
296  HcalFinegrainBit fg_algo(version);
297 
298  // VME produces additional bits on the front used by lumi but not the
299  // trigger, this shift corrects those out by right shifting over them.
300  for (auto& item : theSumMap) {
301  result.push_back(HcalTriggerPrimitiveDigi(item.first));
302  HcalTrigTowerDetId detId(item.second.id());
303  if (detId.ietaAbs() >= theTrigTowerGeometry->firstHFTower(detId.version()) && detId.ietaAbs() < 42) {
304  if (detId.version() == 0) {
305  analyzeHF(item.second, result.back(), RCTScaleShift);
306  } else if (detId.version() == 1) {
307  if (upgrade_hf_)
309  else
311  } else {
312  // Things are going to go poorly
313  }
314  } else if (detId.ietaAbs() >= theTrigTowerGeometry->firstHFTower(detId.version()) && detId.ietaAbs() > 41) {
315  analyzeZDC(item.second, result.back());
316  } else {
317  // Determine which energy reconstruction path to take based on the
318  // fine-grain availability:
319  // * QIE8 TP add entries into fgMap_
320  // * QIE11 TP add entries into fgUpgradeMap_
321  // (not for tower 16 unless HB is upgraded, too)
322  if (fgMap_.find(item.first) != fgMap_.end()) {
323  analyze(item.second, result.back());
324  } else if (fgUpgradeMap_.find(item.first) != fgUpgradeMap_.end()) {
325  SatMap::iterator item_sat = theSatMap.find(detId);
326  if (item_sat == theSatMap.end())
327  analyzeQIE11(item.second, std::vector<bool>(), result.back(), fg_algo);
328  else
329  analyzeQIE11(item.second, item_sat->second, result.back(), fg_algo);
330  }
331  }
332  }
333 
334  // Free up some memory
335  theSumMap.clear();
336  theSatMap.clear();
337  theTowerMapFGSum.clear();
338  HF_Veto.clear();
339  fgMap_.clear();
340  fgUpgradeMap_.clear();
341  fgUpgradeTDCMap_.clear();
342  theHFDetailMap.clear();
343  theHFUpgradeDetailMap.clear();
344 
345  return;
346 }
void analyze(IntegerCaloSamples &samples, HcalTriggerPrimitiveDigi &result)
adds the actual digis
T getParameter(std::string const &) const
Definition: ParameterSet.h:307
HFUpgradeDetailMap theHFUpgradeDetailMap
int getFGVersionHBHE() const
get FineGrain Algorithm Version for HBHE
void analyzeHF(IntegerCaloSamples &samples, HcalTriggerPrimitiveDigi &result, const int hf_lumi_shift)
void analyzeHF2016(const IntegerCaloSamples &SAMPLES, HcalTriggerPrimitiveDigi &result, const int HF_LUMI_SHIFT, const HcalFeatureBit *HCALFEM)
bool exists(std::string const &parameterName) const
checks if a parameter exists
void analyzeHFQIE10(const IntegerCaloSamples &SAMPLES, HcalTriggerPrimitiveDigi &result, const int HF_LUMI_SHIFT, const HcalFeatureBit *HCALFEM)
const HcalTPGCompressor * outcoder_
int firstHFTower(int version) const
const HcalTrigTowerGeometry * theTrigTowerGeometry
const HcalDbService * conditions_
The Signals That Services Can Subscribe To This is based on ActivityRegistry and is current per Services can connect to the signals distributed by the ActivityRegistry in order to monitor the activity of the application Each possible callback has some defined which we here list in angle e< void, edm::EventID const &, edm::Timestamp const & > We also list in braces which AR_WATCH_USING_METHOD_ is used for those or
Definition: Activities.doc:12
const HcalTPParameters * getHcalTPParameters() const
void analyzeQIE11(IntegerCaloSamples &samples, std::vector< bool > sample_saturation, HcalTriggerPrimitiveDigi &result, const HcalFinegrainBit &fg_algo)
void addDigis(const T &collection, const Args &... digis)
const HcaluLUTTPGCoder * incoder_
void analyzeZDC(IntegerCaloSamples &samples, HcalTriggerPrimitiveDigi &result)

◆ runFEFormatError()

void HcalTriggerPrimitiveAlgo::runFEFormatError ( const FEDRawDataCollection rawraw,
const HcalElectronicsMap emap,
HcalTrigPrimDigiCollection result 
)

Definition at line 924 of file HcalTriggerPrimitiveAlgo.cc.

References HcalHTRData::check(), FEDRawData::data(), hcalRecHitTable_cff::detId, runTauDisplay::eid, FEDRawDataCollection::FEDData(), HcalHTRData::getErrorsWord(), HcalDCCHeader::getSourceId(), HcalDCCHeader::getSpigotData(), HcalDCCHeader::getSpigotPresent(), HcalBarrel, HcalEndcap, HcalForward, HcalHTRData::htrSlot(), HcalHTRData::htrTopBottom(), mps_fire::i, HcalHTRData::isHistogramEvent(), HcalElectronicsMap::lookup(), FEDNumbering::MAXHCALFEDID, FEDNumbering::MINHCALFEDID, HcalHTRData::readoutVMECrateId(), mps_fire::result, FEDRawData::size(), HcalDCCHeader::SPIGOT_COUNT, theTrigTowerGeometry, HcalTrigTowerGeometry::towerIds(), cmsswSequenceInfo::tp, and validateGeometry_cfg::valid.

Referenced by HcalTrigPrimDigiProducer::produce().

926  {
927  std::set<uint32_t> FrontEndErrors;
928 
930  const FEDRawData& raw = rawraw->FEDData(i);
931  if (raw.size() < 12)
932  continue;
933  const HcalDCCHeader* dccHeader = (const HcalDCCHeader*)(raw.data());
934  if (!dccHeader)
935  continue;
936  HcalHTRData htr;
937  for (int spigot = 0; spigot < HcalDCCHeader::SPIGOT_COUNT; spigot++) {
938  if (!dccHeader->getSpigotPresent(spigot))
939  continue;
940  dccHeader->getSpigotData(spigot, htr, raw.size());
941  int dccid = dccHeader->getSourceId();
942  int errWord = htr.getErrorsWord() & 0x1FFFF;
943  bool HTRError = (!htr.check() || htr.isHistogramEvent() || (errWord & 0x800) != 0);
944 
945  if (HTRError) {
946  bool valid = false;
947  for (int fchan = 0; fchan < 3 && !valid; fchan++) {
948  for (int fib = 0; fib < 9 && !valid; fib++) {
949  HcalElectronicsId eid(fchan, fib, spigot, dccid - FEDNumbering::MINHCALFEDID);
950  eid.setHTR(htr.readoutVMECrateId(), htr.htrSlot(), htr.htrTopBottom());
951  DetId detId = emap->lookup(eid);
952  if (detId.null())
953  continue;
954  HcalSubdetector subdet = (HcalSubdetector(detId.subdetId()));
955  if (detId.det() != 4 || (subdet != HcalBarrel && subdet != HcalEndcap && subdet != HcalForward))
956  continue;
957  std::vector<HcalTrigTowerDetId> ids = theTrigTowerGeometry->towerIds(detId);
958  for (std::vector<HcalTrigTowerDetId>::const_iterator triggerId = ids.begin(); triggerId != ids.end();
959  ++triggerId) {
960  FrontEndErrors.insert(triggerId->rawId());
961  }
962  //valid = true;
963  }
964  }
965  }
966  }
967  }
968 
969  // Loop over TP collection
970  // Set TP to zero if there is FE Format Error
971  HcalTriggerPrimitiveSample zeroSample(0);
972  for (HcalTrigPrimDigiCollection::iterator tp = result.begin(); tp != result.end(); ++tp) {
973  if (FrontEndErrors.find(tp->id().rawId()) != FrontEndErrors.end()) {
974  for (int i = 0; i < tp->size(); ++i)
975  tp->setSample(i, zeroSample);
976  }
977  }
978 }
bool isHistogramEvent() const
Is this event a histogram event? (do not call standard unpack in this case!!!!!)
Definition: HcalHTRData.cc:409
int getSpigotData(int nspigot, HcalHTRData &decodeTool, int validSize) const
const DetId lookup(HcalElectronicsId fId) const
lookup the logical detid associated with the given electronics id
size_t size() const
Lenght of the data buffer in bytes.
Definition: FEDRawData.h:48
const HcalTrigTowerGeometry * theTrigTowerGeometry
unsigned int htrSlot() const
HcalElectronicsId-style HTR slot.
Definition: HcalHTRData.cc:365
unsigned int htrTopBottom() const
HcalElectronicsId-style HTR top/bottom (1=top/0=bottom)
Definition: HcalHTRData.cc:369
int getSourceId() const
Definition: HcalDCCHeader.h:33
HcalSubdetector
Definition: HcalAssistant.h:31
const FEDRawData & FEDData(int fedid) const
retrieve data for fed
std::vector< T >::iterator iterator
Definition: DetId.h:17
static const int SPIGOT_COUNT
Definition: HcalDCCHeader.h:20
unsigned int getErrorsWord() const
Get the errors word.
Definition: HcalHTRData.h:162
bool getSpigotPresent(unsigned int nspigot) const
Read the "PRESENT" bit for this spigot.
const unsigned char * data() const
Return a const pointer to the beginning of the data buffer.
Definition: FEDRawData.cc:24
unsigned int readoutVMECrateId() const
HcalElectronicsId-style VME crate number.
Definition: HcalHTRData.cc:373
Readout chain identification for Hcal.
std::vector< HcalTrigTowerDetId > towerIds(const HcalDetId &cellId) const
the mapping to and from DetIds
bool check() const
Check for a good event Requires a minimum length, matching wordcount and length, not an empty event...
Definition: HcalHTRData.cc:63

◆ runZS()

void HcalTriggerPrimitiveAlgo::runZS ( HcalTrigPrimDigiCollection tp)

Definition at line 908 of file HcalTriggerPrimitiveAlgo.cc.

References mps_fire::i, mps_fire::result, cmsswSequenceInfo::tp, and ZS_threshold_I_.

Referenced by HcalTrigPrimDigiProducer::produce().

908  {
909  for (HcalTrigPrimDigiCollection::iterator tp = result.begin(); tp != result.end(); ++tp) {
910  bool ZS = true;
911  for (int i = 0; i < tp->size(); ++i) {
912  if (tp->sample(i).compressedEt() > ZS_threshold_I_) {
913  ZS = false;
914  break;
915  }
916  }
917  if (ZS)
918  tp->setZSInfo(false, true);
919  else
920  tp->setZSInfo(true, false);
921  }
922 }
std::vector< T >::iterator iterator

◆ setCodedVetoThreshold()

void HcalTriggerPrimitiveAlgo::setCodedVetoThreshold ( int  aieta,
int  codedVetoThreshold 
)

Definition at line 1109 of file HcalTriggerPrimitiveAlgo.cc.

References codedVetoThresholds_.

Referenced by HcalTrigPrimDigiProducer::beginRun().

1109  {
1110  // Simple map of |ieta| in HBHE to veto threshold
1111  codedVetoThresholds_[aieta] = {codedVetoThreshold};
1112 }
std::array< int, 29 > codedVetoThresholds_

◆ setCodedVetoThresholds()

void HcalTriggerPrimitiveAlgo::setCodedVetoThresholds ( const edm::ParameterSet codedVetoThresholds)

Definition at line 1099 of file HcalTriggerPrimitiveAlgo.cc.

References hcaltpdigi_cfi::codedVetoThresholds, codedVetoThresholds_, and findQualityFiles::v.

Referenced by HcalTrigPrimDigiProducer::HcalTrigPrimDigiProducer().

1099  {
1100  // Names are just abs(ieta) for HBHE
1101  std::vector<std::string> ietaStrs = codedVetoThresholds.getParameterNames();
1102  for (auto& ietaStr : ietaStrs) {
1103  // Strip off "ieta" part of key and just use integer value in map
1104  auto const& v = codedVetoThresholds.getParameter<int>(ietaStr);
1105  codedVetoThresholds_[std::stoi(ietaStr.substr(4))] = {v};
1106  }
1107 }
std::array< int, 29 > codedVetoThresholds_
codedVetoThresholds
threshold for setting TP zero suppression

◆ setFixSaturationFlag()

void HcalTriggerPrimitiveAlgo::setFixSaturationFlag ( bool  fix_saturation)

◆ setNCTScaleShift()

void HcalTriggerPrimitiveAlgo::setNCTScaleShift ( int  shift)

Definition at line 1120 of file HcalTriggerPrimitiveAlgo.cc.

References NCTScaleShift, and edm::shift.

Referenced by HcalTrigPrimDigiProducer::HcalTrigPrimDigiProducer().

1120 { NCTScaleShift = shift; }
static unsigned int const shift

◆ setNumFilterPresamplesHBQIE11()

void HcalTriggerPrimitiveAlgo::setNumFilterPresamplesHBQIE11 ( int  presamples)
inline

◆ setNumFilterPresamplesHEQIE11()

void HcalTriggerPrimitiveAlgo::setNumFilterPresamplesHEQIE11 ( int  presamples)
inline

◆ setPeakFinderAlgorithm()

void HcalTriggerPrimitiveAlgo::setPeakFinderAlgorithm ( int  algo)

Definition at line 1114 of file HcalTriggerPrimitiveAlgo.cc.

References Exception, and peak_finder_algorithm_.

Referenced by HcalTrigPrimDigiProducer::HcalTrigPrimDigiProducer().

1114  {
1115  if (algo <= 0 || algo > 2)
1116  throw cms::Exception("ERROR: Only algo 1 & 2 are supported.") << std::endl;
1118 }

◆ setRCTScaleShift()

void HcalTriggerPrimitiveAlgo::setRCTScaleShift ( int  shift)

Definition at line 1122 of file HcalTriggerPrimitiveAlgo.cc.

References RCTScaleShift, and edm::shift.

Referenced by HcalTrigPrimDigiProducer::HcalTrigPrimDigiProducer().

1122 { RCTScaleShift = shift; }
static unsigned int const shift

◆ setUpgradeFlags()

void HcalTriggerPrimitiveAlgo::setUpgradeFlags ( bool  hb,
bool  he,
bool  hf 
)

◆ setWeightQIE11()

void HcalTriggerPrimitiveAlgo::setWeightQIE11 ( int  aieta,
int  weight 
)

Definition at line 1093 of file HcalTriggerPrimitiveAlgo.cc.

References mps_merge::weight, and weightsQIE11_.

Referenced by HcalTrigPrimDigiProducer::beginRun().

1093  {
1094  // Simple map of |ieta| in HBHE to weight
1095  // Only one weight for SOI-1 TS
1096  weightsQIE11_[aieta] = {{weight, 255}};
1097 }
std::array< std::array< int, 2 >, 29 > weightsQIE11_

◆ setWeightsQIE11()

void HcalTriggerPrimitiveAlgo::setWeightsQIE11 ( const edm::ParameterSet weightsQIE11)

Definition at line 1083 of file HcalTriggerPrimitiveAlgo.cc.

References findQualityFiles::v, hcaltpdigi_cfi::weightsQIE11, and weightsQIE11_.

Referenced by HcalTrigPrimDigiProducer::HcalTrigPrimDigiProducer().

1083  {
1084  // Names are just abs(ieta) for HBHE
1085  std::vector<std::string> ietaStrs = weightsQIE11.getParameterNames();
1086  for (auto& ietaStr : ietaStrs) {
1087  // Strip off "ieta" part of key and just use integer value in map
1088  auto const& v = weightsQIE11.getParameter<std::vector<int>>(ietaStr);
1089  weightsQIE11_[std::stoi(ietaStr.substr(4))] = {{v[0], v[1]}};
1090  }
1091 }
std::array< std::array< int, 2 >, 29 > weightsQIE11_
weightsQIE11
hardware algo

◆ validChannel()

bool HcalTriggerPrimitiveAlgo::validChannel ( const QIE10DataFrame digi,
int  ts 
) const
private

Definition at line 786 of file HcalTriggerPrimitiveAlgo.cc.

References conditions_, HcalDbService::getHcalTPChannelParameter(), HcalTPChannelParameter::getMask(), QIE10DataFrame::id(), QIE10DataFrame::linkError(), ALPAKA_ACCELERATOR_NAMESPACE::pixelClustering::pixelStatus::mask, and QIE10DataFrame::samples().

Referenced by addSignal().

786  {
787  // channels with invalid data should not contribute to the sum
788  if (digi.linkError() || ts >= digi.samples() || !digi[ts].ok())
789  return false;
790 
792  if (mask)
793  return false;
794 
795  return true;
796 }
constexpr edm::DataFrame::id_type id() const
uint32_t getMask() const
get mask for channel validity and self trigger information
const HcalDbService * conditions_
const HcalTPChannelParameter * getHcalTPChannelParameter(const HcalGenericDetId &fId, bool throwOnFail=true) const
constexpr bool linkError() const
constexpr int samples() const
total number of samples in the digi

◆ validUpgradeFG()

bool HcalTriggerPrimitiveAlgo::validUpgradeFG ( const HcalTrigTowerDetId id,
int  depth 
) const
private

Definition at line 990 of file HcalTriggerPrimitiveAlgo.cc.

References hcalRecHitTable_cff::depth, HBHE_OVERLAP_TOWER, ALPAKA_ACCELERATOR_NAMESPACE::ecal::reconstruction::internal::barrel::ietaAbs(), LAST_FINEGRAIN_DEPTH, LAST_FINEGRAIN_TOWER, and upgrade_hb_.

Referenced by addUpgradeFG().

990  {
992  return false;
993  if (id.ietaAbs() > LAST_FINEGRAIN_TOWER)
994  return false;
995  if (id.ietaAbs() == HBHE_OVERLAP_TOWER and not upgrade_hb_)
996  return false;
997  return true;
998 }
ALPAKA_FN_ACC ALPAKA_FN_INLINE uint32_t ietaAbs(uint32_t id)

Member Data Documentation

◆ codedVetoThresholds_

std::array<int, 29> HcalTriggerPrimitiveAlgo::codedVetoThresholds_
private

◆ conditions_

const HcalDbService* HcalTriggerPrimitiveAlgo::conditions_
private

Definition at line 142 of file HcalTriggerPrimitiveAlgo.h.

Referenced by passTDC(), run(), and validChannel().

◆ FG_HF_thresholds_

std::vector<uint32_t> HcalTriggerPrimitiveAlgo::FG_HF_thresholds_
private

Definition at line 150 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyzeHF2016(), and analyzeHFQIE10().

◆ FG_threshold_

uint32_t HcalTriggerPrimitiveAlgo::FG_threshold_
private

Definition at line 149 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyzeHF().

◆ fgMap_

FGbitMap HcalTriggerPrimitiveAlgo::fgMap_
private

Definition at line 221 of file HcalTriggerPrimitiveAlgo.h.

Referenced by addFG(), analyze(), and run().

◆ fgUpgradeMap_

FGUpgradeMap HcalTriggerPrimitiveAlgo::fgUpgradeMap_
private

Definition at line 225 of file HcalTriggerPrimitiveAlgo.h.

Referenced by addUpgradeFG(), analyzeQIE11(), and run().

◆ fgUpgradeTDCMap_

FGUpgradeTDCMap HcalTriggerPrimitiveAlgo::fgUpgradeTDCMap_
private

Definition at line 229 of file HcalTriggerPrimitiveAlgo.h.

Referenced by addUpgradeTDCFG(), analyzeQIE11(), and run().

◆ FIRST_DEPTH7_TOWER

const int HcalTriggerPrimitiveAlgo::FIRST_DEPTH7_TOWER = 26
staticprivate

Definition at line 246 of file HcalTriggerPrimitiveAlgo.h.

Referenced by needUpgradeID().

◆ FIRST_FINEGRAIN_TOWER

const int HcalTriggerPrimitiveAlgo::FIRST_FINEGRAIN_TOWER = 30
staticprivate

Definition at line 251 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyzeHF2016(), and analyzeHFQIE10().

◆ fix_saturation_

bool HcalTriggerPrimitiveAlgo::fix_saturation_ = false
private

Definition at line 235 of file HcalTriggerPrimitiveAlgo.h.

Referenced by addSignal(), analyzeQIE11(), and setFixSaturationFlag().

◆ HBHE_OVERLAP_TOWER

const int HcalTriggerPrimitiveAlgo::HBHE_OVERLAP_TOWER = 16
staticprivate

Definition at line 245 of file HcalTriggerPrimitiveAlgo.h.

Referenced by needLegacyFG(), and validUpgradeFG().

◆ HF_Veto

TowerMapVeto HcalTriggerPrimitiveAlgo::HF_Veto
private

Definition at line 218 of file HcalTriggerPrimitiveAlgo.h.

Referenced by addSignal(), analyzeHF(), and run().

◆ incoder_

const HcaluLUTTPGCoder* HcalTriggerPrimitiveAlgo::incoder_
private

Definition at line 140 of file HcalTriggerPrimitiveAlgo.h.

Referenced by addSignal(), addUpgradeTDCFG(), and run().

◆ LAST_FINEGRAIN_DEPTH

const int HcalTriggerPrimitiveAlgo::LAST_FINEGRAIN_DEPTH = 6
staticprivate

Definition at line 247 of file HcalTriggerPrimitiveAlgo.h.

Referenced by needUpgradeID(), and validUpgradeFG().

◆ LAST_FINEGRAIN_TOWER

const int HcalTriggerPrimitiveAlgo::LAST_FINEGRAIN_TOWER = 28
staticprivate

Definition at line 248 of file HcalTriggerPrimitiveAlgo.h.

Referenced by validUpgradeFG().

◆ latency_

int HcalTriggerPrimitiveAlgo::latency_
private

Definition at line 148 of file HcalTriggerPrimitiveAlgo.h.

◆ LongvrsShortCut

HcalFeatureBit* HcalTriggerPrimitiveAlgo::LongvrsShortCut
private

Definition at line 216 of file HcalTriggerPrimitiveAlgo.h.

Referenced by run().

◆ minSignalThreshold_

uint32_t HcalTriggerPrimitiveAlgo::minSignalThreshold_
private

Definition at line 162 of file HcalTriggerPrimitiveAlgo.h.

Referenced by addSignal().

◆ NCTScaleShift

int HcalTriggerPrimitiveAlgo::NCTScaleShift
private

Definition at line 164 of file HcalTriggerPrimitiveAlgo.h.

Referenced by run(), and setNCTScaleShift().

◆ numberOfFilterPresamplesHBQIE11_

int HcalTriggerPrimitiveAlgo::numberOfFilterPresamplesHBQIE11_
private

Definition at line 155 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyzeQIE11(), and setNumFilterPresamplesHBQIE11().

◆ numberOfFilterPresamplesHEQIE11_

int HcalTriggerPrimitiveAlgo::numberOfFilterPresamplesHEQIE11_
private

Definition at line 156 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyzeQIE11(), and setNumFilterPresamplesHEQIE11().

◆ numberOfPresamples_

int HcalTriggerPrimitiveAlgo::numberOfPresamples_
private

Definition at line 154 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyze(), analyzeQIE11(), and HcalTriggerPrimitiveAlgo().

◆ numberOfPresamplesHF_

int HcalTriggerPrimitiveAlgo::numberOfPresamplesHF_
private

◆ numberOfPresamplesZDC_

int HcalTriggerPrimitiveAlgo::numberOfPresamplesZDC_
private

Definition at line 160 of file HcalTriggerPrimitiveAlgo.h.

Referenced by HcalTriggerPrimitiveAlgo().

◆ numberOfSamples_

int HcalTriggerPrimitiveAlgo::numberOfSamples_
private

Definition at line 153 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyze(), analyzeQIE11(), and HcalTriggerPrimitiveAlgo().

◆ numberOfSamplesHF_

int HcalTriggerPrimitiveAlgo::numberOfSamplesHF_
private

◆ numberOfSamplesZDC_

int HcalTriggerPrimitiveAlgo::numberOfSamplesZDC_
private

Definition at line 159 of file HcalTriggerPrimitiveAlgo.h.

Referenced by HcalTriggerPrimitiveAlgo().

◆ outcoder_

const HcalTPGCompressor* HcalTriggerPrimitiveAlgo::outcoder_
private

◆ override_adc_hf_

bool HcalTriggerPrimitiveAlgo::override_adc_hf_ = false
private

Definition at line 239 of file HcalTriggerPrimitiveAlgo.h.

Referenced by overrideParameters(), and passTDC().

◆ override_adc_hf_value_

uint32_t HcalTriggerPrimitiveAlgo::override_adc_hf_value_
private

Definition at line 240 of file HcalTriggerPrimitiveAlgo.h.

Referenced by overrideParameters(), and passTDC().

◆ override_parameters_

edm::ParameterSet HcalTriggerPrimitiveAlgo::override_parameters_
private

Definition at line 237 of file HcalTriggerPrimitiveAlgo.h.

Referenced by overrideParameters(), and run().

◆ override_tdc_hf_

bool HcalTriggerPrimitiveAlgo::override_tdc_hf_ = false
private

Definition at line 241 of file HcalTriggerPrimitiveAlgo.h.

Referenced by overrideParameters(), and passTDC().

◆ override_tdc_hf_value_

unsigned long long HcalTriggerPrimitiveAlgo::override_tdc_hf_value_
private

Definition at line 242 of file HcalTriggerPrimitiveAlgo.h.

Referenced by overrideParameters(), and passTDC().

◆ peak_finder_algorithm_

int HcalTriggerPrimitiveAlgo::peak_finder_algorithm_
private

Definition at line 171 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyze(), and setPeakFinderAlgorithm().

◆ peakfind_

bool HcalTriggerPrimitiveAlgo::peakfind_
private

Definition at line 144 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyze(), and HcalTriggerPrimitiveAlgo().

◆ PMT_NoiseThreshold_

uint32_t HcalTriggerPrimitiveAlgo::PMT_NoiseThreshold_
private

Definition at line 163 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyzeHF().

◆ QIE10_LINEARIZATION_ET

const int HcalTriggerPrimitiveAlgo::QIE10_LINEARIZATION_ET = HcaluLUTTPGCoder::QIE10_LUT_BITMASK
staticprivate

Definition at line 254 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyzeHFQIE10().

◆ QIE10_MAX_LINEARIZATION_ET

const int HcalTriggerPrimitiveAlgo::QIE10_MAX_LINEARIZATION_ET = 0x7FF
staticprivate

Definition at line 257 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyzeHFQIE10().

◆ QIE10_ZDC_MAX_LINEARIZATION_ET

const int HcalTriggerPrimitiveAlgo::QIE10_ZDC_MAX_LINEARIZATION_ET = 0x3FF
staticprivate

Definition at line 259 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyzeZDC().

◆ QIE11_LINEARIZATION_ET

const int HcalTriggerPrimitiveAlgo::QIE11_LINEARIZATION_ET = HcaluLUTTPGCoder::QIE11_LUT_BITMASK
staticprivate

Definition at line 255 of file HcalTriggerPrimitiveAlgo.h.

Referenced by addSignal().

◆ QIE11_MAX_LINEARIZATION_ET

const int HcalTriggerPrimitiveAlgo::QIE11_MAX_LINEARIZATION_ET = 0x7FF
staticprivate

Definition at line 258 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyzeQIE11().

◆ QIE8_LINEARIZATION_ET

const int HcalTriggerPrimitiveAlgo::QIE8_LINEARIZATION_ET = HcaluLUTTPGCoder::QIE8_LUT_BITMASK
staticprivate

Definition at line 253 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyze(), analyzeHF(), and analyzeHF2016().

◆ RCTScaleShift

int HcalTriggerPrimitiveAlgo::RCTScaleShift
private

Definition at line 165 of file HcalTriggerPrimitiveAlgo.h.

Referenced by run(), and setRCTScaleShift().

◆ theHFDetailMap

HFDetailMap HcalTriggerPrimitiveAlgo::theHFDetailMap
private

Definition at line 191 of file HcalTriggerPrimitiveAlgo.h.

Referenced by addSignal(), analyzeHF2016(), and run().

◆ theHFUpgradeDetailMap

HFUpgradeDetailMap HcalTriggerPrimitiveAlgo::theHFUpgradeDetailMap
private

Definition at line 201 of file HcalTriggerPrimitiveAlgo.h.

Referenced by addSignal(), analyzeHFQIE10(), and run().

◆ theSatMap

SatMap HcalTriggerPrimitiveAlgo::theSatMap
private

Definition at line 182 of file HcalTriggerPrimitiveAlgo.h.

Referenced by addSignal(), and run().

◆ theSumMap

SumMap HcalTriggerPrimitiveAlgo::theSumMap
private

Definition at line 179 of file HcalTriggerPrimitiveAlgo.h.

Referenced by addSignal(), and run().

◆ theThreshold

double HcalTriggerPrimitiveAlgo::theThreshold
private

Definition at line 143 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyze(), and analyzeQIE11().

◆ theTowerMapFGSum

TowerMapFGSum HcalTriggerPrimitiveAlgo::theTowerMapFGSum
private

Definition at line 205 of file HcalTriggerPrimitiveAlgo.h.

Referenced by addSignal(), analyzeHF(), and run().

◆ theTrigTowerGeometry

const HcalTrigTowerGeometry* HcalTriggerPrimitiveAlgo::theTrigTowerGeometry
private

◆ upgrade_hb_

bool HcalTriggerPrimitiveAlgo::upgrade_hb_ = false
private

Definition at line 231 of file HcalTriggerPrimitiveAlgo.h.

Referenced by needLegacyFG(), run(), setUpgradeFlags(), and validUpgradeFG().

◆ upgrade_he_

bool HcalTriggerPrimitiveAlgo::upgrade_he_ = false
private

Definition at line 232 of file HcalTriggerPrimitiveAlgo.h.

Referenced by run(), and setUpgradeFlags().

◆ upgrade_hf_

bool HcalTriggerPrimitiveAlgo::upgrade_hf_ = false
private

Definition at line 233 of file HcalTriggerPrimitiveAlgo.h.

Referenced by run(), and setUpgradeFlags().

◆ useTDCInMinBiasBits_

bool HcalTriggerPrimitiveAlgo::useTDCInMinBiasBits_
private

Definition at line 161 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyzeHFQIE10().

◆ weights_

std::vector<double> HcalTriggerPrimitiveAlgo::weights_
private

Definition at line 145 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyze().

◆ weightsQIE11_

std::array<std::array<int, 2>, 29> HcalTriggerPrimitiveAlgo::weightsQIE11_
private

Definition at line 146 of file HcalTriggerPrimitiveAlgo.h.

Referenced by analyzeQIE11(), setWeightQIE11(), and setWeightsQIE11().

◆ ZS_threshold_

uint32_t HcalTriggerPrimitiveAlgo::ZS_threshold_
private

Definition at line 151 of file HcalTriggerPrimitiveAlgo.h.

Referenced by HcalTriggerPrimitiveAlgo().

◆ ZS_threshold_I_

int HcalTriggerPrimitiveAlgo::ZS_threshold_I_
private

Definition at line 152 of file HcalTriggerPrimitiveAlgo.h.

Referenced by HcalTriggerPrimitiveAlgo(), and runZS().