--- PamCut/TrkCuts/TrkChi2DeflTimeCut/TrkChi2DeflTimeCut.cpp 2011/05/27 14:01:39 1.5 +++ PamCut/TrkCuts/TrkChi2DeflTimeCut/TrkChi2DeflTimeCut.cpp 2015/03/25 17:38:08 1.7 @@ -8,7 +8,8 @@ #include "TrkChi2DeflTimeCut.h" double TrkChi2DeflTimeCut::_GetChi2(PamLevel2 *event) { - return event->GetTrack(0)->GetTrkTrack()->chi2; +// return event->GetTrack(0)->GetTrkTrack()->chi2; + return (event->GetNTracks(_trkAlg)<=0 ? -1. : event->GetTrack(0,_trkAlg)->GetExtTrack()->chi2); } int TrkChi2DeflTimeCut::Check(PamLevel2 *event) { @@ -16,13 +17,41 @@ double chi2 = _GetChi2(event); if (chi2 < 0.) return 0; - Double_t etaMod = fabs(event->GetTrack(0)->GetTrkTrack()->GetDeflection()); +// Double_t etaMod = fabs(event->GetTrack(0)->GetTrkTrack()->GetDeflection()); +// Int_t nHitX = event->GetTrack(0)->GetTrkTrack()->GetNX(); + Double_t etaMod = fabs(event->GetTrack(0,_trkAlg)->GetExtTrack()->GetDeflection()); + Int_t nHitX = event->GetTrack(0,_trkAlg)->GetExtTrack()->GetNX(); + +// cout << " nHitX " << nHitX << endl; + + if (nHitX == 3) { + for (UInt_t i = 0; i < _iDayFirst_nHitX3.size(); i++) { + _iDayFirst.push_back(_iDayFirst_nHitX3[i]); + _iDayLast.push_back(_iDayLast_nHitX3[i]); + for (int iPar=0; iPar<_nPar; iPar++) { + _p[iPar].push_back(_p_nHitX3[iPar][i]); + } + } + } + else if (nHitX >= 4) { + for (UInt_t i = 0; i < _iDayFirst_nHitX4.size(); i++) { + _iDayFirst.push_back(_iDayFirst_nHitX4[i]); + _iDayLast.push_back(_iDayLast_nHitX4[i]); + for (int iPar=0; iPar<_nPar; iPar++) { + _p[iPar].push_back(_p_nHitX4[iPar][i]); + } + } + } + else { + return 0; + } _time.Set(event->GetOrbitalInfo()->absTime, kFALSE, 0, kFALSE); // TTimestamp::GetDate() returns date in format YYYYMMDD so to compare it // with 6-digits dates (YYMMDD) we must subtract 20000000 Int_t iDaySel = (_time.GetDate(kFALSE) - 20000000); // note: GetDate returns an unsigned integer +// cout << "day " << iDaySel << endl; bool found = false; for (UInt_t i = 0; i < _iDayFirst.size(); i++) { @@ -40,8 +69,16 @@ } } - if (!found) + if (!found) { + cout << "not found" << endl; + cout << endl; return 0; + } + +// for (int iPar=0; iPar<_nPar; iPar++) { +// cout << " p" << iPar << ": " << _pSel[iPar] << endl; +// } +// cout << endl; double chi2max;