]>
Commit | Line | Data |
---|---|---|
2d28db9f | 1 | AliAnalysisTask *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 | } |