1 AliAnalysisTask *AddTask_cbaumann_LMEEpp2010(Bool_t runTwo=kFALSE, Bool_t hasMC=kFALSE, Bool_t enableCF=kFALSE){
2 //get the current analysis manager
3 AliAnalysisManager *mgr = AliAnalysisManager::GetAnalysisManager();
5 Error("AddTask_cbaumann_LMEEpp2010", "No analysis manager found.");
10 //create config File names: TRAIN_ROOT is for running on GSI train,
11 // ALICE_ROOT for CERN Lego trains
12 TString configBasePath("$TRAIN_ROOT/cbaumann_dielectron/");
13 TString trainRoot=gSystem->Getenv("TRAIN_ROOT");
14 if (trainRoot.IsNull()) configBasePath= "$ALICE_ROOT/PWGDQ/dielectron/macrosLMEE/";
15 TString configFile("ConfigLMEEpp2010.C");
16 TString configLMEECutLib("LMEECutLib.C");
18 TString configLMEECutLibPath(configBasePath+configLMEECutLib);
19 TString configFilePath(configBasePath+configFile);
23 //AOD Usage not yet testes/avialable-------------------------------------
25 if (mgr->GetInputEventHandler()->IsA()==AliAODInputHandler::Class()){
26 ::Info("AddTaskLMEEpp2010", "no dedicated AOD configuration");
27 // configFile="$TRAIN_ROOT/util/dielectron/dielectron/macros/ConfigLMEEpp2010AOD.C";
31 //Do we have an MC handler? //Child protected, if auto-recognition fails
32 if (AliAnalysisManager::GetAnalysisManager()->GetMCtruthEventHandler()!=0x0)
36 // create task and add it to the manager
38 if (!gROOT->GetListOfGlobalFunctions()->FindObject(configLMEECutLib.Data()))
39 gROOT->LoadMacro(configLMEECutLibPath.Data());
40 if (!gROOT->GetListOfGlobalFunctions()->FindObject(configFile.Data()))
41 gROOT->LoadMacro(configFilePath.Data());
43 LMEECutLib* cutlib = new LMEECutLib();
44 cutlib->SetMCFlag(hasMC);
45 AliAnalysisTaskMultiDielectron *task=new AliAnalysisTaskMultiDielectron("MultiDiEData");
46 if (!hasMC) task->UsePhysicsSelection();
47 task->SetEventFilter(cutlib->GetEventCuts(LMEECutLib::kpp2010TPCandTOF)); //
50 //load dielectron configuration file
52 //add dielectron analysis with different cuts to the task
54 AliDielectron *lowmass1=ConfigLMEEpp2010(1,hasMC,enableCF);
55 task->AddDielectron(lowmass1);
56 printf("add: %s\n",lowmass1->GetName());
59 AliDielectron *lowmass2=ConfigLMEEpp2010(2,hasMC,enableCF);
60 task->AddDielectron(lowmass2);
61 printf("add: %s\n",lowmass2->GetName());
66 //create output container
67 AliAnalysisDataContainer *coutput1 =
68 mgr->CreateContainer("cbaumann_LMEEpp2010_tree",
70 AliAnalysisManager::kExchangeContainer,
71 "cbaumann_LMEEpp2010_default.root");
73 AliAnalysisDataContainer *cOutputHist1 =
74 mgr->CreateContainer("cbaumann_LMEEpp2010_out",
76 AliAnalysisManager::kOutputContainer,
77 "cbaumann_LMEEpp2010_out.root");
78 AliAnalysisDataContainer *cOutputHist2 = 0x0;
81 mgr->CreateContainer("cbaumann_LMEEpp2010_CF",
83 AliAnalysisManager::kOutputContainer,
84 "cbaumann_LMEEpp2010_out.root");
86 AliAnalysisDataContainer *cOutputHist3 =
87 mgr->CreateContainer("cbaumann_EventStatPbPb2011",
89 AliAnalysisManager::kOutputContainer,
90 "cbaumann_LMEEpp2010_out.root");
93 mgr->ConnectInput(task, 0, mgr->GetCommonInputContainer());
94 mgr->ConnectOutput(task, 0, coutput1 );
95 mgr->ConnectOutput(task, 1, cOutputHist1);
97 mgr->ConnectOutput(task, 2, cOutputHist2);
99 mgr->ConnectOutput(task, 3, cOutputHist3);