CMS 3D CMS Logo

List of all members | Classes | Public Member Functions | Protected Attributes | Private Attributes
SiStripDetSummary Class Reference

#include <SiStripDetSummary.h>

Classes

struct  Values
 

Public Member Functions

void add (DetId detid)
 Used to compute the number of entries divided by subdetector, layer and mono/stereo. More...
 
void add (DetId detid, float value)
 Used to compute the mean value of the value variable divided by subdetector, layer and mono/stereo. More...
 
std::map< unsigned int, ValuesgetCounts ()
 
void print (std::stringstream &ss, const bool mean=true) const
 
 SiStripDetSummary (const TrackerTopology *tTopo)
 

Protected Attributes

bool computeMean_
 
std::map< unsigned int, ValuesvalueMap_
 

Private Attributes

const TrackerTopologytrackerTopo_
 

Detailed Description

Author
M. De Mattia
Date
26/3/2009 Class to compute and print summary information.

If values are passed together with DetIds (method add( detId, value)), it computes the mean value and rms of a given quantity and is able to print a summary divided by layer/disk for each subdetector.
If instead only DetIds are passed (method add( detId )), it prints the count divided by layer/disk for each subdetector.

Note: consider the possibility to move this class inside SiStripBaseObject as a protected member class.

Definition at line 28 of file SiStripDetSummary.h.

Constructor & Destructor Documentation

◆ SiStripDetSummary()

SiStripDetSummary::SiStripDetSummary ( const TrackerTopology tTopo)
inlineexplicit

Definition at line 30 of file SiStripDetSummary.h.

30  : computeMean_(true), trackerTopo_(tTopo) {
31  // Initialize valueMap_ with zeros
32  // WARNING: this initialization is strongly connected with how the map is filled in the add method
33  // TIB: layers = 4, stereo = the first 2
34  // TOB: layers = 6, stereo = the first 2
35  // TEC: wheels = 9, stereo = 9
36  // TID: wheels = 3, stereo = 3
37  unsigned int layers[] = {4, 6, 9, 3};
38  unsigned int stereo[] = {2, 2, 9, 3};
39  Values initValues;
40  for (unsigned int subDet = 0; subDet < 4; ++subDet) {
41  // Layers start from 1
42  for (unsigned int layer = 1; layer <= layers[subDet]; ++layer) {
43  valueMap_[1000 * (subDet + 1) + layer * 10] = initValues;
44  if (layer <= stereo[subDet])
45  valueMap_[1000 * (subDet + 1) + layer * 10 + 1] = initValues;
46  }
47  }
48  }

References hgcalTopologyTester_cfi::layers, and valueMap_.

Member Function Documentation

◆ add() [1/2]

void SiStripDetSummary::add ( DetId  detid)
inline

Used to compute the number of entries divided by subdetector, layer and mono/stereo.

Definition at line 53 of file SiStripDetSummary.h.

53  {
54  computeMean_ = false;
55  add(detid, 0);
56  }

References add(), and computeMean_.

Referenced by counter.Counter::register(), SequenceTypes.Task::remove(), and SequenceTypes.Task::replace().

◆ add() [2/2]

void SiStripDetSummary::add ( DetId  detid,
float  value 
)

Used to compute the mean value of the value variable divided by subdetector, layer and mono/stereo.

Definition at line 6 of file SiStripDetSummary.cc.

6  {
7  int layer = 0;
8  int stereo = 0;
9  int detNum = 0;
10 
11  // Using the operator[] if the element does not exist it is created with the default value. That is 0 for integral types.
12  switch (detid.subdetId()) {
14  layer = trackerTopo_->tibLayer(detid);
15  stereo = trackerTopo_->tibStereo(detid);
16  detNum = 1000;
17  break;
19  layer = trackerTopo_->tobLayer(detid);
20  stereo = trackerTopo_->tobStereo(detid);
21  detNum = 2000;
22  break;
24  // is this module in TEC+ or TEC-?
25  layer = trackerTopo_->tecWheel(detid);
26  stereo = trackerTopo_->tecStereo(detid);
27  detNum = 3000;
28  break;
30  // is this module in TID+ or TID-?
31  layer = trackerTopo_->tidWheel(detid);
32  stereo = trackerTopo_->tidStereo(detid);
33  detNum = 4000;
34  break;
35  }
36  detNum += layer * 10 + stereo;
37  // string name( detector + boost::lexical_cast<string>(layer) + boost::lexical_cast<string>(stereo) );
38  valueMap_[detNum].mean += value;
39  valueMap_[detNum].rms += value * value;
40  valueMap_[detNum].count += 1;
41 }

References DetId::subdetId(), StripSubdetector::TEC, TrackerTopology::tecStereo(), TrackerTopology::tecWheel(), StripSubdetector::TIB, TrackerTopology::tibLayer(), TrackerTopology::tibStereo(), StripSubdetector::TID, TrackerTopology::tidStereo(), TrackerTopology::tidWheel(), StripSubdetector::TOB, TrackerTopology::tobLayer(), TrackerTopology::tobStereo(), trackerTopo_, relativeConstraints::value, and valueMap_.

Referenced by add(), SiStripPI::fillNoiseDetSummary(), counter.Counter::register(), SequenceTypes.Task::remove(), and SequenceTypes.Task::replace().

◆ getCounts()

std::map<unsigned int, Values> SiStripDetSummary::getCounts ( )
inline

Definition at line 70 of file SiStripDetSummary.h.

70 { return valueMap_; }

References valueMap_.

◆ print()

void SiStripDetSummary::print ( std::stringstream &  ss,
const bool  mean = true 
) const

Method used to write the output. By default mean == true and it writes the mean value. If mean == false it will write the count.

Definition at line 43 of file SiStripDetSummary.cc.

43  {
44  // Compute the mean for each detector and for each layer.
45  std::map<unsigned int, Values>::const_iterator valueMapIt = valueMap_.begin();
46 
47  ss << "subDet" << std::setw(15) << "layer" << std::setw(16) << "mono/stereo" << std::setw(20);
48  if (mean)
49  ss << "mean +- rms" << std::endl;
50  else
51  ss << "count" << std::endl;
52 
54  std::string oldDetector;
55 
56  for (; valueMapIt != valueMap_.end(); ++valueMapIt) {
57  int count = valueMapIt->second.count;
58  double mean = 0.;
59  double rms = 0.;
60  if (computeMean_ && count != 0) {
61  mean = (valueMapIt->second.mean) / count;
62  rms = (valueMapIt->second.rms) / count - mean * mean;
63  if (rms <= 0)
64  rms = 0;
65  else
66  rms = sqrt(rms);
67  }
68  // Detector type
69  switch ((valueMapIt->first) / 1000) {
70  case 1:
71  detector = "TIB ";
72  break;
73  case 2:
74  detector = "TOB ";
75  break;
76  case 3:
77  detector = "TEC ";
78  break;
79  case 4:
80  detector = "TID ";
81  break;
82  }
83  if (detector != oldDetector) {
84  ss << std::endl << detector;
85  oldDetector = detector;
86  } else
87  ss << " ";
88  // Layer number
89  int layer = (valueMapIt->first) / 10 - (valueMapIt->first) / 1000 * 100;
90  int stereo = valueMapIt->first - layer * 10 - (valueMapIt->first) / 1000 * 1000;
91 
92  ss << std::setw(15) << layer << std::setw(13) << stereo << std::setw(18);
93  if (computeMean_)
94  ss << mean << " +- " << rms << std::endl;
95  else
96  ss << count << std::endl;
97  }
98 }

References computeMean_, KineDebug3::count(), hgcalTestNeighbor_cfi::detector, SiStripPI::mean, SiStripPI::rms, mathSSE::sqrt(), contentValuesCheck::ss, AlCaHLTBitMon_QueryRunRegistry::string, and valueMap_.

Member Data Documentation

◆ computeMean_

bool SiStripDetSummary::computeMean_
protected

Definition at line 75 of file SiStripDetSummary.h.

Referenced by add(), and print().

◆ trackerTopo_

const TrackerTopology* SiStripDetSummary::trackerTopo_
private

Definition at line 78 of file SiStripDetSummary.h.

Referenced by add().

◆ valueMap_

std::map<unsigned int, Values> SiStripDetSummary::valueMap_
protected

Definition at line 74 of file SiStripDetSummary.h.

Referenced by add(), getCounts(), print(), and SiStripDetSummary().

SiStripPI::mean
Definition: SiStripPayloadInspectorHelper.h:169
SiStripPI::rms
Definition: SiStripPayloadInspectorHelper.h:169
TrackerTopology::tobStereo
uint32_t tobStereo(const DetId &id) const
Definition: TrackerTopology.h:275
TrackerTopology::tidWheel
unsigned int tidWheel(const DetId &id) const
Definition: TrackerTopology.h:201
SiStripDetSummary::trackerTopo_
const TrackerTopology * trackerTopo_
Definition: SiStripDetSummary.h:78
SiStripDetSummary::valueMap_
std::map< unsigned int, Values > valueMap_
Definition: SiStripDetSummary.h:74
contentValuesCheck.ss
ss
Definition: contentValuesCheck.py:33
mathSSE::sqrt
T sqrt(T t)
Definition: SSEVec.h:19
StripSubdetector::TIB
static constexpr auto TIB
Definition: StripSubdetector.h:16
SiStripDetSummary::add
void add(DetId detid, float value)
Used to compute the mean value of the value variable divided by subdetector, layer and mono/stereo.
Definition: SiStripDetSummary.cc:6
DetId::subdetId
constexpr int subdetId() const
get the contents of the subdetector field (not cast into any detector's numbering enum)
Definition: DetId.h:48
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
TrackerTopology::tibStereo
uint32_t tibStereo(const DetId &id) const
Definition: TrackerTopology.h:279
reco::JetExtendedAssociation::Values
std::vector< Value > Values
Definition: JetExtendedAssociation.h:28
KineDebug3::count
void count()
Definition: KinematicConstrainedVertexUpdatorT.h:21
TrackerTopology::tidStereo
uint32_t tidStereo(const DetId &id) const
Definition: TrackerTopology.h:283
value
Definition: value.py:1
SiStripDetSummary::computeMean_
bool computeMean_
Definition: SiStripDetSummary.h:75
TrackerTopology::tobLayer
unsigned int tobLayer(const DetId &id) const
Definition: TrackerTopology.h:147
StripSubdetector::TEC
static constexpr auto TEC
Definition: StripSubdetector.h:19
relativeConstraints.value
value
Definition: relativeConstraints.py:53
StripSubdetector::TOB
static constexpr auto TOB
Definition: StripSubdetector.h:18
hgcalTestNeighbor_cfi.detector
detector
Definition: hgcalTestNeighbor_cfi.py:6
TrackerTopology::tecWheel
unsigned int tecWheel(const DetId &id) const
Definition: TrackerTopology.h:198
hgcalTopologyTester_cfi.layers
layers
Definition: hgcalTopologyTester_cfi.py:8
StripSubdetector::TID
static constexpr auto TID
Definition: StripSubdetector.h:17
TrackerTopology::tecStereo
uint32_t tecStereo(const DetId &id) const
Definition: TrackerTopology.h:287
TrackerTopology::tibLayer
unsigned int tibLayer(const DetId &id) const
Definition: TrackerTopology.h:150