]> git.uio.no Git - u/mrichter/AliRoot.git/blame - ANALYSIS/TenderSupplies/AddTaskTender.C
Fix PWG3->PWGHF
[u/mrichter/AliRoot.git] / ANALYSIS / TenderSupplies / AddTaskTender.C
CommitLineData
2d28db9f 1AliAnalysisTask *AddTaskTender(Bool_t useV0=kFALSE){
e75408ba 2 //get the current analysis manager
2d28db9f 3 Bool_t checkEvtSelection = useV0;
e75408ba 4 AliAnalysisManager *mgr = AliAnalysisManager::GetAnalysisManager();
5 if (!mgr) {
6 Error("AddTask_tender_Tender", "No analysis manager found.");
7 return 0;
8 }
9 // currently don't accept AOD input
b34c9f51 10 if (!mgr->GetInputEventHandler()->InheritsFrom(AliESDInputHandler::Class())) {
e75408ba 11 Error("AddTask_tender_Tender","The analysis tender only works with ESD input!");
12 return 0;
13 }
14
15
16 //========= Add tender to the ANALYSIS manager and set default storage =====
17 AliTender *tender=new AliTender("AnalysisTender");
aaf2d706 18 tender->SetCheckEventSelection(checkEvtSelection);
351c53ea 19 tender->SetDefaultCDBStorage("raw://");
aaf2d706 20 if (checkEvtSelection) {
5dea385b 21 if (mgr->GetTasks()->First() != (TObject*)tender ) {
22 TString firstName(mgr->GetTasks()->First()->GetName());
23 Bool_t isSecond=(mgr->GetTasks()->At(1) == (TObject*)tender);
24 if (! (firstName=="PIDResponseTask" && isSecond )){
25 ::Error("When setting the tender to check the event selection, it has to be the first wagon, or the first after the Physics selection ! Aborting.");
aaf2d706 26 return NULL;
5dea385b 27 }
28 }
29 }
30 mgr->AddTask(tender);
e75408ba 31
9259172d 32 //========= Attach VZERO supply ======
6d163207 33
2d28db9f 34 if (useV0) {
35 AliVZEROTenderSupply *vzeroSupply=new AliVZEROTenderSupply("VZEROtender");
36 vzeroSupply->SetDebug(kFALSE);
37 tender->AddSupply(vzeroSupply);
38 }
5ff9ab50 39
6d163207 40
e75408ba 41 //========= Attach TPC supply ======
42 AliTPCTenderSupply *tpcSupply=new AliTPCTenderSupply("TPCtender");
f19a0c5e 43 tpcSupply->SetDebugLevel(2);
ee981ab3 44 //tpcSupply->SetMip(50.);
e75408ba 45 tender->AddSupply(tpcSupply);
e75408ba 46 //========= Attach TOF supply ======
ee981ab3 47 AliTOFTenderSupply *tofTender = new AliTOFTenderSupply("TOFtender");
ee981ab3 48 tender->AddSupply(tofTender);
5ff9ab50 49
e75408ba 50 //========= Attach TRD supply ======
51 AliTRDTenderSupply *trdSupply=new AliTRDTenderSupply("TRDtender");
51a0ce25 52 trdSupply->SetLoadReferencesFromCDB();
53 // Mask Bad chambers
54 trdSupply->AddBadChamber(265); // low drift
55 trdSupply->AddBadChamber(50);
56 trdSupply->AddBadChamber(524); // low drift
57 trdSupply->AddBadChamber(32); // intermediate gain
58 trdSupply->AddBadChamber(15);
59 trdSupply->AddBadChamber(231); // low gain
60 trdSupply->AddBadChamber(273); // intermediate gain
61 trdSupply->AddBadChamber(532);
62 trdSupply->AddBadChamber(5); // low drift
63 trdSupply->AddBadChamber(227);
64 trdSupply->AddBadChamber(287); // low drift
65 trdSupply->AddBadChamber(212); // intermediate gain
66 trdSupply->AddBadChamber(228); // low gain
67 trdSupply->AddBadChamber(52); // low gain
68 trdSupply->AddBadChamber(169); // low drift
69 trdSupply->AddBadChamber(236); // low drift
70
71 trdSupply->SetPIDmethod(AliTRDTenderSupply::k1DLQpid);
72 trdSupply->SetNormalizationFactor(1./7.603);
e75408ba 73 tender->AddSupply(trdSupply);
74
75 //========= Attach PID supply ======
76 tender->AddSupply(new AliPIDTenderSupply("PIDtender"));
77
78 //========= Attach Primary Vertex supply ======
79 tender->AddSupply(new AliVtxTenderSupply("PriVtxtender"));
6d163207 80
e75408ba 81 //================================================
82 // data containers
83 //================================================
84
85 // define output containers, please use 'username'_'somename'
86 AliAnalysisDataContainer *coutput1 =
87 mgr->CreateContainer("tender_event", AliESDEvent::Class(),
88 AliAnalysisManager::kExchangeContainer,"default_tender");
89
90 // connect containers
91 mgr->ConnectInput (tender, 0, mgr->GetCommonInputContainer() );
aa269eb9 92 mgr->ConnectOutput (tender, 1, coutput1);
e75408ba 93
94 return tender;
95}