AliAnalysisTaskKinkResonance *AddTaskKinkResonanceKstarESD(Short_t lCollidingSystems=0 /*0 = pp, 1 = AA*/)
{
// Creates, configures and attaches to the train a kink resonance task.
// Get the pointer to the existing analysis manager via the static access method.
//==============================================================================
AliAnalysisManager *mgr = AliAnalysisManager::GetAnalysisManager();
if (!mgr) {
::Error("AddTaskKinkResonanceKstarESD", "No analysis manager to connect to.");
return NULL;
}
// Check the analysis type using the event handlers connected to the analysis manager.
//==============================================================================
if (!mgr->GetInputEventHandler()) {
::Error("AddTaskKinkResonanceKstarESD", "This task requires an input event handler");
return NULL;
}
TString type = mgr->GetInputEventHandler()->GetDataType(); // can be "ESD" or "AOD"
if (type != "ESD") {
::Error("AddTaskKinkResonanceKstarESD", "This task needs an ESD input handler");
return NULL;
}
if (!mgr->GetMCtruthEventHandler()) {
::Error("AddTaskKinkResonanceKstarESD", "This task needs an MC handler");
return NULL;
}
// Setup the analysis object
AliResonanceKink *kinkResonanceObjectKESD=new AliResonanceKink();
kinkResonanceObjectKESD->InitOutputHistograms(60, 0.6, 1.2, 36, -0.9, 0.9, 100, 0.0, 10.0);
kinkResonanceObjectKESD->SetPDGCodes(kKPlus, kPiPlus, AliResonanceKink::kKstar0);
kinkResonanceObjectKESD->SetAnalysisType("ESD"); // "ESD" or "MC" or "DATA"
kinkResonanceObjectKESD->SetMaxNsigmaToVertex(4.0);
kinkResonanceObjectKESD->SetMaxDCAxy(3.0);
kinkResonanceObjectKESD->SetMaxDCAzaxis(3.0);
kinkResonanceObjectKESD->SetPtTrackCut(0.25);
kinkResonanceObjectKESD->SetMinTPCclusters(50);
kinkResonanceObjectKESD->SetMaxChi2PerTPCcluster(3.5);
kinkResonanceObjectKESD->SetMaxCov0(2.0);
kinkResonanceObjectKESD->SetMaxCov2(2.0);
kinkResonanceObjectKESD->SetMaxCov5(0.5);
kinkResonanceObjectKESD->SetMaxCov9(0.5);
kinkResonanceObjectKESD->SetMaxCov14(2.0);
kinkResonanceObjectKESD->SetMinKinkRadius(120.);
kinkResonanceObjectKESD->SetMaxKinkRadius(220.);
kinkResonanceObjectKESD->SetQtLimits(0.05, 0.5);
kinkResonanceObjectKESD->SetUpperAbsEtaCut(0.9);
// Create and configure the task
AliAnalysisTaskKinkResonance *taskresonanceKstarESD = new AliAnalysisTaskKinkResonance("TaskResKstarESDKinkPID");
taskresonanceKstarESD->SetAnalysisKinkObject(kinkResonanceObjectKESD);
mgr->AddTask(taskresonanceKstarESD);
// Create ONLY the output containers for the data produced by the task.
// Get and connect other common input/output containers via the manager as below
//==============================================================================
TString outputFileName = AliAnalysisManager::GetCommonFileName();
outputFileName += ":PWG2KINKResonanceKstarESD";
if (lCollidingSystems) outputFileName += "_AA";
else outputFileName += "_PP";
if (mgr->GetMCtruthEventHandler()) outputFileName += "_MC";
AliAnalysisDataContainer *coutput1 = mgr->CreateContainer("KinkResKstarESD",
TList::Class(),
AliAnalysisManager::kOutputContainer,
outputFileName );
mgr->ConnectInput(taskresonanceKstarESD, 0, mgr->GetCommonInputContainer());
mgr->ConnectOutput(taskresonanceKstarESD, 1, coutput1);
return taskresonanceKstarESD;
}
AddTaskKinkResonanceKstarESD.C:1 AddTaskKinkResonanceKstarESD.C:2 AddTaskKinkResonanceKstarESD.C:3 AddTaskKinkResonanceKstarESD.C:4 AddTaskKinkResonanceKstarESD.C:5 AddTaskKinkResonanceKstarESD.C:6 AddTaskKinkResonanceKstarESD.C:7 AddTaskKinkResonanceKstarESD.C:8 AddTaskKinkResonanceKstarESD.C:9 AddTaskKinkResonanceKstarESD.C:10 AddTaskKinkResonanceKstarESD.C:11 AddTaskKinkResonanceKstarESD.C:12 AddTaskKinkResonanceKstarESD.C:13 AddTaskKinkResonanceKstarESD.C:14 AddTaskKinkResonanceKstarESD.C:15 AddTaskKinkResonanceKstarESD.C:16 AddTaskKinkResonanceKstarESD.C:17 AddTaskKinkResonanceKstarESD.C:18 AddTaskKinkResonanceKstarESD.C:19 AddTaskKinkResonanceKstarESD.C:20 AddTaskKinkResonanceKstarESD.C:21 AddTaskKinkResonanceKstarESD.C:22 AddTaskKinkResonanceKstarESD.C:23 AddTaskKinkResonanceKstarESD.C:24 AddTaskKinkResonanceKstarESD.C:25 AddTaskKinkResonanceKstarESD.C:26 AddTaskKinkResonanceKstarESD.C:27 AddTaskKinkResonanceKstarESD.C:28 AddTaskKinkResonanceKstarESD.C:29 AddTaskKinkResonanceKstarESD.C:30 AddTaskKinkResonanceKstarESD.C:31 AddTaskKinkResonanceKstarESD.C:32 AddTaskKinkResonanceKstarESD.C:33 AddTaskKinkResonanceKstarESD.C:34 AddTaskKinkResonanceKstarESD.C:35 AddTaskKinkResonanceKstarESD.C:36 AddTaskKinkResonanceKstarESD.C:37 AddTaskKinkResonanceKstarESD.C:38 AddTaskKinkResonanceKstarESD.C:39 AddTaskKinkResonanceKstarESD.C:40 AddTaskKinkResonanceKstarESD.C:41 AddTaskKinkResonanceKstarESD.C:42 AddTaskKinkResonanceKstarESD.C:43 AddTaskKinkResonanceKstarESD.C:44 AddTaskKinkResonanceKstarESD.C:45 AddTaskKinkResonanceKstarESD.C:46 AddTaskKinkResonanceKstarESD.C:47 AddTaskKinkResonanceKstarESD.C:48 AddTaskKinkResonanceKstarESD.C:49 AddTaskKinkResonanceKstarESD.C:50 AddTaskKinkResonanceKstarESD.C:51 AddTaskKinkResonanceKstarESD.C:52 AddTaskKinkResonanceKstarESD.C:53 AddTaskKinkResonanceKstarESD.C:54 AddTaskKinkResonanceKstarESD.C:55 AddTaskKinkResonanceKstarESD.C:56 AddTaskKinkResonanceKstarESD.C:57 AddTaskKinkResonanceKstarESD.C:58 AddTaskKinkResonanceKstarESD.C:59 AddTaskKinkResonanceKstarESD.C:60 AddTaskKinkResonanceKstarESD.C:61 AddTaskKinkResonanceKstarESD.C:62 AddTaskKinkResonanceKstarESD.C:63 AddTaskKinkResonanceKstarESD.C:64 AddTaskKinkResonanceKstarESD.C:65 AddTaskKinkResonanceKstarESD.C:66 AddTaskKinkResonanceKstarESD.C:67 AddTaskKinkResonanceKstarESD.C:68 AddTaskKinkResonanceKstarESD.C:69 AddTaskKinkResonanceKstarESD.C:70 AddTaskKinkResonanceKstarESD.C:71 AddTaskKinkResonanceKstarESD.C:72 AddTaskKinkResonanceKstarESD.C:73