3 #ifndef ALIHLTTPCCLUSTERFINDERCOMPONENT_H
4 #define ALIHLTTPCCLUSTERFINDERCOMPONENT_H
6 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
7 * See cxx source for full Copyright notice */
9 /* AliHLTTPCClusterFinderComponent
12 #include "AliHLTProcessor.h"
13 #include "AliHLTTPCDefinitions.h"
14 #include "AliHLTTPCDigitReaderPacked.h"
15 #include "AliHLTTPCDigitReaderUnpacked.h"
17 class AliHLTTPCClusterFinder;
19 class AliHLTTPCClusterFinderComponent : public AliHLTProcessor
24 * @param packed whether to use the packed or unpacked reader
26 AliHLTTPCClusterFinderComponent(bool packed);
27 /** not a valid copy constructor, defined according to effective C++ style */
28 AliHLTTPCClusterFinderComponent(const AliHLTTPCClusterFinderComponent&);
29 /** not a valid assignment op, but defined according to effective C++ style */
30 AliHLTTPCClusterFinderComponent& operator=(const AliHLTTPCClusterFinderComponent&);
32 virtual ~AliHLTTPCClusterFinderComponent();
34 // Public functions to implement AliHLTComponent's interface.
35 // These functions are required for the registration process
37 const char* GetComponentID();
38 void GetInputDataTypes( vector<AliHLTComponent_DataType>& list);
39 AliHLTComponent_DataType GetOutputDataType();
40 virtual void GetOutputDataSize( unsigned long& constBase, double& inputMultiplier );
41 AliHLTComponent* Spawn();
45 // Protected functions to implement AliHLTComponent's interface.
46 // These functions provide initialization as well as the actual processing
47 // capabilities of the component.
49 int DoInit( int argc, const char** argv );
51 int DoEvent( const AliHLTComponent_EventData& evtData, const AliHLTComponent_BlockData* blocks,
52 AliHLTComponent_TriggerData& trigData, AliHLTUInt8_t* outputPtr,
53 AliHLTUInt32_t& size, vector<AliHLTComponent_BlockData>& outputBlocks );
57 AliHLTTPCClusterFinder* fClusterFinder;
58 AliHLTTPCDigitReader* fReader;
60 float fXYClusterError;
64 ClassDef(AliHLTTPCClusterFinderComponent, 0)