//
#include "AliQAv1.h"
+//#include "TPad.h"
// --- ROOT system ---
class TFile;
class TH2F;
// --- AliRoot header files ---
class AliQACheckerBase;
+class AliQAChecker;
class AliITSQAChecker;
class AliITSCalibrationSDD;
class AliITSLoader;
class AliLog;
class TF1;
class TCanvas;
+class TPaveText;
+class AliQAv1;
-class AliITSQASDDChecker: public TObject {
+class AliITSQASDDChecker: public TObject{
public:
- AliITSQASDDChecker():
- fSubDetOffset(0),
- fStepBitSDD(NULL),
- fLowSDDValue(NULL),
- fHighSDDValue(NULL),
- fCalibration(NULL),
- fRawL3Pattern(NULL),
- fRawL4Pattern(NULL),
- fRecL3Pattern(NULL),
- fRecL4Pattern(NULL),
- fThresholdForRelativeOccupancy(0.01),
- fRawModulePattern(NULL),
- fRecModulePattern(NULL),
- fModulePatternRatio(NULL),
- fThresholdForRecToRawRatio(0.04)
- {;} // ctor
- AliITSQASDDChecker& operator = (const AliITSQASDDChecker& qac) ; //operator =
+
+ AliITSQASDDChecker(); // ctor
virtual ~AliITSQASDDChecker(); // dtor
virtual Double_t Check(AliQAv1::ALITASK_t index, const TObjArray * list, const AliDetectorRecoParam * recoParam);
virtual void SetTaskOffset(Int_t taskoffset);
virtual void SetStepBit(const Double_t *steprange);
virtual Double_t *GetStepBit(){return fStepBitSDD;};
virtual void SetSDDLimits(const Float_t *lowvalue, const Float_t * highvalue);
-private:
- AliITSQASDDChecker(const AliITSQASDDChecker& qac):TObject(),
- fSubDetOffset(qac.fSubDetOffset),
- fStepBitSDD(qac.fStepBitSDD),
- fLowSDDValue(qac.fLowSDDValue),
- fHighSDDValue(qac.fHighSDDValue),
- fCalibration(qac.fCalibration),
- fRawL3Pattern(qac.fRawL3Pattern),
- fRawL4Pattern(qac.fRawL4Pattern),
- fRecL3Pattern(qac.fRecL3Pattern),
- fRecL4Pattern(qac.fRecL4Pattern),
- fThresholdForRelativeOccupancy(qac.fThresholdForRelativeOccupancy),
- fRawModulePattern(qac.fRawModulePattern),
- fRecModulePattern(qac.fRecModulePattern),
- fModulePatternRatio(qac.fModulePatternRatio),
- fThresholdForRecToRawRatio(qac.fThresholdForRecToRawRatio)
- {;} // cpy ctor
- Int_t fSubDetOffset; // checking operation starting point
- Double_t *fStepBitSDD; //step size for each QAbit(kINFO, kWARNING,kERROR,kFATAL)
- Float_t *fLowSDDValue; //low value of each QA bit range
- Float_t *fHighSDDValue; //High value of each QA bit range
- TObjArray *fCalibration; //TObjArray with Calibration SDD Objects
-
- TH2F *fRawL3Pattern; // distribution of Raw Module Counts for L3
- TH2F *fRawL4Pattern; // distribution of Raw Module Counts for L4
- TH2F *fRecL3Pattern; // distribution of Rec Module Counts for L3
- TH2F *fRecL4Pattern; // distribution of Rec Module Counts for L4
- Float_t fThresholdForRelativeOccupancy; // ThresholdForRelativeOccupancy (by module)
- TH1F *fRawModulePattern; // distribution of Raw Module Counts
- TH1F *fRecModulePattern; // distribution of Rec Module Counts
- TH1F *fModulePatternRatio; // distribution of Rec/Raw Module Counts
- Float_t fThresholdForRecToRawRatio; // ThresholdForRecToRawRatio (by module)
-
- static const Int_t fgknSDDmodules = 260; // number of SDD modules
- static const Int_t fgkmodoffset = 240; // number of SPD modules
- ClassDef(AliITSQASDDChecker,3) // description
+ void SetEventSpecieForCheck(Int_t esforcheck=0){ fESforCheck=esforcheck;}
+ Int_t GetEventSpecieForCheck() const {return fESforCheck;}
+
+ virtual Bool_t MakeSDDImage( TObjArray ** list, AliQAv1::TASKINDEX_t task, AliQAv1::MODE_t mode) ;
+ Bool_t MakeSDDRawsImage(TObjArray ** list, AliQAv1::TASKINDEX_t task, AliQAv1::MODE_t mode );//{AliInfo("The method for raw image has been called\n");}
+ Bool_t MakeSDDRecPointsImage(TObjArray ** list, AliQAv1::TASKINDEX_t task, AliQAv1::MODE_t mode);//{AliInfo("The method for recpoint image has been called\n");}
+
+
+ private:
+
+ AliITSQASDDChecker(const AliITSQASDDChecker& qac);
+ AliITSQASDDChecker& operator = (const AliITSQASDDChecker& qac) ;
+ Int_t fSubDetOffset; // checking operation starting point
+ Double_t *fStepBitSDD; //step size for each QAbit(kINFO, kWARNING,kERROR,kFATAL)
+ Float_t *fLowSDDValue; //low value of each QA bit range
+ Float_t *fHighSDDValue; //High value of each QA bit range
+ TObjArray *fCalibration; //TObjArray with Calibration SDD Objects
+
+
+ Float_t fThresholdForRelativeOccupancy; // ThresholdForRelativeOccupancy (by module)
+ Float_t fThresholdForRecToRawRatio; // ThresholdForRecToRawRatio (by module)
+
+ TCanvas ** fImage ; //[AliRecoParam::kNSpecies]
+ TPaveText * fPaveText[AliRecoParam::kNSpecies] ; //[AliRecoParam::kNSpecies]
+
+ Int_t fESforCheck; //eventspecie of the list to check
+
+ static const Int_t fgknSDDmodules = 260; // number of SDD modules
+ static const Int_t fgkmodoffset = 240; // number of SPD modules
+ ClassDef(AliITSQASDDChecker,8) // description
+
};
#endif // AliITSQASDDChecker_H