CGEM BOSS 6.6.5.i
BESIII Offline Software System
Loading...
Searching...
No Matches
RootTofCalibDataCnv.cxx
Go to the documentation of this file.
1// $Header: /bes/bes/BossCvs/Calibration/CalibSvc/CalibROOTCnv/src/cnv/RootTofCalibDataCnv.cxx,v 1.14 2012/11/06 07:54:07 sunss Exp $
2#include "GaudiKernel/MsgStream.h"
8
9#include "TFile.h"
10#include "TTree.h"
11#include "TDirectory.h"
12#include "TObject.h"
13
14#include "GaudiKernel/CnvFactory.h"
15#include "GaudiKernel/IOpaqueAddress.h"
16#include "GaudiKernel/DataObject.h"
17#include "GaudiKernel/IAddressCreator.h"
18#include "GaudiKernel/IDataProviderSvc.h"
19#include "GaudiKernel/IConversionSvc.h"
20#include "GaudiKernel/GenericAddress.h"
21
22#include "CalibDataSvc/ICalibRootSvc.h" //maybe
24//#include "CalibData/CalibTime.h"
25//#include "commonRootData/idents/CalXtalId.h"
26//#include "idents/CalXtalId.h"
27
28// Temporary. Hope to find a better way to do this
30using namespace CalibData;
31//static CnvFactory<RootTofCalibDataCnv> TofCalib_factory;
32//const ICnvFactory& RootTofCalibDataCnvFactory = TofCalib_factory;
33
34const unsigned int nBarAtten = 8;
35const unsigned int nBarSpeed = 2;
36const unsigned int nBarPar = 10;
37const unsigned int nBarParOff = 20;
38const unsigned int nBarSigma = 5;
39const unsigned int nBarSigCnt = 10;
40
41const unsigned int nBarSigCor = 8;
42const unsigned int nBarOffset = 2;
43
44const unsigned int nEndAtten = 5;
45const unsigned int nEndSpeed = 4;
46const unsigned int nEndPar = 8;
47const unsigned int nEndSigma = 5;
48
52
53
54const CLID& RootTofCalibDataCnv::objType() const {
55 return CLID_Calib_TofCal;
56}
57
59 return CLID_Calib_TofCal;
60}
61
62StatusCode RootTofCalibDataCnv::i_createObj(const std::string& fname,
63 DataObject*& refpObject) {
64
65 MsgStream log(msgSvc(), "RootTofCalibDataCnv");
66 log<<MSG::DEBUG<<"SetProperty"<<endreq;
67
68 // open the file
69 StatusCode sc = openRead(fname);
70 if(!sc)
71 { log<<MSG::ERROR<<"unable to open files"<<endreq;
72 }
73
78
79 std::vector<CalibData::bTofCalibBase> tmpbTof;//; = new vector<CalibData::bTofCalibBase>;
80 std::vector<CalibData::eTofCalibBase> tmpeTof;
81 std::vector<CalibData::bTofCommonCalibBase> tmpbTofCommon;
82 std::vector<CalibData::tofCalibInfoBase> tofinfoCol;
83 // Read in the object
84 int cnt;
85 // read btoftree ------------------------------------------------------------
86
87 double cnvBarAtten[nBarAtten];
88 double cnvBarSpeed[nBarSpeed];
89 double cnvBarPar1[nBarPar];
90 double cnvBarPar2[nBarPar];
91 double cnvBarParOff1_bunch0[nBarParOff];
92 double cnvBarParOff2_bunch0[nBarParOff];
93 double cnvBarParOff1_bunch1[nBarParOff];
94 double cnvBarParOff2_bunch1[nBarParOff];
95 double cnvBarParOff1_bunch2[nBarParOff];
96 double cnvBarParOff2_bunch2[nBarParOff];
97 double cnvBarParOff1_bunch3[nBarParOff];
98 double cnvBarParOff2_bunch3[nBarParOff];
99 double cnvFLeft[nBarSigma];
100 double cnvFRight[nBarSigma];
101 double cnvFCount[nBarSigCnt];
102
103 TTree *btoftree = (TTree*)m_inFile -> Get("BarTofPar");
104
105 char brname[10];
106 for( unsigned int i=0; i<nBarAtten; i++ ) {
107 sprintf( brname, "Atten%i", i );
108 btoftree -> SetBranchAddress( brname, &cnvBarAtten[i] );
109 }
110 for( unsigned int i=0; i<nBarSpeed; i++ ) {
111 sprintf( brname, "Speed%i", i );
112 btoftree -> SetBranchAddress( brname, &cnvBarSpeed[i] );
113 }
114 for( unsigned int i=0; i<nBarPar; i++ ) {
115 sprintf( brname, "P%i", i );
116 btoftree -> SetBranchAddress( brname, &cnvBarPar1[i] );
117 }
118 for( unsigned int i=0; i<nBarPar; i++ ) {
119 sprintf( brname, "P%i", i+nBarPar );
120 btoftree -> SetBranchAddress( brname, &cnvBarPar2[i] );
121 }
122 for( unsigned int i=0; i<nBarParOff; i++ ) {
123 sprintf( brname, "Bunch0_Poff%i", i );
124 btoftree -> SetBranchAddress( brname, &cnvBarParOff1_bunch0[i] );
125 }
126 for( unsigned int i=0; i<nBarParOff; i++ ) {
127 sprintf( brname, "Bunch0_Poff%i", i+nBarParOff );
128 btoftree -> SetBranchAddress( brname, &cnvBarParOff2_bunch0[i] );
129 }
130 for( unsigned int i=0; i<nBarParOff; i++ ) {
131 sprintf( brname, "Bunch1_Poff%i", i );
132 btoftree -> SetBranchAddress( brname, &cnvBarParOff1_bunch1[i] );
133 }
134 for( unsigned int i=0; i<nBarParOff; i++ ) {
135 sprintf( brname, "Bunch1_Poff%i", i+nBarParOff );
136 btoftree -> SetBranchAddress( brname, &cnvBarParOff2_bunch1[i] );
137 }
138 for( unsigned int i=0; i<nBarParOff; i++ ) {
139 sprintf( brname, "Bunch2_Poff%i", i );
140 btoftree -> SetBranchAddress( brname, &cnvBarParOff1_bunch2[i] );
141 }
142 for( unsigned int i=0; i<nBarParOff; i++ ) {
143 sprintf( brname, "Bunch2_Poff%i", i+nBarParOff );
144 btoftree -> SetBranchAddress( brname, &cnvBarParOff2_bunch2[i] );
145 }
146 for( unsigned int i=0; i<nBarParOff; i++ ) {
147 sprintf( brname, "Bunch3_Poff%i", i );
148 btoftree -> SetBranchAddress( brname, &cnvBarParOff1_bunch3[i] );
149 }
150 for( unsigned int i=0; i<nBarParOff; i++ ) {
151 sprintf( brname, "Bunch3_Poff%i", i+nBarParOff );
152 btoftree -> SetBranchAddress( brname, &cnvBarParOff2_bunch3[i] );
153 }
154 for( unsigned int i=0; i<nBarSigma; i++ ) {
155 sprintf( brname, "FLeft%i", i );
156 btoftree -> SetBranchAddress( brname, &cnvFLeft[i] );
157 }
158 for( unsigned int i=0; i<nBarSigma; i++ ) {
159 sprintf( brname, "FRight%i", i );
160 btoftree -> SetBranchAddress( brname, &cnvFRight[i] );
161 }
162 for( unsigned int i=0; i<nBarSigCnt; i++ ) {
163 sprintf( brname, "FCounter%i", i );
164 btoftree -> SetBranchAddress( brname, &cnvFCount[i] );
165 }
166
167 for(cnt=0; cnt<176; cnt++){
168 btoftree -> GetEntry(cnt);
169 bTof.setAtten( cnvBarAtten );
170 bTof.setSpeed( cnvBarSpeed );
171 bTof.setP1( cnvBarPar1 );
172 bTof.setP2( cnvBarPar2 );
173 bTof.setPoff1_bunch0( cnvBarParOff1_bunch0 );
174 bTof.setPoff2_bunch0( cnvBarParOff2_bunch0 );
175 bTof.setPoff1_bunch1( cnvBarParOff1_bunch1 );
176 bTof.setPoff2_bunch1( cnvBarParOff2_bunch1 );
177 bTof.setPoff1_bunch2( cnvBarParOff1_bunch2 );
178 bTof.setPoff2_bunch2( cnvBarParOff2_bunch2 );
179 bTof.setPoff1_bunch3( cnvBarParOff1_bunch3 );
180 bTof.setPoff2_bunch3( cnvBarParOff2_bunch3 );
181 bTof.setFPleft( cnvFLeft );
182 bTof.setFPright( cnvFRight );
183 bTof.setFPcounter( cnvFCount );
184 tmpbTof.push_back(bTof);
185 }
186
187 //read etoftree
188 double cnvEndAtten[nEndAtten];
189 double cnvEndSpeed[nEndSpeed];
190 double cnvEndPar[nEndPar];
191 double cnvEndFPar[nEndSigma];
192
193 TTree *etoftree = (TTree*)m_inFile -> Get("EndTofPar");
194
195 char ecname[10];
196 for( unsigned int i=0; i<nEndAtten; i++ ) {
197 sprintf( ecname, "Atten%i", i );
198 etoftree -> SetBranchAddress( ecname, &cnvEndAtten[i] );
199 }
200 for( unsigned int i=0; i<nEndSpeed; i++ ) {
201 sprintf( ecname, "Speed%i", i );
202 etoftree -> SetBranchAddress( ecname, &cnvEndSpeed[i] );
203 }
204 for( unsigned int i=0; i<nEndPar; i++ ) {
205 sprintf( ecname, "P%i", i );
206 etoftree -> SetBranchAddress( ecname, &cnvEndPar[i] );
207 }
208 for( unsigned int i=0; i<nEndSigma; i++ ) {
209 sprintf( ecname, "FCounter%i", i );
210 etoftree -> SetBranchAddress( ecname, &cnvEndFPar[i] );
211 }
212
213 for(cnt=0; cnt<96; cnt++){
214 etoftree -> GetEntry(cnt);
215 eTof.setAtten( cnvEndAtten );
216 eTof.setSpeed( cnvEndSpeed );
217 eTof.setP( cnvEndPar );
218 eTof.setFP( cnvEndFPar );
219 tmpeTof.push_back(eTof);
220 }
221
222 //read bTofCommonCalibBase
223 double cnvBarSigCor[nBarSigCor];
224 double cnvBarOffset[nBarOffset];
225 TTree *btofcommontree = (TTree*)m_inFile -> Get("BarTofParCommon");
226 for( unsigned int i=0; i<nBarSigCor; i++ ) {
227 sprintf( brname, "sigmaCorr%i", i );
228 btofcommontree-> SetBranchAddress( brname, &cnvBarSigCor[i] );
229 }
230 for( unsigned int i=0; i<nBarOffset; i++ ) {
231 sprintf( brname, "t0offset%i", i );
232 btofcommontree-> SetBranchAddress( brname, &cnvBarOffset[i]);
233 }
234
235 int entries = btofcommontree->GetEntries();
236 for(cnt=0;cnt<entries;cnt++){
237 btofcommontree->GetEntry(cnt);
238 bTofCommon.setSigmaCorr( cnvBarSigCor );
239 bTofCommon.setOffset( cnvBarOffset );
240 tmpbTofCommon.push_back(bTofCommon);
241 }
242
243 int m_run1, m_run2, m_version;
244 int m_qCorr, m_qElec, m_misLable;
245 int m_tofidEast[5], m_tofidWest[5], m_tofidEndcap[5];
246
247 TTree *CalibInfo = (TTree*)m_inFile -> Get("CalibInfo");
248 CalibInfo->SetBranchAddress("Run1",&m_run1);
249 CalibInfo->SetBranchAddress("Run2",&m_run2);
250 CalibInfo->SetBranchAddress("Version",&m_version);
251 CalibInfo->SetBranchAddress("ebrId0",&m_tofidEast[0]);
252 CalibInfo->SetBranchAddress("ebrId1",&m_tofidEast[1]);
253 CalibInfo->SetBranchAddress("ebrId2",&m_tofidEast[2]);
254 CalibInfo->SetBranchAddress("ebrId3",&m_tofidEast[3]);
255 CalibInfo->SetBranchAddress("ebrId4",&m_tofidEast[4]);
256 CalibInfo->SetBranchAddress("ecId0",&m_tofidEndcap[0]);
257 CalibInfo->SetBranchAddress("ecId1",&m_tofidEndcap[1]);
258 CalibInfo->SetBranchAddress("ecId2",&m_tofidEndcap[2]);
259 CalibInfo->SetBranchAddress("ecId3",&m_tofidEndcap[3]);
260 CalibInfo->SetBranchAddress("ecId4",&m_tofidEndcap[4]);
261 CalibInfo->SetBranchAddress("wbrId0",&m_tofidWest[0]);
262 CalibInfo->SetBranchAddress("wbrId1",&m_tofidWest[1]);
263 CalibInfo->SetBranchAddress("wbrId2",&m_tofidWest[2]);
264 CalibInfo->SetBranchAddress("wbrId3",&m_tofidWest[3]);
265 CalibInfo->SetBranchAddress("wbrId4",&m_tofidWest[4]);
266 CalibInfo->SetBranchAddress("misLable",&m_misLable);
267 CalibInfo->SetBranchAddress("qCorr",&m_qCorr);
268 CalibInfo->SetBranchAddress("qElec",&m_qElec);
269
270 entries= CalibInfo->GetEntries();
271 for(cnt=0;cnt<entries;cnt++){
272 CalibInfo->GetEntry(cnt);
273 tofinfo.setRunBegin(m_run1);
274 tofinfo.setRunEnd(m_run2);
275 tofinfo.setVersion(m_version);
276 tofinfo.setQCorr(m_qCorr);
277 tofinfo.setQElec(m_qElec);
278 tofinfo.setMisLable(m_misLable);
279 tofinfo.setBrEast(m_tofidEast);
280 tofinfo.setBrWest(m_tofidWest);
281 tofinfo.setEndcap(m_tofidEndcap);
282 tofinfoCol.push_back(tofinfo);
283 }
284
285 CalibData::TofCalibData *tmpObject = new CalibData::TofCalibData(&tmpbTof,&tmpbTofCommon,&tmpeTof,&tofinfoCol);
286
287 refpObject=tmpObject;
288
289 return StatusCode::SUCCESS;
290}
291
292StatusCode RootTofCalibDataCnv::createRoot(const std::string& fname,
293 CalibData::CalibBase1* pTDSObj) {
294 MsgStream log(msgSvc(), "RootTofCalibDataCnv");
295
296 // Open the file, create the branch
297 StatusCode sc = openWrite(fname);
298 if(!sc)
299 { log<<MSG::ERROR<<"unable to open files"<<endreq;
300 }
301 // write the Data in the TCDS to RootFile
302 int j;
303 CalibData::TofCalibData* btof = dynamic_cast<CalibData::TofCalibData*>(pTDSObj);
304
305 // write btoftree----------------------------------------------------------------
306 double cnvBarAtten[nBarAtten];
307 double cnvBarSpeed[nBarSpeed];
308 double cnvBarPar1[nBarPar];
309 double cnvBarPar2[nBarPar];
310 double cnvBarParOff1_bunch0[nBarParOff];
311 double cnvBarParOff2_bunch0[nBarParOff];
312 double cnvBarParOff1_bunch1[nBarParOff];
313 double cnvBarParOff2_bunch1[nBarParOff];
314 double cnvBarParOff1_bunch2[nBarParOff];
315 double cnvBarParOff2_bunch2[nBarParOff];
316 double cnvBarParOff1_bunch3[nBarParOff];
317 double cnvBarParOff2_bunch3[nBarParOff];
318 double cnvFLeft[nBarSigma];
319 double cnvFRight[nBarSigma];
320 double cnvFCount[nBarSigCnt];
321
322 char brname[8], ibrname[8];
323 TTree *btoftree = new TTree("BarTofPar", "BarTofPar");
324 for( unsigned int i=0; i<nBarAtten; i++ ) {
325 sprintf( brname, "Atten%i", i );
326 sprintf( ibrname, "Atten%i/D", i );
327 btoftree -> Branch( brname, &cnvBarAtten[i], ibrname );
328 }
329 for( unsigned int i=0; i<nBarSpeed; i++ ) {
330 sprintf( brname, "Speed%i", i );
331 sprintf( ibrname, "Speed%i/D", i );
332 btoftree -> Branch( brname, &cnvBarSpeed[i], ibrname );
333 }
334 for( unsigned int i=0; i<nBarPar; i++ ) {
335 sprintf( brname, "P%i", i );
336 sprintf( ibrname, "P%i/D", i );
337 btoftree -> Branch( brname, &cnvBarPar1[i], ibrname );
338 }
339 for( unsigned int i=0; i<nBarPar; i++ ) {
340 sprintf( brname, "P%i", i+nBarPar );
341 sprintf( ibrname, "P%i/D", i+nBarPar );
342 btoftree -> Branch( brname, &cnvBarPar2[i], ibrname );
343 }
344 for( unsigned int i=0; i<nBarParOff; i++ ) {
345 sprintf( brname, "Bunch0_Poff%i", i );
346 sprintf( ibrname, "Bunch0_Poff%i/D", i );
347 btoftree -> Branch( brname, &cnvBarParOff1_bunch0[i], ibrname );
348 }
349 for( unsigned int i=0; i<nBarParOff; i++ ) {
350 sprintf( brname, "Bunch0_Poff%i", i+nBarParOff );
351 sprintf( ibrname, "Bunch0_Poff%i/D", i+nBarParOff );
352 btoftree -> Branch( brname, &cnvBarParOff2_bunch0[i], ibrname );
353 }
354 for( unsigned int i=0; i<nBarParOff; i++ ) {
355 sprintf( brname, "Bunch1_Poff%i", i );
356 sprintf( ibrname, "Bunch1_Poff%i/D", i );
357 btoftree -> Branch( brname, &cnvBarParOff1_bunch1[i], ibrname );
358 }
359 for( unsigned int i=0; i<nBarParOff; i++ ) {
360 sprintf( brname, "Bunch1_Poff%i", i+nBarParOff );
361 sprintf( ibrname, "Bunch1_Poff%i/D", i+nBarParOff );
362 btoftree -> Branch( brname, &cnvBarParOff2_bunch1[i], ibrname );
363 }
364 for( unsigned int i=0; i<nBarParOff; i++ ) {
365 sprintf( brname, "Bunch2_Poff%i", i );
366 sprintf( ibrname, "Bunch2_Poff%i/D", i );
367 btoftree -> Branch( brname, &cnvBarParOff1_bunch2[i], ibrname );
368 }
369 for( unsigned int i=0; i<nBarParOff; i++ ) {
370 sprintf( brname, "Bunch2_Poff%i", i+nBarParOff );
371 sprintf( ibrname, "Bunch2_Poff%i/D", i+nBarParOff );
372 btoftree -> Branch( brname, &cnvBarParOff2_bunch2[i], ibrname );
373 }
374 for( unsigned int i=0; i<nBarParOff; i++ ) {
375 sprintf( brname, "Bunch3_Poff%i", i );
376 sprintf( ibrname, "Bunch3_Poff%i/D", i );
377 btoftree -> Branch( brname, &cnvBarParOff1_bunch3[i], ibrname );
378 }
379 for( unsigned int i=0; i<nBarParOff; i++ ) {
380 sprintf( brname, "Bunch3_Poff%i", i+nBarParOff );
381 sprintf( ibrname, "Bunch3_Poff%i/D", i+nBarParOff );
382 btoftree -> Branch( brname, &cnvBarParOff2_bunch3[i], ibrname );
383 }
384 for( unsigned int i=0; i<nBarSigma; i++ ) {
385 sprintf( brname, "FLeft%i", i );
386 sprintf( ibrname, "FLeft%i/D", i );
387 btoftree -> Branch( brname, &cnvFLeft[i], ibrname );
388 }
389 for( unsigned int i=0; i<nBarSigma; i++ ) {
390 sprintf( brname, "FRight%i", i );
391 sprintf( ibrname, "FRight%i/D", i );
392 btoftree -> Branch( brname, &cnvFRight[i], ibrname );
393 }
394 for( unsigned int i=0; i<nBarSigCnt; i++ ) {
395 sprintf( brname, "FCounter%i", i );
396 sprintf( ibrname, "FCounter%i/D", i );
397 btoftree -> Branch( brname, &cnvFCount[i], ibrname );
398 }
399
400 for( int i=0; i<176; i++ ) {
401 for(j=0;j<static_cast<int>(nBarAtten);j++) {
402 cnvBarAtten[j] = btof->getBTofAtten(i,j);
403 }
404 for(j=0;j<static_cast<int>(nBarSpeed);j++) {
405 cnvBarSpeed[j] = btof->getBTofSpeed(i,j);
406 }
407 for(j=0;j<static_cast<int>(nBarPar);j++){
408 cnvBarPar1[j] = btof->getBTofPleft(i,j);
409 cnvBarPar2[j] = btof->getBTofPright(i,j);
410 }
411 for(j=0;j<static_cast<int>(nBarParOff);j++){
412 cnvBarParOff1_bunch0[j] = btof->getBTofPoffleft_bunch0(i,j);
413 cnvBarParOff2_bunch0[j] = btof->getBTofPoffright_bunch0(i,j);
414 }
415 for(j=0;j<static_cast<int>(nBarParOff);j++){
416 cnvBarParOff1_bunch1[j] = btof->getBTofPoffleft_bunch1(i,j);
417 cnvBarParOff2_bunch1[j] = btof->getBTofPoffright_bunch1(i,j);
418 }
419 for(j=0;j<static_cast<int>(nBarParOff);j++){
420 cnvBarParOff1_bunch2[j] = btof->getBTofPoffleft_bunch2(i,j);
421 cnvBarParOff2_bunch2[j] = btof->getBTofPoffright_bunch2(i,j);
422 }
423 for(j=0;j<static_cast<int>(nBarParOff);j++){
424 cnvBarParOff1_bunch3[j] = btof->getBTofPoffleft_bunch3(i,j);
425 cnvBarParOff2_bunch3[j] = btof->getBTofPoffright_bunch3(i,j);
426 }
427 for(j=0;j<static_cast<int>(nBarSigma);j++){
428 cnvFLeft[j] = btof->getBTofFleft(i,j);
429 cnvFRight[j] = btof->getBTofFright(i,j);
430 }
431 for(j=0;j<static_cast<int>(nBarSigCnt);j++){
432 cnvFCount[j] = btof->getBTofFcounter(i,j);
433 }
434 btoftree -> Fill();
435 }
436
437 //write etoftree----------------------------------------------------------------
438 double cnvEndAtten[nEndAtten];
439 double cnvEndSpeed[nEndSpeed];
440 double cnvEndPar[nEndPar];
441 double cnvEndFPar[nEndSigma];
442
443 char ecname[8], iecname[8];
444 TTree *etoftree = new TTree("EndTofPar", "EndTofPar");
445 for( unsigned int i=0; i<nEndAtten; i++ ) {
446 sprintf( ecname, "Atten%i", i );
447 sprintf( iecname, "Atten%i/D", i );
448 etoftree -> Branch( ecname, &cnvEndAtten[i], iecname );
449 }
450 for( unsigned int i=0; i<nEndSpeed; i++ ) {
451 sprintf( ecname, "Speed%i", i );
452 sprintf( iecname, "Speed%i/D", i );
453 etoftree -> Branch( ecname, &cnvEndSpeed[i], iecname );
454 }
455 for( unsigned int i=0; i<nEndPar; i++ ) {
456 sprintf( ecname, "P%i", i );
457 sprintf( iecname, "P%i/D", i );
458 etoftree -> Branch( ecname, &cnvEndPar[i], iecname );
459 }
460 for( unsigned int i=0; i<nEndSigma; i++ ) {
461 sprintf( ecname, "FCounter%i", i );
462 sprintf( iecname, "FCounter%i/D", i );
463 etoftree -> Branch( ecname, &cnvEndFPar[i], iecname );
464 }
465
466 for(int i=0; i<96; i++){
467 for(j=0;j<static_cast<int>(nEndAtten);j++) {
468 cnvEndAtten[j] = btof->getETofAtten(i,j);
469 }
470 for(j=0;j<static_cast<int>(nEndSpeed);j++) {
471 cnvEndSpeed[j] = btof->getETofSpeed(i,j);
472 }
473 for(j=0;j<static_cast<int>(nEndPar);j++){
474 cnvEndPar[j] = btof->getETofP(i,j);
475 }
476 for(j=0;j<static_cast<int>(nEndSigma);j++){
477 cnvEndFPar[j] = btof->getETofFP(i,j);
478 }
479 etoftree -> Fill();
480 }
481
482 // write all the trees
483 btoftree -> Write();
484 etoftree -> Write();
485 delete btoftree;
486 delete etoftree;
487 closeWrite();
488 log<<MSG::INFO<<"successfully create RootFile"<<endreq;
489
490 return sc;
491}
const CLID CLID_Calib_TofCal
Definition CalibModel.h:43
data SetBranchAddress("time",&time)
data GetEntry(0)
const unsigned int nBarOffset
const unsigned int nBarParOff
const unsigned int nEndPar
const unsigned int nBarPar
const unsigned int nBarSigma
const unsigned int nEndSigma
const unsigned int nBarSigCor
const unsigned int nEndSpeed
const unsigned int nBarOffset
const unsigned int nBarParOff
const unsigned int nEndPar
const unsigned int nBarSpeed
const unsigned int nEndAtten
const unsigned int nBarAtten
const unsigned int nBarSigCnt
const unsigned int nBarPar
IMessageSvc * msgSvc()
double getETofFP(int index, int pardex)
double getBTofPoffleft_bunch1(int index, int pardex)
double getBTofPoffleft_bunch3(int index, int pardex)
double getBTofSpeed(int index, int pardex)
double getETofP(int index, int pardex)
double getBTofPoffright_bunch3(int index, int pardex)
double getBTofPoffright_bunch2(int index, int pardex)
double getBTofFleft(int index, int pardex)
double getBTofPoffright_bunch0(int index, int pardex)
double getBTofPoffright_bunch1(int index, int pardex)
double getBTofFright(int index, int pardex)
double getBTofFcounter(int index, int pardex)
double getBTofPoffleft_bunch2(int index, int pardex)
double getETofAtten(int index, int pardex)
double getBTofAtten(int index, int pardex)
double getBTofPoffleft_bunch0(int index, int pardex)
double getBTofPleft(int index, int pardex)
double getETofSpeed(int index, int pardex)
double getBTofPright(int index, int pardex)
void setP2(const double *TofP2)
void setPoff1_bunch3(const double *TofPoff1_bunch3)
void setFPleft(const double *FP1)
void setPoff2_bunch1(const double *TofPoff2_bunch1)
void setSpeed(const double *Speed)
void setAtten(const double *Atten)
void setPoff1_bunch0(const double *TofPoff1_bunch0)
void setPoff2_bunch2(const double *TofPoff2_bunch2)
void setPoff1_bunch1(const double *TofPoff1_bunch1)
void setFPcounter(const double *FP3)
void setPoff1_bunch2(const double *TofPoff1_bunch2)
void setPoff2_bunch3(const double *TofPoff2_bunch3)
void setFPright(const double *FP2)
void setPoff2_bunch0(const double *TofPoff2_bunch0)
void setP1(const double *TofP1)
void setSigmaCorr(const double *sigmaCorr)
void setOffset(const double *offset)
void setAtten(const double *Atten)
void setP(const double *TofP)
void setFP(const double *FP)
void setSpeed(const double *Speed)
void setBrWest(const int *tofidWest)
void setRunEnd(const int run2)
void setVersion(const int version)
void setMisLable(const int misLable)
void setRunBegin(const int run1)
void setBrEast(const int *tofidEast)
void setQElec(const int qElec)
void setQCorr(const int qCorr)
void setEndcap(const int *tofidEndcap)
StatusCode openRead(const std::string &fname)
StatusCode closeWrite()
virtual StatusCode openWrite(const std::string &fname)
static const CLID & classID()
virtual StatusCode createRoot(const std::string &fname, CalibData::CalibBase1 *pTDSObj)
const CLID & objType() const
RootTofCalibDataCnv(ISvcLocator *svc)
virtual StatusCode i_createObj(const std::string &fname, DataObject *&refpObject)