/[PAMELA software]/DarthVader/TrackerLevel2/src/TrkStruct.cpp
ViewVC logotype

Contents of /DarthVader/TrackerLevel2/src/TrkStruct.cpp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.2 - (show annotations) (download)
Tue May 30 16:30:37 2006 UTC (18 years, 7 months ago) by pam-fi
Branch: MAIN
CVS Tags: v0r02, v1r01beta, v1r00, v1r01
Changes since 1.1: +95 -6 lines
Error handling from F77 routine / Fixed some bugs with default calibration

1 /**
2 * \file TrkStruct.h
3 * \author Elena Vannuccini
4 * \date
5 */
6 #include <TrkStruct.h>
7
8
9 using namespace pamela;
10 using namespace std;
11
12 float aint(float f){
13 int ret = (int)f;
14 float ret1 = 0;
15 ret1=(float)ret;
16 return ret1;
17 }
18
19 float anint(float f){
20 int ret = (int)(f+0.5);
21 float ret1 = 0;
22 ret1=(float)ret;
23 return ret1;
24 }
25 /**
26 * Method to fill the tracker calibration-parameter struct from on-line calibrations
27 */
28 void cTrkCalib::FillACalibFrom(TFile* f0, Int_t ev_reg1, Int_t ev_reg2){
29
30 TTree *tr1 = (TTree*)f0->Get("CalibTrk1");
31 TTree *tr2 = (TTree*)f0->Get("CalibTrk2");
32
33 CalibTrk1Event *calibdata1 = 0;
34 CalibTrk2Event *calibdata2 = 0;
35 tr1->SetBranchAddress("CalibTrk1",&calibdata1);
36 tr2->SetBranchAddress("CalibTrk2",&calibdata2);
37 tr1->GetEntry(ev_reg1);
38 tr2->GetEntry(ev_reg2);
39 Int_t dspn1(0),dspn2(0);
40
41 for(Int_t i=0;i<6;i++){
42 dspn1=calibdata1->DSPnumber[i]-1;
43 dspn2=calibdata2->DSPnumber[i]-1;
44 /* cout<<"dspn1= "<<dspn1<<" dspn2= "<<dspn2<<endl; */
45 for(Int_t ii=0;ii<3072;ii++){
46 Int_t j=(ii/128);
47 Int_t jj=ii-j*128;
48 pedestal[jj][j][dspn1]=calibdata1->DSPped_par[i][ii];
49 pedestal[jj][j][dspn2]=calibdata2->DSPped_par[i][ii];
50 pedestal_t[jj][j][dspn1]=aint(calibdata1->DSPped_par[i][ii]);
51 pedestal_t[jj][j][dspn2]=aint(calibdata2->DSPped_par[i][ii]);
52 sigma[jj][j][dspn1]=calibdata1->DSPsig_par[i][ii];
53 sigma[jj][j][dspn2]=calibdata2->DSPsig_par[i][ii];
54 sigma_t[jj][j][dspn1]=anint(calibdata1->DSPsig_par[i][ii]);
55 sigma_t[jj][j][dspn2]=anint(calibdata2->DSPsig_par[i][ii]);
56 // cout<<"sigma trk1= "<<sigma[jj][j][dspn1]<<endl;
57 // cout<<"sigma_t trk1= "<<sigma_t[jj][j][dspn1]<<endl;
58 // cout<<"sigma trk2= "<<sigma[jj][j][dspn2]<<endl;
59 // cout<<"sigma_t trk2= "<<sigma_t[jj][j][dspn2]<<endl;
60
61 //
62 // invert the bad
63 //
64 if(calibdata1->DSPbad_par[i][ii]==0)
65 bad[jj][j][dspn1]=1;
66 else if(calibdata1->DSPbad_par[i][ii]==1)
67 bad[jj][j][dspn1]=0;
68 if(calibdata2->DSPbad_par[i][ii]==0)
69 bad[jj][j][dspn2]=1;
70 else if(calibdata2->DSPbad_par[i][ii]==1)
71 bad[jj][j][dspn2]=0;
72 };
73 };
74
75 tr1->Delete();
76 tr2->Delete();
77 };
78
79 /**
80 * Method to fill the tracker calibration-parameter struct from on-line calibrations
81 */
82 void cTrkCalib::FillFCalibFrom(TFile* f0, Int_t ev_reg1, Int_t ev_reg2){
83
84 TTree *tr1 = (TTree*)f0->Get("CalibTrk1");
85 TTree *tr2 = (TTree*)f0->Get("CalibTrk2");
86
87 CalibTrk1Event *calibdata1 = 0;
88 CalibTrk2Event *calibdata2 = 0;
89 tr1->SetBranchAddress("CalibTrk1",&calibdata1);
90 tr2->SetBranchAddress("CalibTrk2",&calibdata2);
91 tr1->GetEntry(ev_reg1);
92 tr2->GetEntry(ev_reg2);
93 Int_t dspn1(0),dspn2(0);
94
95 for(Int_t i=0;i<6;i++){
96 dspn1=calibdata1->DSPnumber[i]-1;
97 dspn2=calibdata2->DSPnumber[i]-1;
98 /* cout<<"dspn1= "<<dspn1<<" dspn2= "<<dspn2<<endl; */
99 for(Int_t ii=0;ii<3072;ii++){
100 Int_t j=(ii/128);
101 Int_t jj=ii-j*128;
102 pedestal[jj][j][dspn1]=calibdata1->DSPped_par[i][ii];
103 pedestal[jj][j][dspn2]=calibdata2->DSPped_par[i][ii];
104 sigma[jj][j][dspn1]=calibdata1->DSPsig_par[i][ii];
105 sigma[jj][j][dspn2]=calibdata2->DSPsig_par[i][ii];
106 // cout<<"sigma trk1= "<<sigma[jj][j][dspn1]<<endl;
107 // cout<<"sigma_t trk1= "<<sigma_t[jj][j][dspn1]<<endl;
108 // cout<<"sigma trk2= "<<sigma[jj][j][dspn2]<<endl;
109 // cout<<"sigma_t trk2= "<<sigma_t[jj][j][dspn2]<<endl;
110
111 //
112 // invert the bad
113 //
114 if(calibdata1->DSPbad_par[i][ii]==0)
115 bad[jj][j][dspn1]=1;
116 else if(calibdata1->DSPbad_par[i][ii]==1)
117 bad[jj][j][dspn1]=0;
118 if(calibdata2->DSPbad_par[i][ii]==0)
119 bad[jj][j][dspn2]=1;
120 else if(calibdata2->DSPbad_par[i][ii]==1)
121 bad[jj][j][dspn2]=0;
122 };
123 };
124
125 tr1->Delete();
126 tr2->Delete();
127 };
128 /**
129 * Method to fill the tracker calibration-parameter struct from on-line calibrations
130 */
131 void cTrkCalib::FillTCalibFrom(TFile* f0, Int_t ev_reg1, Int_t ev_reg2){
132
133 TTree *tr1 = (TTree*)f0->Get("CalibTrk1");
134 TTree *tr2 = (TTree*)f0->Get("CalibTrk2");
135
136 CalibTrk1Event *calibdata1 = 0;
137 CalibTrk2Event *calibdata2 = 0;
138 tr1->SetBranchAddress("CalibTrk1",&calibdata1);
139 tr2->SetBranchAddress("CalibTrk2",&calibdata2);
140 tr1->GetEntry(ev_reg1);
141 tr2->GetEntry(ev_reg2);
142 Int_t dspn1(0),dspn2(0);
143
144 for(Int_t i=0;i<6;i++){
145 dspn1=calibdata1->DSPnumber[i]-1;
146 dspn2=calibdata2->DSPnumber[i]-1;
147 /* cout<<"dspn1= "<<dspn1<<" dspn2= "<<dspn2<<endl; */
148 for(Int_t ii=0;ii<3072;ii++){
149 Int_t j=(ii/128);
150 Int_t jj=ii-j*128;
151 pedestal_t[jj][j][dspn1]=aint(calibdata1->DSPped_par[i][ii]);
152 pedestal_t[jj][j][dspn2]=aint(calibdata2->DSPped_par[i][ii]);
153 sigma_t[jj][j][dspn1]=anint(calibdata1->DSPsig_par[i][ii]);
154 sigma_t[jj][j][dspn2]=anint(calibdata2->DSPsig_par[i][ii]);
155 };
156 };
157
158 tr1->Delete();
159 tr2->Delete();
160 };
161 /**
162 * Method to fill the tracker calibration-parameter struct from on-line calibrations
163 */
164 void cTrkCalib::FillTCalibFrom(TString path){
165
166 path_.FillWith(path);
167 fillpedsigfromdefault_();
168 if(path_.error) throw -216;
169
170 };
171

  ViewVC Help
Powered by ViewVC 1.1.23