/************************************************************************** * Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. * * * * Author: The ALICE Off-line Project. * * Contributors are mentioned in the code where appropriate. * * * * Permission to use, copy, modify and distribute this software and its * * documentation strictly for non-commercial purposes is hereby granted * * without fee, provided that the above copyright notice appears in all * * copies and that both the copyright notice and this permission notice * * appear in the supporting documentation. The authors make no claims * * about the suitability of this software for any purpose. It is * * provided "as is" without express or implied warranty. * **************************************************************************/ /* $Id$ */ //------------------------------------------------------------------------- // Implementation of the AliTracker class // that is the base for AliTPCtracker, AliITStrackerV2 and AliTRDtracker // Origin: Iouri Belikov, CERN, Jouri.Belikov@cern.ch //------------------------------------------------------------------------- #include #include #include "AliTracker.h" #include "AliCluster.h" #include "AliKalmanTrack.h" Bool_t AliTracker::fgUniformField=kTRUE; Double_t AliTracker::fgBz=0.; const AliMagF *AliTracker::fgkFieldMap=0; ClassImp(AliTracker) AliTracker::AliTracker(): fX(0), fY(0), fZ(0), fSigmaX(0.005), fSigmaY(0.005), fSigmaZ(0.010) { //-------------------------------------------------------------------- // The default constructor. //-------------------------------------------------------------------- if (!fgkFieldMap) AliWarning("Field map is not set. Call AliTracker::SetFieldMap before creating a tracker!"); } void AliTracker::SetFieldMap(const AliMagF* map, Bool_t uni) { //-------------------------------------------------------------------- //This passes the field map to the reconstruction. //-------------------------------------------------------------------- if (map==0) AliFatalClass("Can't access the field map !"); if (fgkFieldMap) { AliWarningClass("The magnetic field map has been already set !"); return; } fgUniformField=uni; fgkFieldMap=map; //Float_t r[3]={0.,0.,0.},b[3]; map->Field(r,b); //Double_t bz=-b[2]; Double_t bz=-map->SolenoidField(); fgBz=TMath::Sign(1e-13,bz) + bz; } //__________________________________________________________________________ void AliTracker::CookLabel(AliKalmanTrack *t, Float_t wrong) const { //-------------------------------------------------------------------- //This function "cooks" a track label. If label<0, this track is fake. //-------------------------------------------------------------------- Int_t noc=t->GetNumberOfClusters(); Int_t *lb=new Int_t[noc]; Int_t *mx=new Int_t[noc]; AliCluster **clusters=new AliCluster*[noc]; Int_t i; for (i=0; iGetClusterIndex(i); clusters[i]=GetCluster(index); } Int_t lab=123456789; for (i=0; iGetLabel(0)); Int_t j; for (j=0; jmax) {max=mx[i]; lab=lb[i];} for (i=0; iGetLabel(1)) == lab || // TMath::Abs(c->GetLabel(2)) == lab ) max++; if (TMath::Abs(c->GetLabel(0)!=lab)) if (TMath::Abs(c->GetLabel(1)) == lab || TMath::Abs(c->GetLabel(2)) == lab ) max++; } if ((1.- Float_t(max)/noc) > wrong) lab=-lab; t->SetFakeRatio((1.- Float_t(max)/noc)); t->SetLabel(lab); delete[] lb; delete[] mx; delete[] clusters; } //____________________________________________________________________________ void AliTracker::UseClusters(const AliKalmanTrack *t, Int_t from) const { //------------------------------------------------------------------ //This function marks clusters associated with the track. //------------------------------------------------------------------ Int_t noc=t->GetNumberOfClusters(); for (Int_t i=from; iGetClusterIndex(i); AliCluster *c=GetCluster(index); c->Use(); } }