]> git.uio.no Git - u/mrichter/AliRoot.git/blob - PWG0/esdTrackCuts/run.C
Transition PWG0 -> PWGUD
[u/mrichter/AliRoot.git] / PWG0 / esdTrackCuts / run.C
1 void run(Char_t* data, Int_t nRuns=20, Int_t offset=0, Bool_t aDebug = kFALSE, Bool_t aProof = kFALSE, Bool_t mc = kFALSE, const char* option = "")
2 {
3   if (aProof)
4   {
5     TProof::Open("lxb6046");
6
7     // Enable the needed package
8     gProof->UploadPackage("STEERBase");
9     gProof->EnablePackage("STEERBase");
10     gProof->UploadPackage("ESD");
11     gProof->EnablePackage("ESD");
12     gProof->UploadPackage("AOD");
13     gProof->EnablePackage("AOD");
14     gProof->UploadPackage("ANALYSIS");
15     gProof->EnablePackage("ANALYSIS");
16     gProof->UploadPackage("PWG0base");
17     gProof->EnablePackage("PWG0base");
18   }
19   else
20   {
21     gSystem->Load("libVMC");
22     gSystem->Load("libTree");
23     gSystem->Load("libSTEERBase");
24     gSystem->Load("libESD");
25     gSystem->Load("libAOD");
26     gSystem->Load("libANALYSIS");
27     gSystem->Load("libPWG0base");
28   }
29
30   // Create chain of input files
31   gROOT->LoadMacro("../CreateESDChain.C");
32   chain = CreateESDChain(data, nRuns, offset);
33
34   // Create the analysis manager
35   mgr = new AliAnalysisManager("testAnalysis");
36
37   TString taskName("AliCutTask.cxx+");
38   if (aDebug)
39     taskName += "+g";
40
41   // Create, add task
42   if (aProof) {
43     gProof->Load(taskName);
44   } else
45     gROOT->Macro(taskName);
46
47   task = new AliCutTask;
48
49   AliPWG0Helper::AnalysisMode analysisMode = AliPWG0Helper::kTPC;
50   task->SetAnalysisMode(analysisMode);
51
52   if (analysisMode != AliPWG0Helper::kSPD)
53   {
54     // selection of esd tracks
55     gROOT->ProcessLine(".L ../CreateStandardCuts.C");
56     AliESDtrackCuts* esdTrackCuts = CreateTrackCuts(analysisMode);
57     if (!esdTrackCuts)
58     {
59       printf("ERROR: esdTrackCuts could not be created\n");
60       return;
61     }
62
63     task->SetTrackCuts(esdTrackCuts);
64   }
65
66   mgr->AddTask(task);
67
68   // Add ESD handler
69   AliESDInputHandler* esdH = new AliESDInputHandler;
70   mgr->SetInputEventHandler(esdH);
71   
72   if (mc) {
73     task->EnableSecondaryStudy();
74     // Enable MC event handler
75     AliMCEventHandler* handler = new AliMCEventHandler;
76     handler->SetReadTR(kFALSE);
77     mgr->SetMCtruthEventHandler(handler);
78   }
79
80   // Attach input
81   cInput  = mgr->GetCommonInputContainer();
82   mgr->ConnectInput(task, 0, cInput);
83
84   // Attach output
85   cOutput = mgr->CreateContainer("cOutput", TList::Class(), AliAnalysisManager::kOutputContainer);
86   mgr->ConnectOutput(task, 0, cOutput);
87
88   // Enable debug printouts
89   if (aDebug)
90     mgr->SetDebugLevel(2);
91
92   // Run analysis
93   mgr->InitAnalysis();
94   mgr->PrintStatus();
95   mgr->StartAnalysis((aProof) ? "proof" : "local", chain);
96 }