]>
Commit | Line | Data |
---|---|---|
71d7c760 | 1 | // XEmacs -*-C++-*- |
2 | // @(#) $Id$ | |
3 | ||
4 | #ifndef ALIHLTTPCSLICETRACKERCOMPONENT_H | |
5 | #define ALIHLTTPCSLICETRACKERCOMPONENT_H | |
6 | /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. * | |
7 | * See cxx source for full Copyright notice */ | |
8 | ||
de554e07 | 9 | /** @file AliHLTTPCSliceTrackerComponent.h |
10 | @author Timm Steinbeck, Matthias Richter | |
11 | @date | |
12 | @brief The TPC conformal mapping tracker component. | |
13 | */ | |
71d7c760 | 14 | |
e67b0680 | 15 | // see below for class documentation |
16 | // or | |
17 | // refer to README to build package | |
18 | // or | |
19 | // visit http://web.ift.uib.no/~kjeks/doc/alice-hlt | |
20 | ||
71d7c760 | 21 | #include "AliHLTProcessor.h" |
71d7c760 | 22 | |
a6c02c85 | 23 | class AliHLTTPCConfMapper; |
24 | class AliHLTTPCVertex; | |
ecefc48a | 25 | class AliHLTTPCInterMerger; |
71d7c760 | 26 | |
de554e07 | 27 | /** |
28 | * @class AliHLTTPCSliceTrackerComponent | |
29 | * The TPC conformal mapping tracker component. | |
30 | * | |
31 | * The component has the following component arguments: | |
32 | * - disable-merger disable merging of track segments | |
33 | * - pp-run parameter set for pp run | |
34 | * - multiplicity multiplicity to choose parameter set for | |
35 | * - bfield magnatic field | |
36 | * | |
37 | * @ingroup alihlt_tpc | |
38 | */ | |
71d7c760 | 39 | class AliHLTTPCSliceTrackerComponent : public AliHLTProcessor |
6235cd38 | 40 | { |
41 | public: | |
42 | /** default constructor */ | |
43 | AliHLTTPCSliceTrackerComponent(); | |
6235cd38 | 44 | /** destructor */ |
45 | virtual ~AliHLTTPCSliceTrackerComponent(); | |
71d7c760 | 46 | |
5df0cbb9 | 47 | // Public functions to implement AliHLTComponent's interface. |
48 | // These functions are required for the registration process | |
71d7c760 | 49 | |
5df0cbb9 | 50 | /** interface function, see @ref AliHLTComponent for description */ |
51 | const char* GetComponentID(); | |
52 | /** interface function, see @ref AliHLTComponent for description */ | |
7bcd6cad | 53 | void GetInputDataTypes(AliHLTComponentDataTypeList& list); |
5df0cbb9 | 54 | /** interface function, see @ref AliHLTComponent for description */ |
55 | AliHLTComponentDataType GetOutputDataType(); | |
56 | /** interface function, see @ref AliHLTComponent for description */ | |
57 | virtual void GetOutputDataSize( unsigned long& constBase, double& inputMultiplier ); | |
58 | /** interface function, see @ref AliHLTComponent for description */ | |
59 | AliHLTComponent* Spawn(); | |
a655eae3 | 60 | |
6235cd38 | 61 | protected: |
71d7c760 | 62 | |
5df0cbb9 | 63 | /** |
64 | * Set Tracker parameters | |
65 | * Knowledge on that has been lost, so somebody has to insert more | |
66 | * documentation. | |
67 | */ | |
68 | void SetTrackerParam(Int_t phiSegments=50,Int_t etaSegments=100, | |
69 | Int_t trackletlength=3,Int_t tracklength=5, | |
70 | Int_t rowscopetracklet=2,Int_t rowscopetrack=3, | |
71 | Double_t minPtFit=0,Double_t maxangle=1.31, | |
72 | Double_t goodDist=5,Double_t hitChi2Cut=10, | |
73 | Double_t goodHitChi2=20,Double_t trackChi2Cut=50, | |
74 | Int_t maxdist=50,Double_t maxphi=0.1,Double_t maxeta=0.1, | |
75 | bool vertexconstraint=true); | |
71d7c760 | 76 | |
5df0cbb9 | 77 | /** |
78 | * Set Tracker parameters | |
79 | * Knowledge on that has been lost, so somebody has to insert more | |
80 | * documentation. | |
81 | */ | |
82 | void SetTrackerParam( bool doPP, int multiplicity, double bField ); | |
83 | ||
84 | /** | |
85 | * Set default tracker parameters | |
86 | * Knowledge on that has been lost, so somebody has to insert more | |
87 | * documentation. | |
88 | */ | |
89 | void SetTrackerParam1(); | |
90 | ||
91 | // Protected functions to implement AliHLTComponent's interface. | |
92 | // These functions provide initialization as well as the actual processing | |
93 | // capabilities of the component. | |
94 | ||
95 | /** interface function, see @ref AliHLTComponent for description */ | |
96 | int DoInit( int argc, const char** argv ); | |
97 | /** interface function, see @ref AliHLTComponent for description */ | |
98 | int DoDeinit(); | |
99 | /** interface function, see @ref AliHLTComponent for description */ | |
100 | int DoEvent( const AliHLTComponentEventData& evtData, const AliHLTComponentBlockData* blocks, | |
101 | AliHLTComponentTriggerData& trigData, AliHLTUInt8_t* outputPtr, | |
7bcd6cad | 102 | AliHLTUInt32_t& size, AliHLTComponentBlockDataList& outputBlocks ); |
5df0cbb9 | 103 | |
6235cd38 | 104 | private: |
cb703d46 | 105 | /** copy constructor prohibited */ |
106 | AliHLTTPCSliceTrackerComponent(const AliHLTTPCSliceTrackerComponent&); | |
107 | /** assignment operator prohibited */ | |
108 | AliHLTTPCSliceTrackerComponent& operator=(const AliHLTTPCSliceTrackerComponent&); | |
71d7c760 | 109 | |
6235cd38 | 110 | /** instance of the tracker */ |
111 | AliHLTTPCConfMapper* fTracker; //! transient | |
112 | /** vertex object */ | |
113 | AliHLTTPCVertex* fVertex; //! transient | |
114 | /** eta range */ | |
115 | Float_t fEta[2]; // see above | |
116 | /** switch for subsequent non-vertex tracking */ | |
117 | Bool_t fDoNonVertex; // see above | |
118 | /** */ | |
119 | Bool_t fDoPP; // see above | |
120 | /** multiplicity estimate */ | |
121 | Int_t fMultiplicity; // see above | |
122 | /** magnetic field */ | |
123 | Double_t fBField; // see above | |
71d7c760 | 124 | |
6235cd38 | 125 | Bool_t fnonvertextracking; // enable NONVERTEX Tracking |
126 | Bool_t fmainvertextracking; // enable MAINVERTEX Tracking | |
738c049f | 127 | |
ecefc48a | 128 | /** merger object */ |
129 | AliHLTTPCInterMerger *fpInterMerger; //! transient | |
130 | ||
6235cd38 | 131 | ClassDef(AliHLTTPCSliceTrackerComponent, 0); |
71d7c760 | 132 | |
6235cd38 | 133 | }; |
71d7c760 | 134 | #endif |