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 */
8 /// \class AliMUONTracker
9 /// \brief MUON base Tracker
11 // Author: Christian Finck, SUBATECH Nantes
13 #include "AliTracker.h"
17 class AliMUONDigitMaker;
18 class AliMUONGeometryTransformer;
19 class AliMUONTrackHitPattern;
20 class AliMUONTriggerCircuit;
21 class AliMUONVClusterStore;
22 class AliMUONVTrackReconstructor;
23 class AliMUONVTrackStore;
24 class AliMUONVTriggerStore;
25 class AliMUONVClusterServer;
26 class AliMUONVDigitStore;
28 class AliMUONTracker : public AliTracker
32 AliMUONTracker(AliMUONVClusterServer& clusterServer,
33 const AliMUONVDigitStore& digitStore,
34 const AliMUONDigitMaker* digitMaker=0,
35 const AliMUONGeometryTransformer* transformer=0,
36 const AliMUONTriggerCircuit* triggerCircuit=0);
37 virtual ~AliMUONTracker();
39 virtual Int_t Clusters2Tracks(AliESDEvent* esd);
41 virtual Int_t LoadClusters(TTree* clustersTree);
43 virtual void UnloadClusters();
45 /// Dummy implementation
46 virtual Int_t PropagateBack(AliESDEvent* /*event*/) {return 0;}
47 /// Dummy implementation
48 virtual Int_t RefitInward(AliESDEvent* /*event*/) {return 0;}
49 /// Dummy implementation
50 virtual AliCluster *GetCluster(Int_t /*index*/) const {return 0;}
54 AliMUONTracker(const AliMUONTracker& rhs);
56 AliMUONTracker& operator=(const AliMUONTracker& rhs);
58 AliMUONVClusterStore* ClusterStore() const;
60 void CreateTrackReconstructor();
62 void FillESD(AliMUONVTrackStore& trackStore, AliESDEvent* esd) const;
65 const AliMUONDigitMaker* fDigitMaker; //!< digit maker (not owner)
66 const AliMUONGeometryTransformer* fTransformer; //!< geometry transformer (not owner)
67 const AliMUONTriggerCircuit* fTriggerCircuit; //!< trigger circuit (not owner)
68 AliMUONTrackHitPattern* fTrackHitPatternMaker; //!< trigger hit pattern maker
69 AliMUONVTrackReconstructor* fTrackReco; //!< track reconstructor
70 mutable AliMUONVClusterStore* fClusterStore; //!< cluster container
71 AliMUONVTriggerStore* fTriggerStore; //!< trigger information
72 AliMUONVClusterServer& fClusterServer; //!< to get clusters
73 const AliMUONVDigitStore& fDigitStore; //!< digit info to fill in ESD
75 ClassDef(AliMUONTracker,0) //tracker base class for MUON