ROOT logo
AliAnalysisTaskPi0FlowMC* AddTaskPHOSPi0pPbMC (Bool_t kWeightsApplied = kFALSE,
                                               const char* name = "PHOSPi0pPbMC",
                                               const char* options = "",
                                               UInt_t offlineTriggerMask = AliVEvent::kINT7,
                                               const char* centrality = "V0M",
                                               const Int_t nCentBins = 5,
                                               const Int_t centEdge0 = 0,
                                               const Int_t centEdge1 = 20,
                                               const Int_t centEdge2 = 40,
                                               const Int_t centEdge3 = 60,
                                               const Int_t centEdge4 = 80,
                                               const Int_t centEdge5 = 100)
{
    //Add a task AliAnalysisTaskPi0FlowMC to the analysis train, for LHC13 PbP MC productions
    //Author:  Paul Baetzing
    /* $Id$ */
    
    AliAnalysisManager *mgr = AliAnalysisManager::GetAnalysisManager();
    if (!mgr) {
        ::Error("AddTaskPHOSPi0pPbMC", "No analysis manager to connect to");
        return NULL;
    }
    
    if (!mgr->GetInputEventHandler()) {
        ::Error("AddTaskPHOSPi0pPbMC", "This task requires an input event handler");
        return NULL;
    }
    
    AliAnalysisTaskPi0FlowMC* task;
    
    if(kWeightsApplied) task  = new AliAnalysisTaskPi0FlowMCParamWeights(Form("%sTask", name));
    else task  = new AliAnalysisTaskPi0FlowMC(Form("%sTask", name));
    
    
    if (nCentBins<1) {
        ::Error("AddTaskPHOSPi0pPb", Form("Invalid number of centrality bins: %d",nCentBins));
        return NULL;
    }
    Double_t *cbin = new Double_t[nCentBins+1];
    cbin[0] = centEdge0;
    cbin[1] = centEdge1;
    if (nCentBins > 1) cbin[2] = centEdge2;
    if (nCentBins > 2) cbin[3] = centEdge3;
    if (nCentBins > 3) cbin[4] = centEdge4;
    if (nCentBins > 4) cbin[5] = centEdge5;
    TArrayD tbin(nCentBins+1, cbin);
    
    Int_t    *nMixed = new Int_t[nCentBins];
    for (Int_t ibin=0; ibin<nCentBins; ibin++) nMixed[ibin] = 20;
    TArrayI tNMixed(nCentBins, nMixed);
    task->SetCentralityBinning(tbin, tNMixed);
    
    
    task->SetCentralityEstimator(centrality);
    
    
    //task->SetEventMixingRPBinning(9);
    //task->SetMixingArraysLength(10);
    task->SelectCollisionCandidates(offlineTriggerMask);
    
    task->SetEnablePHOSModule(2, kFALSE);
    
    mgr->AddTask(task);
    mgr->ConnectInput(task, 0, mgr->GetCommonInputContainer() );
    
    TString cname(Form("%sCoutput1", name));
    TString pname(Form("%s:%s", AliAnalysisManager::GetCommonFileName(), name));
    AliAnalysisDataContainer *coutput1 = mgr->CreateContainer(cname.Data(), TList::Class(), AliAnalysisManager::kOutputContainer, pname.Data());
    mgr->ConnectOutput(task, 1, coutput1);
    
    return task;
}
 AddTaskPHOSPi0pPbMC.C:1
 AddTaskPHOSPi0pPbMC.C:2
 AddTaskPHOSPi0pPbMC.C:3
 AddTaskPHOSPi0pPbMC.C:4
 AddTaskPHOSPi0pPbMC.C:5
 AddTaskPHOSPi0pPbMC.C:6
 AddTaskPHOSPi0pPbMC.C:7
 AddTaskPHOSPi0pPbMC.C:8
 AddTaskPHOSPi0pPbMC.C:9
 AddTaskPHOSPi0pPbMC.C:10
 AddTaskPHOSPi0pPbMC.C:11
 AddTaskPHOSPi0pPbMC.C:12
 AddTaskPHOSPi0pPbMC.C:13
 AddTaskPHOSPi0pPbMC.C:14
 AddTaskPHOSPi0pPbMC.C:15
 AddTaskPHOSPi0pPbMC.C:16
 AddTaskPHOSPi0pPbMC.C:17
 AddTaskPHOSPi0pPbMC.C:18
 AddTaskPHOSPi0pPbMC.C:19
 AddTaskPHOSPi0pPbMC.C:20
 AddTaskPHOSPi0pPbMC.C:21
 AddTaskPHOSPi0pPbMC.C:22
 AddTaskPHOSPi0pPbMC.C:23
 AddTaskPHOSPi0pPbMC.C:24
 AddTaskPHOSPi0pPbMC.C:25
 AddTaskPHOSPi0pPbMC.C:26
 AddTaskPHOSPi0pPbMC.C:27
 AddTaskPHOSPi0pPbMC.C:28
 AddTaskPHOSPi0pPbMC.C:29
 AddTaskPHOSPi0pPbMC.C:30
 AddTaskPHOSPi0pPbMC.C:31
 AddTaskPHOSPi0pPbMC.C:32
 AddTaskPHOSPi0pPbMC.C:33
 AddTaskPHOSPi0pPbMC.C:34
 AddTaskPHOSPi0pPbMC.C:35
 AddTaskPHOSPi0pPbMC.C:36
 AddTaskPHOSPi0pPbMC.C:37
 AddTaskPHOSPi0pPbMC.C:38
 AddTaskPHOSPi0pPbMC.C:39
 AddTaskPHOSPi0pPbMC.C:40
 AddTaskPHOSPi0pPbMC.C:41
 AddTaskPHOSPi0pPbMC.C:42
 AddTaskPHOSPi0pPbMC.C:43
 AddTaskPHOSPi0pPbMC.C:44
 AddTaskPHOSPi0pPbMC.C:45
 AddTaskPHOSPi0pPbMC.C:46
 AddTaskPHOSPi0pPbMC.C:47
 AddTaskPHOSPi0pPbMC.C:48
 AddTaskPHOSPi0pPbMC.C:49
 AddTaskPHOSPi0pPbMC.C:50
 AddTaskPHOSPi0pPbMC.C:51
 AddTaskPHOSPi0pPbMC.C:52
 AddTaskPHOSPi0pPbMC.C:53
 AddTaskPHOSPi0pPbMC.C:54
 AddTaskPHOSPi0pPbMC.C:55
 AddTaskPHOSPi0pPbMC.C:56
 AddTaskPHOSPi0pPbMC.C:57
 AddTaskPHOSPi0pPbMC.C:58
 AddTaskPHOSPi0pPbMC.C:59
 AddTaskPHOSPi0pPbMC.C:60
 AddTaskPHOSPi0pPbMC.C:61
 AddTaskPHOSPi0pPbMC.C:62
 AddTaskPHOSPi0pPbMC.C:63
 AddTaskPHOSPi0pPbMC.C:64
 AddTaskPHOSPi0pPbMC.C:65
 AddTaskPHOSPi0pPbMC.C:66
 AddTaskPHOSPi0pPbMC.C:67
 AddTaskPHOSPi0pPbMC.C:68
 AddTaskPHOSPi0pPbMC.C:69
 AddTaskPHOSPi0pPbMC.C:70
 AddTaskPHOSPi0pPbMC.C:71
 AddTaskPHOSPi0pPbMC.C:72
 AddTaskPHOSPi0pPbMC.C:73