BOSS 7.0.1
BESIII Offline Software System
Loading...
Searching...
No Matches
EmcTCFinder Class Reference

#include <EmcTCFinder.h>

Public Member Functions

 EmcTCFinder ()
 
 ~EmcTCFinder ()
 
void setEmcDigi (EmcDigiCol *emcDigiCol)
 
void setEmcTC (std::vector< uint32_t > vTC)
 
void setEmcBE (std::vector< double > vBE)
 
int getTCPhiId (int partId, int ThetaNb, int PhiNb)
 
int getTCThetaId (int partId, int ThetaNb, int PhiNb)
 
int getBLKId (int TCTheta, int TCPhi) const
 
double & getBTCEnergy (int i, int j)
 
double & getEETCEnergy (int i, int j)
 
double & getWETCEnergy (int i, int j)
 
int & getBTC (int i, int j)
 
int & getEETC (int i, int j)
 
int & getWETC (int i, int j)
 
double & getBTC_ADC (int i, int j)
 
double & getEETC_ADC (int i, int j)
 
double & getWETC_ADC (int i, int j)
 
double getBLKE (int i)
 
 EmcTCFinder ()
 
 ~EmcTCFinder ()
 
void setEmcDigi (EmcDigiCol *emcDigiCol)
 
void setEmcTC (std::vector< uint32_t > vTC)
 
void setEmcBE (std::vector< double > vBE)
 
int getTCPhiId (int partId, int ThetaNb, int PhiNb)
 
int getTCThetaId (int partId, int ThetaNb, int PhiNb)
 
int getBLKId (int TCTheta, int TCPhi) const
 
double & getBTCEnergy (int i, int j)
 
double & getEETCEnergy (int i, int j)
 
double & getWETCEnergy (int i, int j)
 
int & getBTC (int i, int j)
 
int & getEETC (int i, int j)
 
int & getWETC (int i, int j)
 
double & getBTC_ADC (int i, int j)
 
double & getEETC_ADC (int i, int j)
 
double & getWETC_ADC (int i, int j)
 
double getBLKE (int i)
 

Static Public Member Functions

static EmcTCFinderget_Emc (void)
 
static EmcTCFinderget_Emc (void)
 

Detailed Description

Constructor & Destructor Documentation

◆ EmcTCFinder() [1/2]

EmcTCFinder::EmcTCFinder ( )

Definition at line 37 of file EmcTCFinder.cxx.

38{
39 ISvcLocator* svcLocator = Gaudi::svcLocator();
40 IRealizationSvc *tmpReal;
41 StatusCode status = svcLocator->service("RealizationSvc",tmpReal);
42 if (!status.isSuccess())
43 {
44 cout << "FATAL: Could not initialize Realization Service" << endl;
45 } else {
46 m_RealizationSvc=dynamic_cast<RealizationSvc*>(tmpReal);
47 }
48
49 // Get EmcCalibConstSvc.
50 status = svcLocator->service("EmcCalibConstSvc", emcCalibConstSvc);
51 if(status != StatusCode::SUCCESS) {
52 cout << "EmcRecDigit2Hit Error: Can't get EmcCalibConstSvc." << endl;
53 }
54}

Referenced by get_Emc().

◆ ~EmcTCFinder() [1/2]

EmcTCFinder::~EmcTCFinder ( )

Definition at line 55 of file EmcTCFinder.cxx.

56{
57}

◆ EmcTCFinder() [2/2]

EmcTCFinder::EmcTCFinder ( )

◆ ~EmcTCFinder() [2/2]

EmcTCFinder::~EmcTCFinder ( )

Member Function Documentation

◆ get_Emc() [1/2]

EmcTCFinder * EmcTCFinder::get_Emc ( void  )
static

Definition at line 32 of file EmcTCFinder.cxx.

32 {
33 if(!emc_Pointer) emc_Pointer = new EmcTCFinder();
34 return emc_Pointer;
35}

Referenced by EmcCCount::EmcCCount(), EmcESum::EmcESum(), and BesTrigL1::initialize().

◆ get_Emc() [2/2]

static EmcTCFinder * EmcTCFinder::get_Emc ( void  )
static

◆ getBLKE() [1/2]

double EmcTCFinder::getBLKE ( int  i)
inline

Definition at line 35 of file InstallArea/include/Trigger/Trigger/EmcTCFinder.h.

35{ return BlkE[i]; }

Referenced by EmcESum::getESum().

◆ getBLKE() [2/2]

double EmcTCFinder::getBLKE ( int  i)
inline

Definition at line 35 of file Trigger/Trigger/Trigger-00-01-05/Trigger/EmcTCFinder.h.

35{ return BlkE[i]; }

◆ getBLKId() [1/2]

int EmcTCFinder::getBLKId ( int  TCTheta,
int  TCPhi 
) const

Definition at line 283 of file EmcTCFinder.cxx.

284{
285 int id,parity;
286 parity = (int)TCPhi/5;
287 if(parity%2==0)
288 {
289 if(TCTheta<6) id = parity;
290 if(TCTheta>=6) id = parity+6;
291 }
292 if(parity%2!=0)
293 {
294 if(TCTheta<5) id = parity;
295 if(TCTheta>=5) id = parity+6;
296 }
297
298 return id;
299}

Referenced by BesTrigL1::getEmcAnalogSig().

◆ getBLKId() [2/2]

int EmcTCFinder::getBLKId ( int  TCTheta,
int  TCPhi 
) const

◆ getBTC() [1/2]

int & EmcTCFinder::getBTC ( int  i,
int  j 
)
inline

Definition at line 27 of file InstallArea/include/Trigger/Trigger/EmcTCFinder.h.

27{ return BTC[i][j];}

Referenced by EmcCCount::findCluster().

◆ getBTC() [2/2]

int & EmcTCFinder::getBTC ( int  i,
int  j 
)
inline

Definition at line 27 of file Trigger/Trigger/Trigger-00-01-05/Trigger/EmcTCFinder.h.

27{ return BTC[i][j];}

◆ getBTC_ADC() [1/2]

double & EmcTCFinder::getBTC_ADC ( int  i,
int  j 
)
inline

Definition at line 31 of file InstallArea/include/Trigger/Trigger/EmcTCFinder.h.

31{ return BTCEnergy_adc[i][j];}

◆ getBTC_ADC() [2/2]

double & EmcTCFinder::getBTC_ADC ( int  i,
int  j 
)
inline

Definition at line 31 of file Trigger/Trigger/Trigger-00-01-05/Trigger/EmcTCFinder.h.

31{ return BTCEnergy_adc[i][j];}

◆ getBTCEnergy() [1/2]

double & EmcTCFinder::getBTCEnergy ( int  i,
int  j 
)
inline

Definition at line 23 of file InstallArea/include/Trigger/Trigger/EmcTCFinder.h.

23{ return BTCEnergy[i][j];}

Referenced by EmcCCount::getClusterId().

◆ getBTCEnergy() [2/2]

double & EmcTCFinder::getBTCEnergy ( int  i,
int  j 
)
inline

Definition at line 23 of file Trigger/Trigger/Trigger-00-01-05/Trigger/EmcTCFinder.h.

23{ return BTCEnergy[i][j];}

◆ getEETC() [1/2]

int & EmcTCFinder::getEETC ( int  i,
int  j 
)
inline

Definition at line 28 of file InstallArea/include/Trigger/Trigger/EmcTCFinder.h.

28{ return EETC[i][j];}

Referenced by EmcCCount::findCluster().

◆ getEETC() [2/2]

int & EmcTCFinder::getEETC ( int  i,
int  j 
)
inline

Definition at line 28 of file Trigger/Trigger/Trigger-00-01-05/Trigger/EmcTCFinder.h.

28{ return EETC[i][j];}

◆ getEETC_ADC() [1/2]

double & EmcTCFinder::getEETC_ADC ( int  i,
int  j 
)
inline

Definition at line 32 of file InstallArea/include/Trigger/Trigger/EmcTCFinder.h.

32{ return EETCEnergy_adc[i][j];}

◆ getEETC_ADC() [2/2]

double & EmcTCFinder::getEETC_ADC ( int  i,
int  j 
)
inline

Definition at line 32 of file Trigger/Trigger/Trigger-00-01-05/Trigger/EmcTCFinder.h.

32{ return EETCEnergy_adc[i][j];}

◆ getEETCEnergy() [1/2]

double & EmcTCFinder::getEETCEnergy ( int  i,
int  j 
)
inline

Definition at line 24 of file InstallArea/include/Trigger/Trigger/EmcTCFinder.h.

24{ return EETCEnergy[i][j];}

Referenced by EmcCCount::getClusterId().

◆ getEETCEnergy() [2/2]

double & EmcTCFinder::getEETCEnergy ( int  i,
int  j 
)
inline

Definition at line 24 of file Trigger/Trigger/Trigger-00-01-05/Trigger/EmcTCFinder.h.

24{ return EETCEnergy[i][j];}

◆ getTCPhiId() [1/2]

int EmcTCFinder::getTCPhiId ( int  partId,
int  ThetaNb,
int  PhiNb 
)

Definition at line 222 of file EmcTCFinder.cxx.

223{
224 if(partId==1)
225 TCPhiNb = int(PhiNb/4);
226/*
227 //trigger cell in endcaps theta*phi = 2*16
228 if(partId==0)
229 {
230 if(ThetaNb<2) TCPhiNb = int(PhiNb/4);
231 if(ThetaNb>=2&&ThetaNb<4) TCPhiNb = int(PhiNb/5);
232 if(ThetaNb>=4) TCPhiNb = int(PhiNb/6);
233 }
234 if(partId==2)
235 {
236 if(ThetaNb<2) TCPhiNb = int(PhiNb/4);
237 if(ThetaNb>=2&&ThetaNb<4) TCPhiNb = int(PhiNb/5);
238 if(ThetaNb>=4) TCPhiNb = int(PhiNb/6);
239 }
240*/
241 // trigger cell in endcaps theta*phi = 1*32
242 if(partId==0)
243 {
244 if(ThetaNb<2) TCPhiNb = int(PhiNb/2);
245 if(ThetaNb==2)
246 {
247 int quot = int(PhiNb/5);
248 int rema = PhiNb%5;
249 if(rema <= 1) TCPhiNb = 2*quot;
250 if(rema > 1) TCPhiNb = 2*quot + 1;
251 }
252 if(ThetaNb==3)
253 {
254 int quot = int(PhiNb/5);
255 int rema = PhiNb%5;
256 if(rema <= 2) TCPhiNb = 2*quot;
257 if(rema > 2) TCPhiNb = 2*quot + 1;
258 }
259 if(ThetaNb>=4) TCPhiNb = int(PhiNb/3);
260 }
261 if(partId==2)
262 {
263 if(ThetaNb<2) TCPhiNb = int(PhiNb/2);
264 if(ThetaNb==2)
265 {
266 int quot = int(PhiNb/5);
267 int rema = PhiNb%5;
268 if(rema <= 1) TCPhiNb = 2*quot;
269 if(rema > 1) TCPhiNb = 2*quot + 1;
270 }
271 if(ThetaNb==3)
272 {
273 int quot = int(PhiNb/5);
274 int rema = PhiNb%5;
275 if(rema <= 2) TCPhiNb = 2*quot;
276 if(rema > 2) TCPhiNb = 2*quot + 1;
277 }
278 if(ThetaNb>=4) TCPhiNb = int(PhiNb/3);
279 }
280
281 return TCPhiNb;
282}

Referenced by BesTrigL1::getEmcAnalogSig(), and setEmcDigi().

◆ getTCPhiId() [2/2]

int EmcTCFinder::getTCPhiId ( int  partId,
int  ThetaNb,
int  PhiNb 
)

◆ getTCThetaId() [1/2]

int EmcTCFinder::getTCThetaId ( int  partId,
int  ThetaNb,
int  PhiNb 
)

Definition at line 179 of file EmcTCFinder.cxx.

180{
181 //Note: There are 44*120(theta*phi) crystals and they are divided 11*30 trigger cell in
182 //barrel emc. So each trigger cell includes 4*4 crystals
183 if(partId==1)
184 {
185 //if(ThetaNb<2)
186 //TCThetaNb = 0;
187 //else if(ThetaNb>41)
188 // TCThetaNb = 11;
189 //else
190 //TCThetaNb = int((ThetaNb+2)/4);
191 TCThetaNb = (int)ThetaNb/4;
192 }
193/* if(partId==0)
194 {
195 if(ThetaNb<3) TCThetaNb = 0;
196 if(ThetaNb>3) TCThetaNb = 1;
197 if(ThetaNb==3)
198 {
199 int n = PhiNb%10;
200 if(n>2&&n<7)
201 TCThetaNb = 0;
202 else TCThetaNb = 1;
203 }
204 }
205 if(partId==2)
206 {
207 if(ThetaNb<3) TCThetaNb = 0;
208 if(ThetaNb>3) TCThetaNb = 1;
209 if(ThetaNb==3)
210 {
211 int n = PhiNb%10;
212 if(n>2&&n<7)
213 TCThetaNb = 0;
214 else TCThetaNb = 1;
215 }
216 }
217*/
218 if(partId==0) TCThetaNb = 0;
219 if(partId==2) TCThetaNb = 0;
220 return TCThetaNb;
221}

Referenced by BesTrigL1::getEmcAnalogSig(), and setEmcDigi().

◆ getTCThetaId() [2/2]

int EmcTCFinder::getTCThetaId ( int  partId,
int  ThetaNb,
int  PhiNb 
)

◆ getWETC() [1/2]

int & EmcTCFinder::getWETC ( int  i,
int  j 
)
inline

Definition at line 29 of file InstallArea/include/Trigger/Trigger/EmcTCFinder.h.

29{ return WETC[i][j];}

Referenced by EmcCCount::findCluster().

◆ getWETC() [2/2]

int & EmcTCFinder::getWETC ( int  i,
int  j 
)
inline

Definition at line 29 of file Trigger/Trigger/Trigger-00-01-05/Trigger/EmcTCFinder.h.

29{ return WETC[i][j];}

◆ getWETC_ADC() [1/2]

double & EmcTCFinder::getWETC_ADC ( int  i,
int  j 
)
inline

Definition at line 33 of file InstallArea/include/Trigger/Trigger/EmcTCFinder.h.

33{ return WETCEnergy_adc[i][j];}

◆ getWETC_ADC() [2/2]

double & EmcTCFinder::getWETC_ADC ( int  i,
int  j 
)
inline

Definition at line 33 of file Trigger/Trigger/Trigger-00-01-05/Trigger/EmcTCFinder.h.

33{ return WETCEnergy_adc[i][j];}

◆ getWETCEnergy() [1/2]

double & EmcTCFinder::getWETCEnergy ( int  i,
int  j 
)
inline

Definition at line 25 of file InstallArea/include/Trigger/Trigger/EmcTCFinder.h.

25{ return WETCEnergy[i][j];}

Referenced by EmcCCount::getClusterId().

◆ getWETCEnergy() [2/2]

double & EmcTCFinder::getWETCEnergy ( int  i,
int  j 
)
inline

Definition at line 25 of file Trigger/Trigger/Trigger-00-01-05/Trigger/EmcTCFinder.h.

25{ return WETCEnergy[i][j];}

◆ setEmcBE() [1/2]

void EmcTCFinder::setEmcBE ( std::vector< double >  vBE)

Definition at line 166 of file EmcTCFinder.cxx.

166 {
167 //reset block energy
168 for(int i = 0; i < 16; i++) {
169 BlkE[i] = 0;
170 }
171 if(vBE.size() != 0) {
172 if(vBE.size() != 16 ) std::cerr << "The number of block is not equal 16, please check it (in EmcTCFinder::setEmcBE() )" << std::endl;
173 for(int i = 0; i < vBE.size(); i++) {
174 BlkE[i] = vBE[i];
175 }
176 }
177}

Referenced by BesTrigL1::runAclock_emc().

◆ setEmcBE() [2/2]

void EmcTCFinder::setEmcBE ( std::vector< double >  vBE)

◆ setEmcDigi() [1/2]

void EmcTCFinder::setEmcDigi ( EmcDigiCol emcDigiCol)

Definition at line 58 of file EmcTCFinder.cxx.

59{
60 //double energy;
61 double tot_adc = 0.;
62 double adc = 0., adc1 = 0., tdc = 0.;
63 unsigned int measure;
64 //reset tc energy of barrel and endcap
65 for(int i=0;i<TrigConf::TCTHETANO_B;i++)
66 for(int j=0;j<TrigConf::TCPHINO_B;j++) {
67 BTCEnergy[i][j] = 0;
68 BTCEnergy_adc[i][j] = 0;
69 }
70 for(int i=0;i<TrigConf::TCTHETANO_E;i++)
71 for(int j=0;j<TrigConf::TCPHINO_E;j++)
72 {
73 EETCEnergy[i][j] = 0;
74 WETCEnergy[i][j] = 0;
75 EETCEnergy_adc[i][j] = 0;
76 WETCEnergy_adc[i][j] = 0;
77 }
78 EmcDigiCol::iterator iter3;
79 Identifier id;
80 for (iter3=emcDigiCol->begin();iter3!= emcDigiCol->end();iter3++) {
81 id=(*iter3)->identify();
82
83 unsigned int module;
84 unsigned int theta;
85 unsigned int phi;
86 module = EmcID::barrel_ec(id);
87 theta = EmcID::theta_module(id);
88 phi = EmcID::phi_module(id);
89 adc = double ((*iter3)->getChargeChannel());
90 adc1 = double ((*iter3)->getChargeChannel());
91 measure = (*iter3)->getMeasure();
92 tdc = (*iter3)->getTimeChannel();
93
94 int index = emcCalibConstSvc->getIndex(module,theta,phi);
95 //divided by electronics calibration constants and times trigger gain
96 //double trgGain = ((50./255.)*(m_RealizationSvc->getTrgGain(index))/60.)*5*0.5;
97 double trgGain = m_RealizationSvc->getTrgGain(index);
98 std::cout <<"partId, thetaId, phiId, trgGain: " << module << ", " << theta << ", " << phi << ", " << trgGain << std::endl;
99 //if((*iter3)->getMeasure()==0) adc = adc*(m_RealizationSvc->getEleCalib(index,7))*(trgGain)*800.*2/65535;
100 //else if((*iter3)->getMeasure()==1) adc = adc*(m_RealizationSvc->getEleCalib(index,4))*(trgGain)*800.*2/65535;
101 //else adc = adc*(m_RealizationSvc->getEleCalib(index,1))*(trgGain)*800.*2/65535;
102 if((*iter3)->getMeasure()==0) adc = adc*2*800.*2/65535.*(trgGain);
103 else if((*iter3)->getMeasure()==1) adc = adc*16*800.*2/65535*(trgGain);
104 else adc = adc*64*800.*2/65535*(trgGain);
105
106 //double trgConst = m_RealizationSvc->getTrgConst(index);
107 //if((*iter3)->getMeasure()==0) adc1 = adc1*2*800.*2/65535.*(trgConst)*0.333;
108 //else if((*iter3)->getMeasure()==1) adc1 = adc1*16*800.*2/65535*(trgConst)*0.333;
109 //else adc1 = adc1*64*800.*2/65535*(trgConst)*0.333;
110
111 //std::cout << "eCalib: " << m_RealizationSvc->getEleCalib(index,7) << "," << m_RealizationSvc->getEleCalib(index,4) << "," << m_RealizationSvc->getEleCalib(index,1) << " TrigGain: " << m_RealizationSvc->getTrgGain(index) << std::endl;
112 //std::cout << " TrgGain: " << trgGain << " adc: " << adc << std::endl;
113 //adc = RawDataUtil::EmcCharge(measure,adc); //MeV
114 //energy = RandGauss::shoot(energy,0.1*energy); //add 10% smear in each ADC channel
115
116 int TCThetaId = getTCThetaId(module,theta,phi);
117 int TCPhiId = getTCPhiId(module,theta,phi);
118 //Get energy of each trigger cell
119 if(module==1) BTCEnergy[TCThetaId][TCPhiId] += adc;
120 if(module==0) EETCEnergy[TCThetaId][TCPhiId] += adc;
121 if(module==2) WETCEnergy[TCThetaId][TCPhiId] += adc;
122 if(module==1) BTCEnergy_adc[TCThetaId][TCPhiId] += adc;
123 if(module==0) EETCEnergy_adc[TCThetaId][TCPhiId] += adc;
124 if(module==2) WETCEnergy_adc[TCThetaId][TCPhiId] += adc;
125 }
126
127 //subtract ped
128/*
129 for(int i=0;i<TrigConf::TCTHETANO_B;i++)
130 for(int j=0;j<TrigConf::TCPHINO_B;j++) {
131 if((BTCEnergy[i][j] - 0x0a) < 0) BTCEnergy[i][j] = 0;
132 else BTCEnergy[i][j] = BTCEnergy[i][j] - 0x0a;
133 }
134 for(int i=0;i<TrigConf::TCTHETANO_E;i++)
135 for(int j=0;j<TrigConf::TCPHINO_E;j++)
136 {
137 if((EETCEnergy[i][j] - 0x0a) < 0) EETCEnergy[i][j] = 0;
138 else EETCEnergy[i][j] = EETCEnergy[i][j] - 0x0a;
139 if((WETCEnergy[i][j] - 0x0a) < 0) WETCEnergy[i][j] = 0;
140 else WETCEnergy[i][j] = WETCEnergy[i][j] - 0x0a;
141 }*/
142}
static unsigned int barrel_ec(const Identifier &id)
Values of different levels (failure returns 0)
Definition: EmcID.cxx:38
static unsigned int theta_module(const Identifier &id)
Definition: EmcID.cxx:43
static unsigned int phi_module(const Identifier &id)
Definition: EmcID.cxx:48
int getTCThetaId(int partId, int ThetaNb, int PhiNb)
int getTCPhiId(int partId, int ThetaNb, int PhiNb)
virtual int getIndex(unsigned int PartId, unsigned int ThetaIndex, unsigned int PhiIndex) const =0

◆ setEmcDigi() [2/2]

void EmcTCFinder::setEmcDigi ( EmcDigiCol emcDigiCol)

◆ setEmcTC() [1/2]

void EmcTCFinder::setEmcTC ( std::vector< uint32_t >  vTC)

Definition at line 144 of file EmcTCFinder.cxx.

144 {
145 //reset tc energy of barrel and endcap
146 for(int i=0;i<TrigConf::TCTHETANO_B;i++)
147 for(int j=0;j<TrigConf::TCPHINO_B;j++) {
148 BTC[i][j] = 0;
149 }
150 for(int i=0;i<TrigConf::TCTHETANO_E;i++)
151 for(int j=0;j<TrigConf::TCPHINO_E;j++)
152 {
153 EETC[i][j] = 0;
154 WETC[i][j] = 0;
155 }
156 for(std::vector<uint32_t>::iterator iter = vTC.begin(); iter != vTC.end(); iter++) {
157 int par_TC = (*iter & 0xFF0000) >> 16;
158 int the_TC = (*iter & 0xFF00) >> 8;
159 int phi_TC = (*iter & 0xFF);
160 if(par_TC == 0) EETC[the_TC][phi_TC] = 1;
161 if(par_TC == 1) BTC[the_TC][phi_TC] = 1;
162 if(par_TC == 2) WETC[the_TC][phi_TC] = 1;
163 }
164}
EvtStreamInputIterator< typename Generator::result_type > iter(Generator gen, int N=0)

Referenced by BesTrigL1::runAclock_emc().

◆ setEmcTC() [2/2]

void EmcTCFinder::setEmcTC ( std::vector< uint32_t >  vTC)

The documentation for this class was generated from the following files: