1 |
pam-fi |
1.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 */ |