|
|
Go to the documentation of this file.
45 static constexpr
float inv_sqrt_12 = 0.2886751;
55 int wg_left = wgroups[0];
57 int wg_right = wgroups[wgroups.size() - 1];
65 int centerWire_left = (
int)(Mwire1 - Nwires1 / 2. + 0.5);
66 int centerWire_right = (
int)(Mwire2 + Nwires2 / 2.);
68 float centerWire = (centerWire_left + centerWire_right) / 2.;
74 if (wHit.
deadWG() > 0 || wgroups.size() > 2) {
76 for (
unsigned int iWG = 0; iWG < wgroups.size(); iWG++) {
79 }
else if (2 == wgroups.size()) {
87 }
else if (1 == wgroups.size()) {
96 int nStrip =
strips.size();
97 int idCenterStrip = nStrip / 2;
98 int centerStrip =
strips[idCenterStrip];
101 const std::vector<float>&
adc = sHit.
s_adc();
102 const std::vector<float>& adcRaw = sHit.
s_adcRaw();
104 std::vector<float> adc2;
105 std::vector<float> adc2Raw;
107 LogTrace(
"CSCMake2DRecHit") <<
"[CSCMake2DRecHit] dump of adc values to be added to rechit follows...";
109 for (
int iStrip = 0; iStrip < nStrip; ++iStrip) {
114 for (
int t = 0;
t < 4; ++
t) {
115 adc2.push_back(
adc[
t + iStrip * 4]);
116 adc2Raw.push_back(adcRaw[
t + iStrip * 4]);
119 adcMap.
put(
strips[iStrip], adc2.begin(), adc2.end());
123 LogTrace(
"CSCMake2DRecHit") <<
"[CSCMake2DRecHit] strip = " <<
strips[iStrip] <<
" adcs= " << adc2Raw[0] <<
" "
124 << adc2Raw[1] <<
" " << adc2Raw[2] <<
" " << adc2Raw[3];
130 for (
int t = 0;
t < 4; ++
t) {
131 int k =
t + 4 * (idCenterStrip);
132 adcArray[
t] =
adc[
k];
136 LogTrace(
"CSCRecHit") <<
"[CSCMake2DRecHit] " <<
id <<
" strip=" << centerStrip <<
", t_zero=" << tpeak - 133.f
137 <<
", tpeak=" << tpeak;
139 float positionWithinTheStrip = -99.;
140 float sigmaWithinTheStrip = -99.;
151 float stripWidth = -99.f;
153 if (centerStrip == 1 || centerStrip ==
specs_->
nStrips() || nStrip < 2) {
155 positionWithinTheStrip = 0.f;
157 sigmaWithinTheStrip = stripWidth * inv_sqrt_12;
162 float ymiddle = lp11.
y();
166 float xWithinChamber = lp11.
x();
177 positionWithinTheStrip,
190 float phaseCorrection = (sHit.
stripsl1a()[0] >> (15 - 0) & 0
x1) * 25.;
194 float tofCorrection = gp0.
mag() / 29.9792458;
195 float signalPropagationSpeed[11] = {0.0, -78, -76, -188, -262, -97, -99, -90, -99, -99, -113};
202 tpeak = tpeak + chipCorrection + phaseCorrection + chamberCorrection - tofCorrection + yCorrection;
212 float gasGainCorrection = -999.f;
225 float energyDeposit = -999.f;
226 if (gasGainCorrection < -998.
f) {
228 energyDeposit = -998.f;
230 }
else if (gasGainCorrection < 0.
f) {
232 energyDeposit = -997.f;
236 if (adcMap.
size() == 12) {
237 energyDeposit = adcMap[0] * gasGainCorrection + adcMap[1] * gasGainCorrection + adcMap[2] * gasGainCorrection +
238 adcMap[4] * gasGainCorrection + adcMap[5] * gasGainCorrection + adcMap[6] * gasGainCorrection +
239 adcMap[8] * gasGainCorrection + adcMap[9] * gasGainCorrection + adcMap[10] * gasGainCorrection;
241 }
else if (adcMap.
size() == 4) {
243 energyDeposit = -996.f;
263 positionWithinTheStrip,
264 sigmaWithinTheStrip / stripWidth,
274 LogTrace(
"CSCRecHit") <<
"[CSCMake2DRecHit] rechit created in layer " <<
id <<
"... \n" << rechit;
280 bool isInFiducial =
true;
288 isInFiducial =
false;
306 float timeGuess = tpeak / 25.f + anode_bx_offset;
307 float diffMin = 9999.f;
309 for (
int j = 0;
j < (
int)timeBinsOn.size();
j++) {
310 auto diff = timeGuess - timeBinsOn[
j];
315 wireBx = timeBinsOn[
j];
318 int side = diffMin > 0 ? 1 : -1;
319 bool unchanged =
true;
322 (
bestMatch + side) < (
int)timeBinsOn.size()) {
326 wireBx = wireBx + 0.5f * side;
334 wireBx = wireBx - 0.5f * side;
337 return wireBx - anode_bx_offset;
CSCMake2DRecHit(const edm::ParameterSet &)
std::vector< int > ChannelContainer
float chipCorrection(const CSCDetId &detId, int channel) const
All other functions are accessed by geometrical strip label (i.e. strip number according to local coo...
const CSCChamber * chamber() const
const std::unique_ptr< CSCFindPeakTime > peakTimeFinder_
float chamberTimingCorrection(const CSCDetId &id) const
LocalError localError(int strip, float sigmaStrip, float sigmaWire) const
Point3DBase< Scalar, LocalTag > LocalPoint
void put(ID id, CI begin, CI end)
insert an object range with specified identifier
def bestMatch(object, matchCollection)
unsigned short iChamberType() const
size_t size() const
return number of contained object
static const double tmax[3]
Sin< T >::type sin(const T &t)
constexpr int adc(sample_type sample)
get the ADC sample (12 bits)
int numberOfWiresPerGroup(int wireGroup) const
const CSCLayerGeometry * layergeom_
const CSCChamberSpecs * specs_
float findWireBx(const std::vector< int > &timeBinsOn, float tpeak, const CSCDetId &id)
float middleWireOfGroup(int wireGroup) const
const CSCLayerGeometry * geometry() const
short int deadStrip() const
is a neighbouring string a dead strip?
void setConditions(const CSCRecoConditions *reco)
Cache pointer to conditions data.
bool inside(const Local3DPoint &, const LocalError &, float scale=1.f) const override
GlobalPoint toGlobal(const Local2DPoint &lp) const
Conversion to the global R.F. from the R.F. of the GeomDet.
const StripHitADCContainer & s_adcRaw() const
the raw ADC counts for each of the strip within cluster
LocalPoint localPosition() const override
int tmax() const
Strip hit maximum time bin.
static int position[264][3]
const ChannelContainer & stripsTotal() const
The strips used in cluster to produce strip hit (total content)
void findXOnStrip(const CSCDetId &id, const CSCLayer *layer, const CSCStripHit &stripHit, int centralStrip, float &xWithinChamber, float &stripWidth, const float &tpeak, float &xWithinStrip, float &sigma, int &quality_flag)
Returns fitted local x position and its estimated error.
const CSCChamberSpecs * specs() const
float stripAngle(int strip) const
float gasGainCorrection(const CSCDetId &id, int strip, int wireGroup) const
returns gas-gain correction
bool useTimingCorrections
ChannelContainer wgroupsBXandWire() const
The BX + wire group number.
bool isHitInFiducial(const CSCLayer *layer, const CSCRecHit2D &rh)
Test if rechit is in fiducial volume.
std::vector< int > timeBinsOn() const
Vector of time bins ON for central wire digi, lower of center pair if even number.
CSCXonStrip_MatchGatti * xMatchGatti_
float yResolution(int wireGroup=1) const
const CSCRecoConditions * recoConditions_
T getParameter(std::string const &) const
const ChannelContainer & stripsl1a() const
L1A.
CSCRecHit2D hitFromStripAndWire(const CSCDetId &id, const CSCLayer *layer, const CSCWireHit &wHit, const CSCStripHit &sHit)
Make 2D hits when have both wire and strip hit available in same layer.
const ChannelContainer & strips() const
L1A.
float anodeBXoffset(const CSCDetId &detId) const
Abs< T >::type abs(const T &t)
short int deadWG() const
a dead WG in the cluster?
ChannelContainer wgroups() const
The wire groups used for forming the cluster.
std::pair< LocalPoint, float > possibleRecHitPosition(float s, int w1, int w2) const
strips
#turn off noise in all subdetectors simHcalUnsuppressedDigis.doNoise = False mix.digitizers....
bool useGasGainCorrections
const StripHitADCContainer & s_adc() const
L1A.
void setConditions(const CSCRecoConditions *reco)
Pass pointer to conditions data onwards.