Main Page
Namespaces
Classes
Package Documentation
src
DataFormats
TrackerRecHit2D
src
SiPixelRecHitQuality.cc
Go to the documentation of this file.
1
#include "
DataFormats/TrackerRecHit2D/interface/SiPixelRecHitQuality.h
"
2
3
#include "
FWCore/MessageLogger/interface/MessageLogger.h
"
4
5
SiPixelRecHitQuality::Packing::Packing
()
6
{
7
// Constructor: pre-computes masks and shifts from field widths
8
// X is now XY
9
// Y is now Q
10
probX_width
= 14;
11
probY_width
= 8;
12
qBin_width
= 3;
13
edge_width
= 1;
14
bad_width
= 1;
15
twoROC_width
= 1;
16
hasFilledProb_width
= 1;
17
spare_width
= 3;
18
19
if
(
probX_width
+
probY_width
+
qBin_width
+
edge_width
+
20
bad_width
+
twoROC_width
+
hasFilledProb_width
+
spare_width
21
!= 32 ) {
22
throw
cms::Exception
(
"SiPixelRecHitQuality::Packing: "
)
23
<<
"\nERROR: The allocated bits for the quality word to not sum to 32."
24
<<
"\n\n"
;
25
}
26
27
probX_units
= 1.0018;
28
probY_units
= 1.0461;
29
probX_1_over_log_units
= 1.0 /
log
(
probX_units
);
30
probY_1_over_log_units
= 1.0 /
log
(
probY_units
);
31
32
// Fields are counted from right to left!
33
probX_shift
= 0;
34
probY_shift
=
probX_shift
+
probX_width
;
35
qBin_shift
=
probY_shift
+
probY_width
;
36
edge_shift
=
qBin_shift
+
qBin_width
;
37
bad_shift
=
edge_shift
+
edge_width
;
38
twoROC_shift
=
bad_shift
+
bad_width
;
39
hasFilledProb_shift
=
twoROC_shift
+
twoROC_width
;
40
41
// Ensure the complement of the correct
42
// number of bits:
43
QualWordType
zero32 = 0;
// 32-bit wide set of 0's
44
45
probX_mask
= ~(~zero32 <<
probX_width
);
46
probY_mask
= ~(~zero32 <<
probY_width
);
47
qBin_mask
= ~(~zero32 <<
qBin_width
);
48
edge_mask
= ~(~zero32 <<
edge_width
);
49
bad_mask
= ~(~zero32 <<
bad_width
);
50
twoROC_mask
= ~(~zero32 <<
twoROC_width
);
51
hasFilledProb_mask
= ~(~zero32 <<
hasFilledProb_width
);
52
}
53
54
// Initialize the packing format singleton
55
const
SiPixelRecHitQuality::Packing
SiPixelRecHitQuality::thePacking
;
56
SiPixelRecHitQuality::Packing::probX_shift
int probX_shift
Definition:
SiPixelRecHitQuality.h:23
SiPixelRecHitQuality::Packing::probX_1_over_log_units
double probX_1_over_log_units
Definition:
SiPixelRecHitQuality.h:25
SiPixelRecHitQuality::thePacking
static const Packing thePacking
Definition:
SiPixelRecHitQuality.h:171
MessageLogger.h
SiPixelRecHitQuality::Packing::probX_mask
QualWordType probX_mask
Definition:
SiPixelRecHitQuality.h:22
Exception
Definition:
hltDiff.cc:292
SiPixelRecHitQuality::Packing::qBin_shift
int qBin_shift
Definition:
SiPixelRecHitQuality.h:35
SiPixelRecHitQuality::Packing::hasFilledProb_shift
int hasFilledProb_shift
Definition:
SiPixelRecHitQuality.h:51
SiPixelRecHitQuality::Packing::Packing
Packing()
Definition:
SiPixelRecHitQuality.cc:5
SiPixelRecHitQuality::Packing::probY_shift
int probY_shift
Definition:
SiPixelRecHitQuality.h:29
SiPixelRecHitQuality::Packing::probY_mask
QualWordType probY_mask
Definition:
SiPixelRecHitQuality.h:28
SiPixelRecHitQuality::Packing::twoROC_mask
QualWordType twoROC_mask
Definition:
SiPixelRecHitQuality.h:46
SiPixelRecHitQuality::Packing
Definition:
SiPixelRecHitQuality.h:15
SiPixelRecHitQuality::Packing::probY_width
char probY_width
Definition:
SiPixelRecHitQuality.h:32
SiPixelRecHitQuality::Packing::probY_1_over_log_units
double probY_1_over_log_units
Definition:
SiPixelRecHitQuality.h:31
SiPixelRecHitQuality::Packing::qBin_width
char qBin_width
Definition:
SiPixelRecHitQuality.h:36
SiPixelRecHitQuality::Packing::twoROC_width
char twoROC_width
Definition:
SiPixelRecHitQuality.h:48
SiPixelRecHitQuality::Packing::qBin_mask
QualWordType qBin_mask
Definition:
SiPixelRecHitQuality.h:34
SiPixelRecHitQuality::Packing::bad_mask
QualWordType bad_mask
Definition:
SiPixelRecHitQuality.h:42
SiPixelRecHitQuality::Packing::twoROC_shift
int twoROC_shift
Definition:
SiPixelRecHitQuality.h:47
SiPixelRecHitQuality::Packing::edge_width
char edge_width
Definition:
SiPixelRecHitQuality.h:40
cmsBatch.log
log
Definition:
cmsBatch.py:343
SiPixelRecHitQuality::Packing::bad_shift
int bad_shift
Definition:
SiPixelRecHitQuality.h:43
SiPixelRecHitQuality::Packing::edge_mask
QualWordType edge_mask
Definition:
SiPixelRecHitQuality.h:38
SiPixelRecHitQuality::Packing::bad_width
char bad_width
Definition:
SiPixelRecHitQuality.h:44
SiPixelRecHitQuality::QualWordType
unsigned int QualWordType
Definition:
SiPixelRecHitQuality.h:10
SiPixelRecHitQuality::Packing::probX_width
char probX_width
Definition:
SiPixelRecHitQuality.h:26
SiPixelRecHitQuality::Packing::probX_units
float probX_units
Definition:
SiPixelRecHitQuality.h:24
SiPixelRecHitQuality::Packing::spare_width
char spare_width
Definition:
SiPixelRecHitQuality.h:54
SiPixelRecHitQuality::Packing::probY_units
float probY_units
Definition:
SiPixelRecHitQuality.h:30
SiPixelRecHitQuality.h
SiPixelRecHitQuality::Packing::edge_shift
int edge_shift
Definition:
SiPixelRecHitQuality.h:39
SiPixelRecHitQuality::Packing::hasFilledProb_mask
QualWordType hasFilledProb_mask
Definition:
SiPixelRecHitQuality.h:50
SiPixelRecHitQuality::Packing::hasFilledProb_width
char hasFilledProb_width
Definition:
SiPixelRecHitQuality.h:52
Generated for CMSSW Reference Manual by
1.8.11