1 |
/* |
2 |
* TofNucleiZCut.cpp |
3 |
* |
4 |
* Created on: 21-apr-2009 |
5 |
* Author: Nicola Mori |
6 |
*/ |
7 |
|
8 |
#ifndef NO_TOFNUCLEI |
9 |
|
10 |
/*! @file TofNucleiZCut.cpp The TofNucleiZCut class implementation file */ |
11 |
|
12 |
#include "TofNucleiZCut.h" |
13 |
|
14 |
const float TofNucleiZCut::_sigmaZdefault[] = { 0.12, 0.15, 0.20, 0.25, 0.32, 0.40, 0.45, 0.50 }; // the charge-width in a layer for Z=1..8 |
15 |
const unsigned int TofNucleiZCut::_maskArray[] = { TOFNUCLEIZ_S11, TOFNUCLEIZ_S12, TOFNUCLEIZ_S21, TOFNUCLEIZ_S22, |
16 |
TOFNUCLEIZ_S31, TOFNUCLEIZ_S32 }; //The layer - mask code association |
17 |
|
18 |
|
19 |
TofNucleiZCut::TofNucleiZCut(const char *cutName, unsigned int Z, float lowerLimit, float upperLimit, unsigned int minLayers, |
20 |
unsigned int layersMask) : |
21 |
PamCut(cutName), _Z(Z), _mean(8, 6), _sigma(8, 6), _lowerLimit(lowerLimit), _upperLimit(upperLimit), _minLayers( |
22 |
minLayers), _layersMask(layersMask), _tofNuclei(NULL) { |
23 |
|
24 |
//TODO Put calibration parameters on a file; load only those parameters needed for the current Z. |
25 |
|
26 |
// Hard-coded calibrations |
27 |
// H |
28 |
_mean[0][0] = 0.987; // S11 peak |
29 |
_sigma[0][0] = 0.11; // S11 sigma |
30 |
_mean[0][1] = 0.988; // S12 peak |
31 |
_sigma[0][1] = 0.12; // S12 sigma |
32 |
_mean[0][2] = 0.961; // S21 peak |
33 |
_sigma[0][2] = 0.083;// S21 sigma |
34 |
_mean[0][3] = 0.966; // S22 peak |
35 |
_sigma[0][3] = 0.10; // S22 sigma |
36 |
_mean[0][4] = 0.981; // S31 peak |
37 |
_sigma[0][4] = 0.092;// S31 sigma |
38 |
_mean[0][5] = 0.979; // S32 peak |
39 |
_sigma[0][5] = 0.095;// S32 sigma |
40 |
|
41 |
// He |
42 |
_mean[1][0] = 1.96; // S11 peak |
43 |
_sigma[1][0] = 0.12;// S11 sigma |
44 |
_mean[1][1] = 1.95; // S12 peak |
45 |
_sigma[1][1] = 0.14;// S12 sigma |
46 |
_mean[1][2] = 1.95; // S21 peak |
47 |
_sigma[1][2] = 0.13;// S21 sigma |
48 |
_mean[1][3] = 1.96; // S22 peak |
49 |
_sigma[1][3] = 0.14;// S22 sigma |
50 |
_mean[1][4] = 1.99; // S31 peak |
51 |
_sigma[1][4] = 0.14;// S31 sigma |
52 |
_mean[1][5] = 2.00; // S32 peak |
53 |
_sigma[1][5] = 0.15;// S32 sigma |
54 |
|
55 |
// Heavier nuclei are not calibrated yet; using default values |
56 |
for (unsigned int z = 3; z < 9; z++) { |
57 |
for (int i = 0; i < 6; i++) { |
58 |
_mean[z - 1][i] = z; |
59 |
_sigma[z - 1][i] = _sigmaZdefault[z - 1]; |
60 |
} |
61 |
} |
62 |
|
63 |
#ifdef DEBUGPAMCUT |
64 |
|
65 |
TString hId; |
66 |
TString hTitle; |
67 |
|
68 |
for (UInt_t j = 0; j < 12; j++) { |
69 |
hId.Form("h_tof_z_vs_beta_%i", j); |
70 |
hTitle.Form("TOF Z vs beta (%i)", j); |
71 |
h_tof_z_beta[j] = new TH2F(hId.Data(), hTitle.Data(), 50, 0, 1, 50, 0, 10); |
72 |
} |
73 |
|
74 |
#endif |
75 |
|
76 |
} |
77 |
|
78 |
int TofNucleiZCut::Check(PamLevel2 *event) { |
79 |
|
80 |
if (_Z < 1 || _Z > 8) |
81 |
return TOFNUCLEIZ_ILLEGALZ; |
82 |
|
83 |
// Check if ToFNuclei has already been initialized |
84 |
if (_tofNuclei == NULL) |
85 |
_tofNuclei = new ToFNuclei(event); |
86 |
|
87 |
Float_t *charge = _tofNuclei->Get_Charge_ToF_std_layer(); //Returns a 6 elements array |
88 |
unsigned int nGood = 0; |
89 |
bool good[6]; |
90 |
|
91 |
#ifdef DEBUGPAMCUT |
92 |
Int_t seqno = event->GetTrack(0)->GetTrkTrack()->GetSeqNo(); |
93 |
Int_t ntrack_tof = 0; |
94 |
for (Int_t i=0; i<event->GetToFLevel2()->ntrk(); i++) { |
95 |
if ( event->GetToFLevel2()->GetToFTrkVar(i)->trkseqno == seqno ) ntrack_tof = i; |
96 |
} |
97 |
Float_t beta=event->GetToFLevel2()->CalcBeta(ntrack_tof,10.,10.,20.); // beta[12] |
98 |
#endif |
99 |
|
100 |
#ifdef DEBUGPAMCUT |
101 |
for (int i = 0; i < 6; i++) { |
102 |
h_tof_z_beta[i]->Fill(beta, charge[i]); |
103 |
} |
104 |
#endif |
105 |
|
106 |
for (int i = 0; i < 6; i++) { // determine good, non-masked layers |
107 |
if ((charge[i] < 1000) && (charge[i] > 0) && ((_maskArray[i] & _layersMask) != _maskArray[i])) { |
108 |
good[i] = true; |
109 |
nGood++; |
110 |
} |
111 |
else { |
112 |
good[i] = false; |
113 |
} |
114 |
} |
115 |
|
116 |
if (nGood < _minLayers) { |
117 |
return TOFNUCLEIZ_TOOFEWLAYERS; |
118 |
} |
119 |
|
120 |
for (int i = 0; i < 6; i++) { // check done only for good, non-masked layers |
121 |
if (good[i]) { |
122 |
if ((charge[i] > _mean[_Z - 1][i] + _upperLimit * _sigma[_Z - 1][i]) || ((charge[i] < _mean[_Z - 1][i] |
123 |
- _lowerLimit * _sigma[_Z - 1][i]))) { |
124 |
return TOFNUCLEIZ_OUTOFBOUNDS; |
125 |
} |
126 |
} |
127 |
} |
128 |
|
129 |
#ifdef DEBUGPAMCUT |
130 |
for (int i = 0; i < 6; i++) { |
131 |
h_tof_z_beta[6+i]->Fill(beta, charge[i]); |
132 |
} |
133 |
#endif |
134 |
|
135 |
return CUTOK; |
136 |
|
137 |
} |
138 |
|
139 |
#endif /* NO_TOFNUCLEI */ |