#include <CSCConditions.h>
Public Member Functions | |
float | anodeBXoffset (const CSCDetId &detId) const |
anode bx offset in bx given detId of chamber More... | |
float | averageGain () const |
average gain over entire CSC system (logically const although must be cached here). More... | |
const std::bitset< 112 > & | badStripWord () const |
bad strip channel word for a CSCLayer - 1 bit per channel More... | |
const std::bitset< 112 > & | badWireWord () const |
bad wiregroup channel word for a CSCLayer - 1 bit per channel More... | |
float | chamberTimingCorrection (const CSCDetId &detId) const |
chamber timing correction in ns given detId of chamber More... | |
int | channelFromStrip (const CSCDetId &id, int geomStrip) const |
feedthrough for external access More... | |
float | chipCorrection (const CSCDetId &detId, int channel) const |
chip speed correction in ns given detId (w/layer) and strip channel More... | |
void | crossTalk (const CSCDetId &id, int channel, std::vector< float > &ct) const |
fill vector (dim 4, must be allocated by caller) with crosstalk sl, il, sr, ir More... | |
float | crosstalkIntercept (const CSCDetId &detId, int channel, bool leftRight) const |
crosstalk intercept for left and right More... | |
float | crosstalkSlope (const CSCDetId &detId, int channel, bool leftRight) const |
crosstalk slope for left and right More... | |
CSCConditions (const edm::ParameterSet &ps) | |
void | fillBadChannelWords (const CSCDetId &id) |
Fill bad channel words - one for strips, one for wires, for an offline CSCDetId. More... | |
float | gain (const CSCDetId &detId, int channel) const |
gain per channel More... | |
float | gainSigma (const CSCDetId &detId, int channel) const |
overall calibration precision More... | |
float | gasGainCorrection (const CSCDetId &detId, int strip, int wire) const |
gas gain correction as a function of detId (w/layer), strip, and wire channels More... | |
const CSCDetId & | idOfBadChannelWords () const |
the offline CSCDetId of current bad channel words More... | |
void | initializeEvent (const edm::EventSetup &es) |
fetch database content via EventSetup More... | |
bool | isInBadChamber (const CSCDetId &id) const |
Is the gven chamber flagged as bad? More... | |
const CSCDBNoiseMatrix::Item & | noiseMatrix (const CSCDetId &detId, int channel) const |
raw noise matrix (unscaled short int elements) More... | |
void | noiseMatrixElements (const CSCDetId &id, int channel, std::vector< float > &me) const |
fill vector (dim 12, must be allocated by caller) with noise matrix elements (scaled to float) More... | |
float | pedestal (const CSCDetId &detId, int channel) const |
static ped in ADC counts More... | |
float | pedestalSigma (const CSCDetId &detId, int channel) const |
static ped rms in ADC counts More... | |
void | print () const |
int | rawStripChannel (const CSCDetId &id, int geomChannel) const |
bool | readBadChambers () const |
did we request reading bad chamber info from db? More... | |
bool | readBadChannels () const |
did we request reading bad channel info from db? More... | |
bool | useGasGainCorrections () const |
did we request reading gas gain correction info from db? More... | |
bool | useTimingCorrections () const |
did we request reading timing correction info from db? More... | |
~CSCConditions () | |
Private Types | |
enum | elayers { MAX_LAYERS = 3240 } |
Private Member Functions | |
void | fillBadStripWord (const CSCDetId &id) |
fill bad channel words for offline id More... | |
void | fillBadWireWord (const CSCDetId &id) |
void | setIdOfBadChannelWords (const CSCDetId &id) |
Set id for current content of bad channel words - this is offline id i.e. separate for ME11A & ME11B. More... | |
Encapsulates a user interface into the CSC conditions
Interfaces generally use "channels" which count from 1 and are 'geometric' i.e. in the order matching local coordinates. This is the channel labelling in CSCStripDigi (and CSCWireDigi) after internal corrections within CSCRawToDigi.
The input CSCDetId is also 'geometric channel level' i.e. ME11A has its own CSCDetId even in the ganged case,
Ganged ME1a channels are 1-16 (and unganged, of course, 1-48)
From CMSSW 61X, this class also handles separate algorithm versions for indexing the conditions data and for mapping between online and offline channel labelling.
Definition at line 46 of file CSCConditions.h.
|
private |
Enumerator | |
---|---|
MAX_LAYERS |
Definition at line 181 of file CSCConditions.h.
|
explicit |
Definition at line 37 of file CSCConditions.cc.
References edm::ParameterSet::getParameter(), readBadChambers_, readBadChannels_, useGasGainCorrections_, and useTimingCorrections_.
CSCConditions::~CSCConditions | ( | ) |
Definition at line 54 of file CSCConditions.cc.
float CSCConditions::anodeBXoffset | ( | const CSCDetId & | detId | ) | const |
anode bx offset in bx given detId of chamber
Definition at line 337 of file CSCConditions.cc.
References CSCChamberTimeCorrections::ChamberTimeCorrections::anode_bx_offset, CSCIndexerBase::chamberIndex(), objects.autophobj::float, diffTreeTool::index, indexer_, edm::ESHandleBase::isValid(), CSCChamberTimeCorrections::item(), mapper_, CSCChamberTimeCorrections::precision(), CSCChannelMapperBase::rawCSCDetId(), theChamberTimingCorrections, and useTimingCorrections().
Referenced by CSCRecoConditions::anodeBXoffset(), and gainSigma().
float CSCConditions::averageGain | ( | ) | const |
average gain over entire CSC system (logically const although must be cached here).
Return average strip gain for full CSC system. Lazy evaluation. Restrict averaging to gains between 5 and 10, and require average is between 6 or 9 otherwise fix it to 7.5. These values came from Dominique and Stan,
Definition at line 353 of file CSCConditions.cc.
References objects.autophobj::float, CSCDBGains::gains, CSCDBGains::scale(), theAverageGain, and theGains.
Referenced by CSCRecoConditions::averageGain(), and useTimingCorrections().
|
inline |
bad strip channel word for a CSCLayer - 1 bit per channel
Definition at line 89 of file CSCConditions.h.
References badStripWord_.
Referenced by CSCRecoConditions::badStrip().
|
inline |
bad wiregroup channel word for a CSCLayer - 1 bit per channel
Definition at line 94 of file CSCConditions.h.
References badWireWord_.
Referenced by CSCRecoConditions::badWireWord().
float CSCConditions::chamberTimingCorrection | ( | const CSCDetId & | detId | ) | const |
chamber timing correction in ns given detId of chamber
Definition at line 322 of file CSCConditions.cc.
References CSCChamberTimeCorrections::ChamberTimeCorrections::cfeb_cable_delay, CSCChamberTimeCorrections::ChamberTimeCorrections::cfeb_timing_corr, CSCChamberTimeCorrections::ChamberTimeCorrections::cfeb_tmb_skew_delay, CSCIndexerBase::chamberIndex(), objects.autophobj::float, diffTreeTool::index, indexer_, edm::ESHandleBase::isValid(), CSCChamberTimeCorrections::item(), mapper_, CSCChamberTimeCorrections::precision(), CSCChannelMapperBase::rawCSCDetId(), theChamberTimingCorrections, and useTimingCorrections().
Referenced by CSCRecoConditions::chamberTimingCorrection(), and gainSigma().
int CSCConditions::channelFromStrip | ( | const CSCDetId & | id, |
int | geomStrip | ||
) | const |
feedthrough for external access
Definition at line 403 of file CSCConditions.cc.
References CSCChannelMapperBase::channelFromStrip(), and mapper_.
Referenced by CSCRecoConditions::badStrip(), CSCRecoConditions::chipCorrection(), CSCRecoConditions::crossTalk(), CSCRecoConditions::gasGainCorrection(), CSCRecoConditions::noiseMatrix(), CSCRecoConditions::stripWeight(), and useGasGainCorrections().
float CSCConditions::chipCorrection | ( | const CSCDetId & | detId, |
int | channel | ||
) | const |
chip speed correction in ns given detId (w/layer) and strip channel
Definition at line 309 of file CSCConditions.cc.
References CSCIndexerBase::chipIndex(), objects.autophobj::float, diffTreeTool::index, indexer_, edm::ESHandleBase::isValid(), mapper_, CSCChannelMapperBase::rawCSCDetId(), CSCChannelMapperBase::rawStripChannel(), CSCDBChipSpeedCorrection::scale(), theChipCorrections, useTimingCorrections(), and CSCDBChipSpeedCorrection::value().
Referenced by CSCRecoConditions::chipCorrection(), and gainSigma().
void CSCConditions::crossTalk | ( | const CSCDetId & | id, |
int | channel, | ||
std::vector< float > & | ct | ||
) | const |
fill vector (dim 4, must be allocated by caller) with crosstalk sl, il, sr, ir
Definition at line 297 of file CSCConditions.cc.
References objects.autophobj::float, diffTreeTool::index, indexer_, CSCDBCrosstalk::iscale(), edm::ESHandleBase::isValid(), CSCDBCrosstalk::linter(), CSCDBCrosstalk::lslope(), mapper_, CSCChannelMapperBase::rawCSCDetId(), CSCChannelMapperBase::rawStripChannel(), CSCDBCrosstalk::rinter(), CSCDBCrosstalk::rslope(), CSCDBCrosstalk::sscale(), CSCIndexerBase::stripChannelIndex(), and theCrosstalk.
Referenced by CSCRecoConditions::crossTalk(), and gainSigma().
float CSCConditions::crosstalkIntercept | ( | const CSCDetId & | detId, |
int | channel, | ||
bool | leftRight | ||
) | const |
crosstalk intercept for left and right
Definition at line 245 of file CSCConditions.cc.
References objects.autophobj::float, diffTreeTool::index, indexer_, CSCDBCrosstalk::iscale(), edm::ESHandleBase::isValid(), CSCDBCrosstalk::linter(), mapper_, CSCChannelMapperBase::rawCSCDetId(), CSCChannelMapperBase::rawStripChannel(), CSCDBCrosstalk::rinter(), CSCIndexerBase::stripChannelIndex(), and theCrosstalk.
Referenced by CSCDbStripConditions::crosstalk(), and gainSigma().
float CSCConditions::crosstalkSlope | ( | const CSCDetId & | detId, |
int | channel, | ||
bool | leftRight | ||
) | const |
crosstalk slope for left and right
Definition at line 257 of file CSCConditions.cc.
References objects.autophobj::float, diffTreeTool::index, indexer_, edm::ESHandleBase::isValid(), CSCDBCrosstalk::lslope(), mapper_, CSCChannelMapperBase::rawCSCDetId(), CSCChannelMapperBase::rawStripChannel(), CSCDBCrosstalk::rslope(), CSCDBCrosstalk::sscale(), CSCIndexerBase::stripChannelIndex(), and theCrosstalk.
Referenced by CSCDbStripConditions::crosstalk(), and gainSigma().
void CSCConditions::fillBadChannelWords | ( | const CSCDetId & | id | ) |
Fill bad channel words - one for strips, one for wires, for an offline CSCDetId.
Definition at line 110 of file CSCConditions.cc.
References badStripWord_, badWireWord_, fillBadStripWord(), fillBadWireWord(), idOfBadChannelWords(), mapper_, CSCChannelMapperBase::rawCSCDetId(), readBadChannels(), and setIdOfBadChannelWords().
Referenced by CSCRecoConditions::fillBadChannelWords(), and useTimingCorrections().
|
private |
fill bad channel words for offline id
Next function private.
Definition at line 135 of file CSCConditions.cc.
References badStripWord_, CSCIndexerBase::chamberIndex(), CSCBadStrips::chambers, officialStyle::chan, CSCBadStrips::channels, mps_fire::i, indexer_, and theBadStrips.
Referenced by fillBadChannelWords(), and useGasGainCorrections().
|
private |
Definition at line 172 of file CSCConditions.cc.
References badWireWord_, CSCIndexerBase::chamberIndex(), CSCBadWires::chambers, officialStyle::chan, CSCBadWires::channels, mps_fire::i, indexer_, and theBadWires.
Referenced by fillBadChannelWords(), and useGasGainCorrections().
float CSCConditions::gain | ( | const CSCDetId & | detId, |
int | channel | ||
) | const |
gain per channel
Definition at line 216 of file CSCConditions.cc.
References objects.autophobj::float, CSCDBGains::gain(), diffTreeTool::index, indexer_, edm::ESHandleBase::isValid(), mapper_, CSCChannelMapperBase::rawCSCDetId(), CSCChannelMapperBase::rawStripChannel(), CSCDBGains::scale(), CSCIndexerBase::stripChannelIndex(), and theGains.
Referenced by CSCDbStripConditions::gain(), and CSCRecoConditions::gain().
|
inline |
overall calibration precision
Definition at line 58 of file CSCConditions.h.
References anodeBXoffset(), chamberTimingCorrection(), chipCorrection(), crossTalk(), crosstalkIntercept(), crosstalkSlope(), noiseMatrix(), noiseMatrixElements(), pedestal(), and pedestalSigma().
float CSCConditions::gasGainCorrection | ( | const CSCDetId & | detId, |
int | strip, | ||
int | wire | ||
) | const |
gas gain correction as a function of detId (w/layer), strip, and wire channels
Definition at line 390 of file CSCConditions.cc.
References objects.autophobj::float, CSCIndexerBase::gasGainIndex(), diffTreeTool::index, indexer_, edm::ESHandleBase::isValid(), mapper_, CSCChannelMapperBase::rawCSCDetId(), CSCChannelMapperBase::rawStripChannel(), theGasGainCorrections, useGasGainCorrections(), and CSCDBGasGainCorrection::value().
Referenced by CSCRecoConditions::gasGainCorrection(), and useTimingCorrections().
|
inline |
the offline CSCDetId of current bad channel words
Definition at line 99 of file CSCConditions.h.
References idOfBadChannelWords_, isInBadChamber(), and print().
Referenced by CSCRecoConditions::badStrip(), and fillBadChannelWords().
void CSCConditions::initializeEvent | ( | const edm::EventSetup & | es | ) |
fetch database content via EventSetup
Definition at line 56 of file CSCConditions.cc.
References edm::ESWatcher< T >::check(), gainsWatcher_, edm::EventSetup::get(), indexer_, mapper_, readBadChambers(), readBadChannels(), theAverageGain, theBadChambers, theBadStrips, theBadWires, theChamberTimingCorrections, theChipCorrections, theCrosstalk, theGains, theGasGainCorrections, theNoiseMatrix, thePedestals, useGasGainCorrections(), and useTimingCorrections().
Referenced by CSCDbStripConditions::initializeEvent(), and CSCRecoConditions::initializeEvent().
bool CSCConditions::isInBadChamber | ( | const CSCDetId & | id | ) | const |
Is the gven chamber flagged as bad?
Definition at line 204 of file CSCConditions.cc.
References CSCIndexerBase::chamberIndex(), diffTreeTool::index, indexer_, CSCBadChambers::isInBadChamber(), mapper_, CSCChannelMapperBase::rawCSCDetId(), readBadChambers(), and theBadChambers.
Referenced by idOfBadChannelWords(), and CSCDbStripConditions::isInBadChamber().
const CSCDBNoiseMatrix::Item & CSCConditions::noiseMatrix | ( | const CSCDetId & | detId, |
int | channel | ||
) | const |
raw noise matrix (unscaled short int elements)
Definition at line 268 of file CSCConditions.cc.
References diffTreeTool::index, indexer_, edm::ESHandleBase::isValid(), CSCDBNoiseMatrix::item(), mapper_, CSCChannelMapperBase::rawCSCDetId(), CSCChannelMapperBase::rawStripChannel(), CSCIndexerBase::stripChannelIndex(), and theNoiseMatrix.
Referenced by gainSigma(), and noiseMatrixElements().
void CSCConditions::noiseMatrixElements | ( | const CSCDetId & | id, |
int | channel, | ||
std::vector< float > & | me | ||
) | const |
fill vector (dim 12, must be allocated by caller) with noise matrix elements (scaled to float)
Definition at line 280 of file CSCConditions.cc.
References objects.autophobj::float, noiseMatrix(), CSCDBNoiseMatrix::scale(), and theNoiseMatrix.
Referenced by CSCDbStripConditions::fetchNoisifier(), gainSigma(), and CSCRecoConditions::noiseMatrix().
float CSCConditions::pedestal | ( | const CSCDetId & | detId, |
int | channel | ||
) | const |
static ped in ADC counts
Definition at line 225 of file CSCConditions.cc.
References objects.autophobj::float, diffTreeTool::index, indexer_, edm::ESHandleBase::isValid(), mapper_, CSCDBPedestals::pedestal(), CSCChannelMapperBase::rawCSCDetId(), CSCChannelMapperBase::rawStripChannel(), CSCDBPedestals::scale_ped(), CSCIndexerBase::stripChannelIndex(), and thePedestals.
Referenced by gainSigma(), CSCDbStripConditions::pedestal(), and CSCRecoConditions::pedestal().
float CSCConditions::pedestalSigma | ( | const CSCDetId & | detId, |
int | channel | ||
) | const |
static ped rms in ADC counts
Definition at line 235 of file CSCConditions.cc.
References objects.autophobj::float, diffTreeTool::index, indexer_, edm::ESHandleBase::isValid(), mapper_, CSCDBPedestals::pedestal_rms(), CSCChannelMapperBase::rawCSCDetId(), CSCChannelMapperBase::rawStripChannel(), CSCDBPedestals::scale_rms(), CSCIndexerBase::stripChannelIndex(), and thePedestals.
Referenced by gainSigma(), CSCDbStripConditions::pedestalSigma(), and CSCRecoConditions::pedestalSigma().
void CSCConditions::print | ( | void | ) | const |
Definition at line 410 of file CSCConditions.cc.
Referenced by idOfBadChannelWords().
int CSCConditions::rawStripChannel | ( | const CSCDetId & | id, |
int | geomChannel | ||
) | const |
Definition at line 406 of file CSCConditions.cc.
References mapper_, and CSCChannelMapperBase::rawStripChannel().
Referenced by CSCRecoConditions::badStrip(), and useGasGainCorrections().
|
inline |
did we request reading bad chamber info from db?
Definition at line 112 of file CSCConditions.h.
References readBadChambers_.
Referenced by initializeEvent(), and isInBadChamber().
|
inline |
did we request reading bad channel info from db?
Definition at line 109 of file CSCConditions.h.
References readBadChannels_.
Referenced by fillBadChannelWords(), and initializeEvent().
|
inlineprivate |
Set id for current content of bad channel words - this is offline id i.e. separate for ME11A & ME11B.
Definition at line 139 of file CSCConditions.h.
References hcalTTPDigis_cfi::id, and idOfBadChannelWords_.
Referenced by fillBadChannelWords().
|
inline |
did we request reading gas gain correction info from db?
Definition at line 127 of file CSCConditions.h.
References channelFromStrip(), fillBadStripWord(), fillBadWireWord(), rawStripChannel(), and useGasGainCorrections_.
Referenced by gasGainCorrection(), and initializeEvent().
|
inline |
did we request reading timing correction info from db?
Definition at line 115 of file CSCConditions.h.
References averageGain(), fillBadChannelWords(), gasGainCorrection(), digi_MixPreMix_cfi::strip, and useTimingCorrections_.
Referenced by anodeBXoffset(), chamberTimingCorrection(), chipCorrection(), and initializeEvent().
|
private |
Definition at line 170 of file CSCConditions.h.
Referenced by badStripWord(), fillBadChannelWords(), and fillBadStripWord().
|
private |
Definition at line 171 of file CSCConditions.h.
Referenced by badWireWord(), fillBadChannelWords(), and fillBadWireWord().
|
private |
Definition at line 175 of file CSCConditions.h.
Referenced by initializeEvent().
|
private |
Definition at line 169 of file CSCConditions.h.
Referenced by idOfBadChannelWords(), and setIdOfBadChannelWords().
|
private |
Definition at line 158 of file CSCConditions.h.
Referenced by anodeBXoffset(), chamberTimingCorrection(), chipCorrection(), crossTalk(), crosstalkIntercept(), crosstalkSlope(), fillBadStripWord(), fillBadWireWord(), gain(), gasGainCorrection(), initializeEvent(), isInBadChamber(), noiseMatrix(), pedestal(), and pedestalSigma().
|
private |
Definition at line 159 of file CSCConditions.h.
Referenced by anodeBXoffset(), chamberTimingCorrection(), channelFromStrip(), chipCorrection(), crossTalk(), crosstalkIntercept(), crosstalkSlope(), fillBadChannelWords(), gain(), gasGainCorrection(), initializeEvent(), isInBadChamber(), noiseMatrix(), pedestal(), pedestalSigma(), and rawStripChannel().
|
private |
Definition at line 164 of file CSCConditions.h.
Referenced by CSCConditions(), and readBadChambers().
|
private |
Definition at line 163 of file CSCConditions.h.
Referenced by CSCConditions(), and readBadChannels().
|
mutableprivate |
Definition at line 173 of file CSCConditions.h.
Referenced by averageGain(), and initializeEvent().
|
private |
Definition at line 151 of file CSCConditions.h.
Referenced by initializeEvent(), and isInBadChamber().
|
private |
Definition at line 149 of file CSCConditions.h.
Referenced by fillBadStripWord(), and initializeEvent().
|
private |
Definition at line 150 of file CSCConditions.h.
Referenced by fillBadWireWord(), and initializeEvent().
|
private |
Definition at line 153 of file CSCConditions.h.
Referenced by anodeBXoffset(), chamberTimingCorrection(), and initializeEvent().
|
private |
Definition at line 152 of file CSCConditions.h.
Referenced by chipCorrection(), and initializeEvent().
|
private |
Definition at line 146 of file CSCConditions.h.
Referenced by crossTalk(), crosstalkIntercept(), crosstalkSlope(), and initializeEvent().
|
private |
Definition at line 145 of file CSCConditions.h.
Referenced by averageGain(), gain(), and initializeEvent().
|
private |
Definition at line 154 of file CSCConditions.h.
Referenced by gasGainCorrection(), and initializeEvent().
|
private |
Definition at line 148 of file CSCConditions.h.
Referenced by initializeEvent(), noiseMatrix(), and noiseMatrixElements().
|
private |
Definition at line 147 of file CSCConditions.h.
Referenced by initializeEvent(), pedestal(), and pedestalSigma().
|
private |
Definition at line 166 of file CSCConditions.h.
Referenced by CSCConditions(), and useGasGainCorrections().
|
private |
Definition at line 165 of file CSCConditions.h.
Referenced by CSCConditions(), and useTimingCorrections().