Minor changes needed for debugging purphoses
[u/mrichter/AliRoot.git] / HLT / PHOS / AliHLTPHOSRawAnalyzerComponent.h
1 #ifndef ALIHLTPHOSRAWANALYZERCOMPONENT_H
2 #define ALIHLTPHOSRAWANALYZERCOMPONENT_H
3
4 /* Copyright(c) 2006, ALICE Experiment at CERN, All rights reserved. *
5  * See cxx source for full Copyright notice                          */
6 #include "AliHLTPHOSRcuProcessor.h"
7
8 class AliHLTPHOSRawAnalyzer;
9 class AliHLTPHOSRcuCellEnergyDataStruct;
10 class AliHLTPHOSRcuChannelDataStruct;
11 class AliHLTPHOSMapper;
12 class AliHLTDDLDecoder;
13 class AliHLTAltroData;
14 class AliHLTAltroBunch;
15 class AliHLTPHOSSanityInspector;
16
17 class AliHLTPHOSRawAnalyzerComponent: public AliHLTPHOSRcuProcessor
18 {
19  public:
20   AliHLTPHOSRawAnalyzerComponent();
21   virtual ~AliHLTPHOSRawAnalyzerComponent();
22   virtual int DoInit(int argc =0, const char** argv  = 0);
23   virtual int Deinit();
24   virtual const char* GetComponentID() = 0;
25   virtual void GetInputDataTypes( vector <AliHLTComponentDataType>& list);
26   virtual AliHLTComponentDataType GetOutputDataType();
27   virtual void GetOutputDataSize(unsigned long& constBase, double& inputMultiplier);
28   virtual AliHLTComponent* Spawn() = 0; 
29  protected:
30   AliHLTPHOSRawAnalyzer *fAnalyzerPtr;  /**<Pointer to an analyzer object used for raw data anlysis*/ 
31
32  private:
33   virtual int DoEvent( const AliHLTComponentEventData& evtData, const AliHLTComponentBlockData* blocks, 
34                      AliHLTComponentTriggerData& trigData, AliHLTUInt8_t* outputPtr, 
35                      AliHLTUInt32_t& size, vector<AliHLTComponentBlockData>& outputBlocks ); 
36   void Reset();
37   void ResetDataPtr(int startindex = 0, int sampleCnt = 0);
38   void SetBaselines(const char* baselineFile);
39   Bool_t fSendChannelData;       /**<wether or not to send raw data from the component into shared memory*/
40   Double_t fTmpChannelData[ALTRO_MAX_SAMPLES];                        /**<temporary variable to store raw samples from a single altro channel*/
41   Double_t fMaxValues[N_MODULES][N_ZROWS_MOD][N_XCOLUMNS_MOD][N_GAINS]; /**<array to store cell energies*/
42   // AliHLTPHOSRcuCellEnergyDataStruct* fOutPtr;         /**<Pointer to outputbuffer to write results from the component into shared memory*/
43
44   AliHLTPHOSRcuCellEnergyDataStruct* fOutPtr;
45   AliHLTPHOSMapper *fMapperPtr;
46   AliHLTDDLDecoder *fDecoderPtr;
47   AliHLTAltroData  *fAltroDataPtr;
48   AliHLTAltroBunch *fAltroBunchPtr;
49   AliHLTPHOSSanityInspector *fSanityInspectorPtr;
50   Bool_t fUseBaselineSubtraction;
51   Float_t fBaselines[N_XCOLUMNS_RCU][N_ZROWS_RCU][N_GAINS];
52   int fDebugCnt;
53   
54 };
55 #endif
56