X-Git-Url: http://git.uio.no/git/?a=blobdiff_plain;f=ITS%2FAliITSQAChecker.cxx;h=daec1eab7d455fe5e48f3c37f77d1a339873e429;hb=008e8516f01781385da44d0a4b18fac02313db5e;hp=362b12c76480bdc62c1b1750371b774e32e2abb1;hpb=e7e8567189df4b28dba70c169425d9a6bec22529;p=u%2Fmrichter%2FAliRoot.git diff --git a/ITS/AliITSQAChecker.cxx b/ITS/AliITSQAChecker.cxx index 362b12c7648..daec1eab7d4 100644 --- a/ITS/AliITSQAChecker.cxx +++ b/ITS/AliITSQAChecker.cxx @@ -24,12 +24,14 @@ // --- ROOT system --- #include "TH1.h" #include +#include "TStyle.h" // --- AliRoot header files --- #include "AliITSQAChecker.h" #include "AliITSQASPDChecker.h" #include "AliITSQASDDChecker.h" #include "AliITSQASSDChecker.h" +#include "AliITSQADataMakerRec.h" ClassImp(AliITSQAChecker) @@ -42,75 +44,300 @@ fLDC(0), fSPDOffset(0), fSDDOffset(0), fSSDOffset(0), +fSPDHisto(0), +fSDDHisto(0), +fSSDHisto(0), fSPDChecker(0), // SPD Checker fSDDChecker(0), // SDD Checker fSSDChecker(0) // SSD Checker + { + // Standard constructor fkOnline = kMode; fDet = subDet; fLDC = ldc; if(fDet == 0 || fDet == 1) { - AliDebug(1,"AliITSQAChecker::Create SPD Checker\n"); + AliDebug(AliQAv1::GetQADebugLevel(),"AliITSQAChecker::Create SPD Checker\n"); + fSPDChecker = new AliITSQASPDChecker(); } if(fDet == 0 || fDet == 2) { - AliDebug(1,"AliITSQAChecker::Create SDD Checker\n"); + AliDebug(AliQAv1::GetQADebugLevel(),"AliITSQAChecker::Create SDD Checker\n"); + fSDDChecker = new AliITSQASDDChecker(); } if(fDet == 0 || fDet == 3) { - AliDebug(1,"AliITSQAChecker::Create SSD Checker\n"); + AliDebug(AliQAv1::GetQADebugLevel(),"AliITSQAChecker::Create SSD Checker\n"); + fSSDChecker = new AliITSQASSDChecker(); } - + InitQACheckerLimits(); } -//__________________________________________________________________ -AliITSQAChecker& AliITSQAChecker::operator = (const AliITSQAChecker& qac ) +//____________________________________________________________________________ +AliITSQAChecker::AliITSQAChecker(const AliITSQAChecker& qac): +AliQACheckerBase(qac.GetName(), qac.GetTitle()), +fkOnline(qac.fkOnline), +fDet(qac.fDet), +fLDC(qac.fLDC), +fSPDOffset(qac.fSPDOffset), +fSDDOffset(qac.fSDDOffset), +fSSDOffset(qac.fSSDOffset), +fSPDHisto(qac.fSPDHisto), +fSDDHisto(qac.fSDDHisto), +fSSDHisto(qac.fSSDHisto), +fSPDChecker(qac.fSPDChecker), +fSDDChecker(qac.fSDDChecker), +fSSDChecker(qac.fSSDChecker) { - // Equal operator. + // copy constructor + AliError("Copy should not be used with this class\n"); +} +//____________________________________________________________________________ +AliITSQAChecker& AliITSQAChecker::operator=(const AliITSQAChecker& qac){ + // assignment operator this->~AliITSQAChecker(); - new(this) AliITSQAChecker(qac); + new(this)AliITSQAChecker(qac); return *this; } + //____________________________________________________________________________ -const Double_t AliITSQAChecker::Check(AliQA::ALITASK_t index, TObjArray * list) +AliITSQAChecker::~AliITSQAChecker(){ + // destructor + if(fSPDChecker)delete fSPDChecker; + if(fSDDChecker)delete fSDDChecker; + if(fSSDChecker)delete fSSDChecker; + +} +//____________________________________________________________________________ +void AliITSQAChecker::Check(Double_t * rv, AliQAv1::ALITASK_t index, TObjArray ** list, const AliDetectorRecoParam * recoParam) { - - // Super-basic check on the QA histograms on the input list: - // look whether they are empty! - Double_t spdCheck, sddCheck, ssdCheck; - Double_t retval = 1.; - if(fDet == 0 || fDet == 1) { - AliDebug(1,"AliITSQAChecker::Create SPD Checker\n"); - if(!fSPDChecker) { - fSPDChecker = new AliITSQASPDChecker(); + + + // basic checks on the QA histograms on the input list + //for the ITS subdetectorQA (Raws Digits Hits RecPoints SDigits) return the worst value of the three result + if(index == AliQAv1::kESD){ + + for (Int_t specie = 0 ; specie < AliRecoParam::kNSpecies ; specie++) { + rv[specie] = 0.0 ; + if ( !AliQAv1::Instance()->IsEventSpecieSet(specie) ) + continue ; + AliDebug(AliQAv1::GetQADebugLevel(),"Checker for ESD"); + Int_t tested = 0; + Int_t empty = 0; + // The following flags are set to kTRUE if the corresponding + // QA histograms exceed a given quality threshold + Bool_t cluMapSA = kFALSE; + Bool_t cluMapMI = kFALSE; + Bool_t cluMI = kFALSE; + Bool_t cluSA = kFALSE; + Bool_t verSPDZ = kFALSE; + if (list[specie]->GetEntries() == 0) { + rv[specie] = 0.; // nothing to check + } + else { + Double_t stepbit[AliQAv1::kNBIT]; + Double_t histonumb= list[specie]->GetEntries(); + CreateStepForBit(histonumb,stepbit); + TIter next1(list[specie]); + TH1 * hdata; + Int_t nskipped=0; + Bool_t skipped[6]={kFALSE,kFALSE,kFALSE,kFALSE,kFALSE,kFALSE}; + // look for layers that we wanted to skip + while ( (hdata = dynamic_cast(next1())) ) { + if(hdata){ + TString hname = hdata->GetName(); + if(!hname.Contains("hESDSkippedLayers")) continue; + for(Int_t k=1; k<7; k++) { + if(hdata->GetBinContent(k)>0) { + nskipped++; + skipped[k-1]=kTRUE; + } + } + } + } + TIter next(list[specie]); + while ( (hdata = dynamic_cast(next())) ) { + if(hdata){ + TString hname = hdata->GetName(); + Double_t entries = hdata->GetEntries(); + ++tested; + if(!(entries>0.))++empty; + AliDebug(AliQAv1::GetQADebugLevel(),Form("ESD hist name %s - entries %12.1g",hname.Data(),entries)); + if(hname.Contains("hESDClusterMapSA") && entries>0.){ + cluMapSA = kTRUE; + AliDebug(AliQAv1::GetQADebugLevel(),Form("Processing histogram %s",hname.Data())); + // Check if there are layers with anomalously low + // contributing points to SA reconstructed tracks + for(Int_t k=1;k<7;k++){ + // check if the layer was skipped + if(skipped[k-1]) continue; + if(hdata->GetBinContent(k)<0.5*(entries/6.)){ + cluMapSA = kFALSE; + AliDebug(AliQAv1::GetQADebugLevel(),Form("SA tracks have few points on layer %d - look at histogram hESDClustersSA",k)); + } + } + }//end clustermapsa + + else if(hname.Contains("hESDClusterMapMI") && entries>0.){ + // Check if there are layers with anomalously low + // contributing points to MI reconstructed tracks + AliDebug(AliQAv1::GetQADebugLevel(),Form("Processing histogram %s",hname.Data())); + cluMapMI = kTRUE; + for(Int_t k=1;k<7;k++){ + // check if the layer was skipped + if(skipped[k-1]) continue; + if(hdata->GetBinContent(k)<0.5*(entries/6.)){ + cluMapMI = kFALSE; + AliDebug(AliQAv1::GetQADebugLevel(),Form("MI tracks have few points on layer %d - look at histogram hESDClustersMI",k)); + } + } + }//end clustermapmi + + else if(hname.Contains("hESDClustersMI") && entries>0.){ + // Check if 6 clusters MI tracks are the majority + AliDebug(AliQAv1::GetQADebugLevel(),Form("Processing histogram %s",hname.Data())); + cluMI = kTRUE; + Double_t maxlaytracks = hdata->GetBinContent(7-nskipped); + for(Int_t k=2; k<7-nskipped; k++){ + if(hdata->GetBinContent(k)>maxlaytracks){ + cluMI = kFALSE; + AliDebug(AliQAv1::GetQADebugLevel(),Form("MI Tracks with %d clusters are more than tracks with %d clusters. Look at histogram hESDClustersMI",k-1,6-nskipped)); + } + } + }//end clustersmi + + else if(hname.Contains("hESDClustersSA") && entries>0.){ + // Check if 6 clusters SA tracks are the majority + AliDebug(AliQAv1::GetQADebugLevel(),Form("Processing histogram %s",hname.Data())); + cluSA = kTRUE; + Double_t maxlaytracks = hdata->GetBinContent(7-nskipped); + for(Int_t k=2; k<7-nskipped; k++){ + if(hdata->GetBinContent(k)>maxlaytracks){ + cluSA = kFALSE; + AliDebug(AliQAv1::GetQADebugLevel(), Form("SA Tracks with %d clusters are more than tracks with %d clusters. Look at histogram hESDClustersSA",k-1,6-nskipped)); + } + } + }//end clusterssa + + else if(hname.Contains("hSPDVertexZ") && entries>0.){ + // Check if average Z vertex coordinate is -5 < z < 5 cm + AliDebug(AliQAv1::GetQADebugLevel(),Form("Processing histogram %s",hname.Data())); + verSPDZ = kTRUE; + if(hdata->GetMean()<-5. && hdata->GetMean()>5.){ + verSPDZ = kFALSE; + AliDebug(AliQAv1::GetQADebugLevel(),Form("Average z vertex coordinate is at z= %10.4g cm",hdata->GetMean())); + } + }//end spdvertexz + + else{ AliError("ESD Checker - invalid data type");}//end else + + rv[specie] = 0.; + if(tested>0){ + if(tested == empty){ + rv[specie] = 2500.; // set to error + AliWarning(Form("All ESD histograms are empty - specie=%d",specie)); + } + else { + rv[specie] = 2500.-1500.*(static_cast(tested-empty)/static_cast(tested)); // INFO if all histos are filled + if(cluMapSA)rv[specie]-=200.; + if(cluMapMI)rv[specie]-=200.; + if(cluMI)rv[specie]-=200.; + if(cluSA)rv[specie]-=200.; + if(verSPDZ)rv[specie]-=199.; // down to 1 if everything is OK + } + }//end tested + }//end hdata + }//end while + // AliDebug(AliQAv1::GetQADebugLevel(), Form("ESD - Tested %d histograms, Return value %f \n",tested,rv[specie])); + AliInfo(Form("ESD - Tested %d histograms, Return value %f \n",tested,rv[specie])); + } } - fSPDChecker->SetTaskOffset(fSPDOffset); - spdCheck = fSPDChecker->Check(index, list); - if(spdCheckIsEventSpecieSet(specie)) continue; + if ( AliQAv1::Instance()->IsEventSpecieSet(specie) ) { + Double_t histotot=list[specie]->GetEntries(); + if(histotot!=0) + { + spdCheck[specie]=0.; + sddCheck[specie]=0.; + ssdCheck[specie]=0.; + rv[specie] = 0.0 ;// + //pixel + if(fDet == 0 || fDet == 1) { + fSPDChecker->SetTaskOffset(fSPDOffset); + //printf("spdoffset = %i \n",fSPDOffset ); + Double_t histoSPD=double(GetSPDHisto()); + if(AliITSQADataMakerRec::AreEqual(histoSPD,0)==kFALSE){ + Double_t *stepSPD=new Double_t[AliQAv1::kNBIT]; + CreateStepForBit(histoSPD,stepSPD); + fSPDChecker->SetStepBit(stepSPD); + spdCheck[specie] = fSPDChecker->Check(index, list[specie], recoParam); + if(spdCheck[specie]>fUpTestValue[AliQAv1::kFATAL]||spdCheck[specie]<0.) + { + AliInfo(Form("SPD check result for %s is out of range (%f)!!! Retval of specie %s is sit to -1\n ",AliQAv1::GetAliTaskName(index),spdCheck[specie],AliRecoParam::GetEventSpecieName(specie))); + spdCheck[specie]=fUpTestValue[AliQAv1::kFATAL]; + } + delete []stepSPD; + }//end check SPD entries + else{spdCheck[specie]=fUpTestValue[AliQAv1::kFATAL];} + rv[specie]=spdCheck[specie]; + }//end SPD check + //drift + if(fDet == 0 || fDet == 2) { + fSDDChecker->SetTaskOffset(fSDDOffset); + Double_t histoSDD=double(GetSDDHisto()); + if(AliITSQADataMakerRec::AreEqual(histoSDD,0)==kFALSE){ + Double_t *stepSDD=new Double_t[AliQAv1::kNBIT]; + CreateStepForBit(histoSDD,stepSDD); + fSDDChecker->SetStepBit(stepSDD); + sddCheck[specie] = fSDDChecker->Check(index, list[specie], recoParam); + if(sddCheck[specie]>fUpTestValue[AliQAv1::kFATAL]||sddCheck[specie]<0.) + { + AliInfo(Form("SDD check result for %s is out of range (%f)!!! Retval of specie %s is sit to -1\n ",AliQAv1::GetAliTaskName(index),sddCheck[specie],AliRecoParam::GetEventSpecieName(specie))); + sddCheck[specie]=fUpTestValue[AliQAv1::kFATAL]; + } + delete []stepSDD; + }//end check SDD entries + else{ssdCheck[specie]=fUpTestValue[AliQAv1::kFATAL];} + if(sddCheck[specie]>rv[specie])rv[specie]=sddCheck[specie]; + }//end SDD + //strip + if(fDet == 0 || fDet == 3) { + fSSDChecker->SetTaskOffset(fSSDOffset); + Double_t histoSSD=double(GetSSDHisto()); + if(AliITSQADataMakerRec::AreEqual(histoSSD,0)==kFALSE){ + Double_t *stepSSD=new Double_t[AliQAv1::kNBIT]; + CreateStepForBit(histoSSD,stepSSD); + fSSDChecker->SetStepBit(stepSSD); + ssdCheck[specie] = fSSDChecker->Check(index, list[specie], recoParam); + if(ssdCheck[specie]>fUpTestValue[AliQAv1::kFATAL]||ssdCheck[specie]<0.) + { + AliInfo(Form("SSD check result for %s is out of range (%f)!!! Retval of specie %s is sit to -1\n ",AliQAv1::GetAliTaskName(index),ssdCheck[specie],AliRecoParam::GetEventSpecieName(specie))); + ssdCheck[specie]=fUpTestValue[AliQAv1::kFATAL]; + } + delete [] stepSSD; + }//end check SSD entries + else{ssdCheck[specie]=fUpTestValue[AliQAv1::kFATAL];} + if(ssdCheck[specie]>rv[specie])rv[specie]=ssdCheck[specie]; + }//end SSD + + AliInfo(Form("Check result for %s: \n\t SPD %f \n\t SDD %f \n\t SSD %f \n Check result %f \n ",AliQAv1::GetAliTaskName(index),spdCheck[specie],sddCheck[specie],ssdCheck[specie],rv[specie])); + // here merging part for common ITS QA result + // + }//end entries + }//end if event specie + }//end for } - if(fDet == 0 || fDet == 2) { - AliDebug(1,"AliITSQAChecker::Create SDD Checker\n"); - if(!fSDDChecker) { - fSDDChecker = new AliITSQASDDChecker(); - } - fSDDChecker->SetTaskOffset(fSDDOffset); - sddCheck = fSDDChecker->Check(index, list); - if(sddCheckGetEntries())); - } - fSSDChecker->SetTaskOffset(fSSDOffset); - ssdCheck = fSSDChecker->Check(index, list); - if(ssdCheck %f < value < %f \n WARNING -> %f < value <= %f \n ERROR -> %f < value <= %f \n FATAL -> %f <= value < %f \n", fLowTestValue[AliQAv1::kINFO], fUpTestValue[AliQAv1::kINFO], fLowTestValue[AliQAv1::kWARNING], fUpTestValue[AliQAv1::kWARNING], fLowTestValue[AliQAv1::kERROR], fUpTestValue[AliQAv1::kERROR], fLowTestValue[AliQAv1::kFATAL], fUpTestValue[AliQAv1::kFATAL] )); + + if(fDet == 0 || fDet == 1) { + fSPDChecker->SetSPDLimits( lowtolerancevalue,hightolerancevalue ); + } + if(fDet == 0 || fDet == 2) { + fSDDChecker->SetSDDLimits( lowtolerancevalue,hightolerancevalue ); + } + if(fDet == 0 || fDet == 3) { + fSSDChecker->SetSSDLimits( lowtolerancevalue,hightolerancevalue ); + } + + + +} + + +//_____________________________________________________________________________ + +void AliITSQAChecker::CreateStepForBit(Double_t histonumb,Double_t *steprange) +{ + for(Int_t bit=0;bit < AliQAv1::kNBIT; bit++) + { + //printf("%i\t %f \t %f \t %f \n",bit, fUpTestValue[bit],fLowTestValue[AliQAv1::kINFO],histonumb); + steprange[bit]=double((fUpTestValue[bit] - fLowTestValue[AliQAv1::kINFO])/histonumb); + //printf("%i\t %f \t %f \t %f \t %f\n",bit, fUpTestValue[bit],fLowTestValue[AliQAv1::kINFO],histonumb,steprange[bit] ); + } + //AliInfo(Form("StepBitValue:numner of histo %f\n\t INFO %f \t WARNING %f \t ERROR %f \t FATAL %f \n",histonumb, steprange[AliQAv1::kINFO],steprange[AliQAv1::kWARNING],steprange[AliQAv1::kERROR],steprange[AliQAv1::kFATAL])); +} + + +//_____________________________________________________________________________ +void AliITSQAChecker::SetQA(AliQAv1::ALITASK_t index, Double_t * value) const +{ + + AliQAv1 * qa = AliQAv1::Instance(index) ; + + + for (Int_t specie = 0 ; specie < AliRecoParam::kNSpecies ; specie++) { + + if (! qa->IsEventSpecieSet(AliRecoParam::ConvertIndex(specie))) + continue ; + if ( value == NULL ) { // No checker is implemented, set all QA to Fatal + qa->Set(AliQAv1::kFATAL, specie) ; + } else { + if ( value[specie] > fLowTestValue[AliQAv1::kFATAL] && value[specie] <= fUpTestValue[AliQAv1::kFATAL] ) + qa->Set(AliQAv1::kFATAL, AliRecoParam::ConvertIndex(specie)) ; + else if ( value[specie] > fLowTestValue[AliQAv1::kERROR] && value[specie] <= fUpTestValue[AliQAv1::kERROR] ) + qa->Set(AliQAv1::kERROR, AliRecoParam::ConvertIndex(specie)) ; + else if ( value[specie] > fLowTestValue[AliQAv1::kWARNING] && value[specie] <= fUpTestValue[AliQAv1::kWARNING] ) + qa->Set(AliQAv1::kWARNING, AliRecoParam::ConvertIndex(specie)) ; + else if ( value[specie] > fLowTestValue[AliQAv1::kINFO] && value[specie] <= fUpTestValue[AliQAv1::kINFO] ) + qa->Set(AliQAv1::kINFO, AliRecoParam::ConvertIndex(specie)) ; + //else if(value[specie]==0) qa->Set(AliQAv1::kFATAL, AliRecoParam::ConvertIndex(specie)) ; //no ckeck has been done + } + qa->ShowStatus(AliQAv1::kITS,index,AliRecoParam::ConvertIndex(specie)); + }//end for + +} + + +//__________________________________________________________________ +void AliITSQAChecker::MakeImage( TObjArray ** list, AliQAv1::TASKINDEX_t task, AliQAv1::MODE_t mode) +{ + + //gStyle->SetPalette(1); + + //Int_t nImages = 0 ; + //Int_t imageindex=0; + for (Int_t esIndex = 0 ; esIndex < AliRecoParam::kNSpecies ; esIndex++) { + if (! AliQAv1::Instance(AliQAv1::GetDetIndex(GetName()))->IsEventSpecieSet(AliRecoParam::ConvertIndex(esIndex)) ) + continue ; + //else imageindex=esIndex; + + TIter next(list[esIndex]) ; + TH1 * hdata = NULL ; + while ( (hdata=static_cast(next())) ) { + TString cln(hdata->ClassName()) ; + if ( ! cln.Contains("TH") ) + continue ; + if(cln.Contains("TH2")) hdata->SetOption("colz"); + } + break ; + } + + Bool_t retvalue=kFALSE; + + if(GetSubDet()==0) MakeITSImage(list,task, mode); + else if(GetSubDet()==1) + { + retvalue=fSPDChecker->MakeSPDImage(list,task, mode) ; + if(retvalue==kFALSE)AliQACheckerBase::MakeImage(list,task, mode); + } + else if(GetSubDet()==2){ retvalue=fSDDChecker->MakeSDDImage(list,task, mode) ;if(retvalue==kFALSE)AliQACheckerBase::MakeImage(list,task,mode); } + else if(GetSubDet()==3) + { + retvalue=fSSDChecker->MakeSSDImage(list,task, mode) ; + if(retvalue==kFALSE)AliQACheckerBase::MakeImage(list,task, mode); + } + +} +