167{
168 MsgStream log(
msgSvc(), name());
169 log<<MSG::INFO<<"DedxCalibMomentum::WriteHists()"<< endreq;
170
172 double pos_chientryNo[
nbins]={0},pos_chimean[
nbins]={0},pos_chimeanerr[
nbins]={0},pos_chisigma[
nbins]={0},pos_chisq[
nbins]={0};
173 double neg_chientryNo[
nbins]={0},neg_chimean[
nbins]={0},neg_chimeanerr[
nbins]={0},neg_chisigma[
nbins]={0},neg_chisq[
nbins]={0};
175 double pos_fitentryNo[
nbins]={0},pos_fitmean[
nbins]={0},pos_fitmeanerr[
nbins]={0},pos_fitsigma[
nbins]={0},pos_fitchisq[
nbins]={0};
176 double neg_fitentryNo[
nbins]={0},neg_fitmean[
nbins]={0},neg_fitmeanerr[
nbins]={0},neg_fitsigma[
nbins]={0},neg_fitchisq[
nbins]={0};
177 double hits_mean[
nbins]={0},hits_sigma[
nbins]={0};
178 double pBin[
nbins]={0};
179
180 for(
int i=0;i<
nbins;i++)
181 {
182 pBin[i] = (i+0.5)*bin_step + pMin;
183
184 chientryNo[i] = m_chi[i]->Integral();
185 if(chientryNo[i]>100)
186 {
187 chimean[i] = m_chi[i]->GetFunction("gaus")->GetParameter(1);
188 chimeanerr[i] = m_chi[i]->GetFunction("gaus")->GetParError(1);
189 chisigma[i] = m_chi[i]->GetFunction("gaus")->GetParameter(2);
190 chisq[i] = (m_chi[i]->GetFunction("gaus")->GetChisquare())/(m_chi[i]->GetFunction("gaus")->GetNDF());
191 }
192 pos_chientryNo[i] = m_pos_chi[i]->Integral();
193 if(pos_chientryNo[i]>100)
194 {
195 pos_chimean[i] = m_pos_chi[i]->GetFunction("gaus")->GetParameter(1);
196 pos_chimeanerr[i] = m_pos_chi[i]->GetFunction("gaus")->GetParError(1);
197 pos_chisigma[i] = m_pos_chi[i]->GetFunction("gaus")->GetParameter(2);
198 pos_chisq[i] = (m_pos_chi[i]->GetFunction("gaus")->GetChisquare())/(m_pos_chi[i]->GetFunction("gaus")->GetNDF());
199 }
200 neg_chientryNo[i] = m_neg_chi[i]->Integral();
201 if(neg_chientryNo[i]>100)
202 {
203 neg_chimean[i] = m_neg_chi[i]->GetFunction("gaus")->GetParameter(1);
204 neg_chimeanerr[i] = m_neg_chi[i]->GetFunction("gaus")->GetParError(1);
205 neg_chisigma[i] = m_neg_chi[i]->GetFunction("gaus")->GetParameter(2);
206 neg_chisq[i] = (m_neg_chi[i]->GetFunction("gaus")->GetChisquare())/(m_neg_chi[i]->GetFunction("gaus")->GetNDF());
207 }
208
209 fitentryNo[i] = m_dedx[i]->Integral();
210 if(fitentryNo[i]>100)
211 {
212 fitmean[i] = m_dedx[i]->GetFunction("gaus")->GetParameter(1);
213 fitmeanerr[i] = m_dedx[i]->GetFunction("gaus")->GetParError(1);
214 fitsigma[i] = m_dedx[i]->GetFunction("gaus")->GetParameter(2);
215 fitchisq[i] = (m_dedx[i]->GetFunction("gaus")->GetChisquare())/(m_dedx[i]->GetFunction("gaus")->GetNDF());
216 }
217 pos_fitentryNo[i] = m_pos_dedx[i]->Integral();
218 if(pos_fitentryNo[i]>100)
219 {
220 pos_fitmean[i] = m_pos_dedx[i]->GetFunction("gaus")->GetParameter(1);
221 pos_fitmeanerr[i] = m_pos_dedx[i]->GetFunction("gaus")->GetParError(1);
222 pos_fitsigma[i] = m_pos_dedx[i]->GetFunction("gaus")->GetParameter(2);
223 pos_fitchisq[i] = (m_pos_dedx[i]->GetFunction("gaus")->GetChisquare())/(m_pos_dedx[i]->GetFunction("gaus")->GetNDF());
224 }
225 neg_fitentryNo[i] = m_neg_dedx[i]->Integral();
226 if(neg_fitentryNo[i]>100)
227 {
228 neg_fitmean[i] = m_neg_dedx[i]->GetFunction("gaus")->GetParameter(1);
229 neg_fitmeanerr[i] = m_neg_dedx[i]->GetFunction("gaus")->GetParError(1);
230 neg_fitsigma[i] = m_neg_dedx[i]->GetFunction("gaus")->GetParameter(2);
231 neg_fitchisq[i] = (m_neg_dedx[i]->GetFunction("gaus")->GetChisquare())/(m_neg_dedx[i]->GetFunction("gaus")->GetNDF());
232 }
233
234 hits_mean[i] = m_hits[i]->GetMean();
235 hits_sigma[i] = m_hits[i]->GetRMS();
236 }
237
238 double dedx1[
Size] = {0};
239 double ptrk1[
Size] = {0};
240 cout << "Vec_dedx.size() = " << Vec_dedx.size() << endl;
241 for(
int i=0;i<
Size && i< Vec_dedx.size();i++)
242 {
243 dedx1[i] = Vec_dedx[i];
244 ptrk1[i] = Vec_ptrk[i];
245
246 }
247
248 log<<MSG::INFO<<"begin generating root file!!! "<<endreq;
249 TFile*
f =
new TFile(
m_rootfile.c_str(),
"RECREATE");
250 for(
int i=0;i<
nbins;i++)
251 {
252 m_chi[i]->Write();
253 m_pos_chi[i]->Write();
254 m_neg_chi[i]->Write();
255 m_dedx[i]->Write();
256 m_pos_dedx[i]->Write();
257 m_neg_dedx[i]->Write();
258 m_hits[i]->Write();
259 }
260
261 TTree* momInfor = new TTree("momInfor","momInfor");
262 momInfor->Branch("chientryNo",chientryNo,"chientryNo[50]/D");
263 momInfor->Branch("chimean",chimean,"chimean[50]/D");
264 momInfor->Branch("chimeanerr",chimeanerr,"chimeanerr[50]/D");
265 momInfor->Branch("chisigma",chisigma,"chisigma[50]/D");
266 momInfor->Branch("chisq",chisq,"chisq[50]/D");
267 momInfor->Branch("pos_chientryNo",pos_chientryNo,"pos_chientryNo[50]/D");
268 momInfor->Branch("pos_chimean",pos_chimean,"pos_chimean[50]/D");
269 momInfor->Branch("pos_chimeanerr",pos_chimeanerr,"pos_chimeanerr[50]/D");
270 momInfor->Branch("pos_chisigma",pos_chisigma,"pos_chisigma[50]/D");
271 momInfor->Branch("pos_chisq",pos_chisq,"pos_chisq[50]/D");
272 momInfor->Branch("neg_chientryNo",neg_chientryNo,"neg_chientryNo[50]/D");
273 momInfor->Branch("neg_chimean",neg_chimean,"neg_chimean[50]/D");
274 momInfor->Branch("neg_chimeanerr",neg_chimeanerr,"neg_chimeanerr[50]/D");
275 momInfor->Branch("neg_chisigma",neg_chisigma,"neg_chisigma[50]/D");
276 momInfor->Branch("neg_chisq",neg_chisq,"neg_chisq[50]/D");
277 momInfor->Branch("fitentryNo",fitentryNo,"fitentryNo[50]/D");
278 momInfor->Branch("fitmean",fitmean,"fitmean[50]/D");
279 momInfor->Branch("fitmeanerr",fitmeanerr,"fitmeanerr[50]/D");
280 momInfor->Branch("fitsigma",fitsigma,"fitsigma[50]/D");
281 momInfor->Branch("fitchisq",fitchisq,"fitchisq[50]/D");
282 momInfor->Branch("pos_fitentryNo",pos_fitentryNo,"pos_fitentryNo[50]/D");
283 momInfor->Branch("pos_fitmean",pos_fitmean,"pos_fitmean[50]/D");
284 momInfor->Branch("pos_fitmeanerr",pos_fitmeanerr,"pos_fitmeanerr[50]/D");
285 momInfor->Branch("pos_fitsigma",pos_fitsigma,"pos_fitsigma[50]/D");
286 momInfor->Branch("pos_fitchisq",pos_fitchisq,"pos_fitchisq[50]/D");
287 momInfor->Branch("neg_fitentryNo",neg_fitentryNo,"neg_fitentryNo[50]/D");
288 momInfor->Branch("neg_fitmean",neg_fitmean,"neg_fitmean[50]/D");
289 momInfor->Branch("neg_fitmeanerr",neg_fitmeanerr,"neg_fitmeanerr[50]/D");
290 momInfor->Branch("neg_fitsigma",neg_fitsigma,"neg_fitsigma[50]/D");
291 momInfor->Branch("neg_fitchisq",neg_fitchisq,"neg_fitchisq[50]/D");
292 momInfor->Branch("hits_mean",hits_mean,"hits_mean[50]/D");
293 momInfor->Branch("hits_sigma",hits_sigma,"hits_sigma[50]/D");
294 momInfor->Branch("pBin",pBin,"pBin[50]/D");
295 momInfor->
Branch(
"ptrk1",ptrk1,
"ptrk1[700000]/D");
296 momInfor->
Branch(
"dedx1",dedx1,
"dedx1[700000]/D");
297 momInfor->Fill();
298 momInfor->Write();
299
300 TCanvas c1("c1", "canvas", 500, 400);
302 momInfor ->
Draw(
"dedx1:ptrk1",
"dedx1>200 && dedx1<1200");
304 for(Int_t i=0;i<
nbins;i++)
305 {
306 m_chi[i]->Draw();
308 }
309 for(Int_t i=0;i<
nbins;i++)
310 {
311 m_pos_chi[i]->Draw();
313 }
314 for(Int_t i=0;i<
nbins;i++)
315 {
316 m_neg_chi[i]->Draw();
318 }
319 for(Int_t i=0;i<
nbins;i++)
320 {
321 m_dedx[i]->Draw();
323 }
324 for(Int_t i=0;i<
nbins;i++)
325 {
326 m_pos_dedx[i]->Draw();
328 }
329 for(Int_t i=0;i<
nbins;i++)
330 {
331 m_neg_dedx[i]->Draw();
333 }
336
337 for(
int i=0;i<
nbins;i++)
338 {
339 delete m_chi[i];
340 delete m_pos_chi[i];
341 delete m_neg_chi[i];
342 delete m_dedx[i];
343 delete m_pos_dedx[i];
344 delete m_neg_dedx[i];
345 delete m_hits[i];
346 }
347}
curve Branch("CurveSize",&CurveSize,"CurveSize/I")