]> git.uio.no Git - u/mrichter/AliRoot.git/blame - MUON/AliMUONTracker.h
Introducing event specie in QA (Yves)
[u/mrichter/AliRoot.git] / MUON / AliMUONTracker.h
CommitLineData
196471e9 1#ifndef ALIMUONTRACKER_H
2#define ALIMUONTRACKER_H
3/* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4 * See cxx source for full Copyright notice */
5
e41c38cf 6// $Id$
196471e9 7
6b092dfc 8/// \ingroup rec
196471e9 9/// \class AliMUONTracker
10/// \brief MUON base Tracker
d81d2e8e 11///
9bf6860b 12// Authors: Christian Finck, Laurent Aphecetche, SUBATECH Nantes
196471e9 13
14#include "AliTracker.h"
e64fdf8a 15
196471e9 16class AliCluster;
af885e0f 17class AliESDEvent;
e64fdf8a 18class AliMUONDigitMaker;
19class AliMUONGeometryTransformer;
a0dc65b4 20class AliMUONRecoParam;
e64fdf8a 21class AliMUONTrackHitPattern;
32ab62c9 22class AliMUONTriggerCircuit;
9bf6860b 23class AliMUONVClusterServer;
e64fdf8a 24class AliMUONVClusterStore;
9bf6860b 25class AliMUONVDigitStore;
196471e9 26class AliMUONVTrackReconstructor;
e64fdf8a 27class AliMUONVTrackStore;
28class AliMUONVTriggerStore;
9bf6860b 29class AliMUONVTriggerTrackStore;
196471e9 30
31class AliMUONTracker : public AliTracker
32{
33 public:
34
a0dc65b4 35 AliMUONTracker(const AliMUONRecoParam* recoParam,
36 AliMUONVClusterServer* clusterServer,
9bf6860b 37 const AliMUONVDigitStore& digitStore,
1fef78c8 38 const AliMUONDigitMaker* digitMaker=0,
e64fdf8a 39 const AliMUONGeometryTransformer* transformer=0,
683cb6c5 40 const AliMUONTriggerCircuit* triggerCircuit=0);
196471e9 41 virtual ~AliMUONTracker();
196471e9 42
af885e0f 43 virtual Int_t Clusters2Tracks(AliESDEvent* esd);
e64fdf8a 44
e64fdf8a 45 virtual Int_t LoadClusters(TTree* clustersTree);
46
e64fdf8a 47 virtual void UnloadClusters();
48
a0dc65b4 49 const AliMUONRecoParam* GetRecoParam() const { return fRecoParam; }
50
71a2d3aa 51 /// Dummy implementation
af885e0f 52 virtual Int_t PropagateBack(AliESDEvent* /*event*/) {return 0;}
71a2d3aa 53 /// Dummy implementation
af885e0f 54 virtual Int_t RefitInward(AliESDEvent* /*event*/) {return 0;}
71a2d3aa 55 /// Dummy implementation
196471e9 56 virtual AliCluster *GetCluster(Int_t /*index*/) const {return 0;}
196471e9 57
a0dc65b4 58 static AliMUONVTrackReconstructor* CreateTrackReconstructor(const AliMUONRecoParam* recoParam, AliMUONVClusterServer* clusterServer);
9bf6860b 59
196471e9 60private:
71a2d3aa 61 /// Not implemented
62 AliMUONTracker(const AliMUONTracker& rhs);
63 /// Not implemented
64 AliMUONTracker& operator=(const AliMUONTracker& rhs);
65
1fef78c8 66 AliMUONVClusterStore* ClusterStore() const;
67
9bf6860b 68 AliMUONVTriggerTrackStore* TriggerTrackStore() const;
3304fa09 69
af885e0f 70 void FillESD(AliMUONVTrackStore& trackStore, AliESDEvent* esd) const;
e64fdf8a 71
9bf6860b 72 void SetupClusterServer(AliMUONVClusterServer& clusterServer);
73
e64fdf8a 74private:
e64fdf8a 75 const AliMUONDigitMaker* fDigitMaker; //!< digit maker (not owner)
76 const AliMUONGeometryTransformer* fTransformer; //!< geometry transformer (not owner)
3304fa09 77 const AliMUONTriggerCircuit* fTriggerCircuit; //!< trigger circuit (not owner)
e64fdf8a 78 AliMUONTrackHitPattern* fTrackHitPatternMaker; //!< trigger hit pattern maker
3304fa09 79 AliMUONVTrackReconstructor* fTrackReco; //!< track reconstructor
1fef78c8 80 mutable AliMUONVClusterStore* fClusterStore; //!< cluster container
e64fdf8a 81 AliMUONVTriggerStore* fTriggerStore; //!< trigger information
9bf6860b 82 AliMUONVClusterServer* fClusterServer; //!< to get clusters
83 Bool_t fIsOwnerOfClusterServer; //!< whether we are owner of the cluster server
89b4e052 84 const AliMUONVDigitStore& fDigitStore; //!< digit info to fill in ESD
9bf6860b 85 mutable AliMUONVClusterStore* fInputClusterStore; //!< cluster container
86 mutable AliMUONVTriggerTrackStore* fTriggerTrackStore; //!< trigger track store
a0dc65b4 87 const AliMUONRecoParam* fRecoParam; //!< pointer to reco param
e64fdf8a 88
196471e9 89 ClassDef(AliMUONTracker,0) //tracker base class for MUON
90};
91#endif