2 #ifndef ALIHLTTPCCALIBPULSERCOMPONENT_H
3 #define ALIHLTTPCCALIBPULSERCOMPONENT_H
5 /* This file is property of and copyright by the ALICE HLT Project *
6 * ALICE Experiment at CERN, All rights reserved. *
7 * See cxx source for full Copyright notice */
9 /** @file AliHLTTPCCalibPulserComponent.h
10 @author Jochen Thaeder
12 @brief A pulser calibration component for the TPC.
15 // see header file for class documentation
17 // refer to README to build package
19 // visit http://web.ift.uib.no/~kjeks/doc/alice-hlt
21 #include "AliHLTCalibrationProcessor.h"
22 #include "AliHLTTPCDefinitions.h"
24 class AliTPCRawStream;
25 class AliRawReaderMemory;
26 class AliTPCCalibPulser;
29 * @class AliHLTTPCCalibPulserComponent
31 * This class is the calibration component for the AliTPCCalibPulser class
32 * used for pulser calibration of the TPC.
34 * It inherits from the AliHLTCalibrationProcessor and uses the high-level
35 * interface. The output is the class AliTPCCalibPulser as a TObject.
37 * The component has the following component arguments:
38 * -rcuformat <old/new> : Wether to use old or new rcuformat ( default is new )
39 * -enableanalysis : Wether to enable analyis before shipping data to FXS
43 class AliHLTTPCCalibPulserComponent : public AliHLTCalibrationProcessor
47 AliHLTTPCCalibPulserComponent();
49 virtual ~AliHLTTPCCalibPulserComponent();
51 // Public functions to implement AliHLTComponent's interface.
52 // These functions are required for the registration process
54 const char* GetComponentID();
55 void GetInputDataTypes( vector<AliHLTComponentDataType>& list);
56 AliHLTComponentDataType GetOutputDataType();
57 virtual void GetOutputDataSize( unsigned long& constBase, double& inputMultiplier );
58 AliHLTComponent* Spawn();
62 using AliHLTCalibrationProcessor::ProcessCalibration;
63 using AliHLTCalibrationProcessor::ShipDataToFXS;
65 // Protected functions to implement AliHLTComponent's interface.
66 // These functions provide initialization as well as the actual processing
67 // capabilities of the component.
69 /** Initialize the calibration component. */
70 Int_t InitCalibration();
72 /** Scan commandline arguments of the calibration component. */
73 Int_t ScanArgument( Int_t argc, const char** argv );
75 /** DeInitialize the calibration component. */
76 Int_t DeinitCalibration();
78 /** Process the data in the calibration component. */
79 Int_t ProcessCalibration( const AliHLTComponentEventData& evtData, AliHLTComponentTriggerData& trigData );
81 /** Ship the data to the FXS at end of run or eventmodulo. */
82 Int_t ShipDataToFXS( const AliHLTComponentEventData& evtData, AliHLTComponentTriggerData& trigData );
85 /** copy constructor prohibited */
86 AliHLTTPCCalibPulserComponent(const AliHLTTPCCalibPulserComponent&);
87 /** assignment operator prohibited */
88 AliHLTTPCCalibPulserComponent& operator=(const AliHLTTPCCalibPulserComponent&);
90 /** The reader object for reading from memory */
91 AliRawReaderMemory* fRawReader; //!transient
93 /** The reader object for reading TPC raw data */
94 AliTPCRawStream* fRawStream; //!transient
96 /** Pulser Calibration class */
97 AliTPCCalibPulser * fCalibPulser; //!transient
99 /** Wether to use old RCU format */
100 Bool_t fRCUFormat; // see above
102 /** Minimum patch specifcation for this component */
103 AliHLTUInt8_t fMinPatch; // see above
105 /** Minimum patch specifcation for this component */
106 AliHLTUInt8_t fMaxPatch; // see above
108 /** The Specification for this component */
109 AliHLTUInt32_t fSpecification; // see above
111 /** Analysze calibration data before shipping to FXS */
112 Bool_t fEnableAnalysis; // see above
114 ClassDef(AliHLTTPCCalibPulserComponent, 0)