ROOT logo
void AddTask_GammaConvCalo_PbPb(   	Int_t trainConfig = 1,  //change different set of cuts
									Bool_t isMC   = kFALSE, //run MC 
									Int_t enableQAMesonTask = 0, //enable QA in AliAnalysisTaskGammaConvV1
									Int_t enableQAPhotonTask = 0, // enable additional QA task
									TString fileNameInputForWeighting = "MCSpectraInput.root", // path to file for weigting input
									Int_t headerSelectionInt = 0,  // 1 pi0 header, 2 eta header, 3 both (only for "named" boxes)
									TString cutnumberAODBranch = "1000000060084000001500000",
									TString periodName = "LHC13d2",  //name of the period for added signals and weighting
                                    Bool_t doWeighting = kFALSE,  //enable Weighting
                                    Bool_t enableExtendedMatching = kFALSE //enable or disable extended matching histograms for conversion electrons <-> cluster
								) {

	// ================= Load Librariers =================================
	gSystem->Load("libCore.so");  
	gSystem->Load("libTree.so");
	gSystem->Load("libGeom.so");
	gSystem->Load("libVMC.so");
	gSystem->Load("libPhysics.so");
	gSystem->Load("libMinuit");
	gSystem->Load("libSTEERBase");
	gSystem->Load("libESD");
	gSystem->Load("libAOD");
	gSystem->Load("libANALYSIS");
	gSystem->Load("libANALYSISalice");  
	gSystem->Load("libCDB.so");
	gSystem->Load("libSTEER.so");
	gSystem->Load("libSTEERBase.so");
	gSystem->Load("libTENDER.so");
	gSystem->Load("libTENDERSupplies.so");
	gSystem->Load("libPWGflowBase.so");
	gSystem->Load("libPWGflowTasks.so");
	gSystem->Load("libPWGGAGammaConv.so");

	Int_t isHeavyIon = 1;
	
	// ================== GetAnalysisManager ===============================
	AliAnalysisManager *mgr = AliAnalysisManager::GetAnalysisManager();
	if (!mgr) {
		Error(Form("AddTask_GammaConvV1_%i",trainConfig), "No analysis manager found.");
		return ;
	}

	// ================== GetInputEventHandler =============================
	AliVEventHandler *inputHandler=mgr->GetInputEventHandler();
	
	//========= Add PID Reponse to ANALYSIS manager ====
	if(!(AliPIDResponse*)mgr->GetTask("PIDResponseTask")){
		gROOT->LoadMacro("$ALICE_ROOT/ANALYSIS/macros/AddTaskPIDResponse.C");
		AddTaskPIDResponse(isMC);
	}
	
	//=========  Set Cutnumber for V0Reader ================================
	TString cutnumberPhoton = "000000084001001500000000";
	TString cutnumberEvent = "1000000";
	AliAnalysisDataContainer *cinput = mgr->GetCommonInputContainer();

	//========= Add V0 Reader to  ANALYSIS manager if not yet existent =====
	if( !(AliV0ReaderV1*)mgr->GetTask("V0ReaderV1") ){
		AliV0ReaderV1 *fV0ReaderV1 = new AliV0ReaderV1("V0ReaderV1");
		
		fV0ReaderV1->SetUseOwnXYZCalculation(kTRUE);
		fV0ReaderV1->SetCreateAODs(kFALSE);// AOD Output
		fV0ReaderV1->SetUseAODConversionPhoton(kTRUE);

		if (!mgr) {
			Error("AddTask_V0ReaderV1", "No analysis manager found.");
			return;
		}

		AliConvEventCuts *fEventCuts=NULL;
		if(cutnumberEvent!=""){
			fEventCuts= new AliConvEventCuts(cutnumberEvent.Data(),cutnumberEvent.Data());
			fEventCuts->SetPreSelectionCutFlag(kTRUE);
			if(fEventCuts->InitializeCutsFromCutString(cutnumberEvent.Data())){
				fV0ReaderV1->SetEventCuts(fEventCuts);
				fEventCuts->SetFillCutHistograms("",kTRUE);
			}
		}

		
		// Set AnalysisCut Number
		AliConversionPhotonCuts *fCuts=NULL;
		if(cutnumberPhoton!=""){
			fCuts= new AliConversionPhotonCuts(cutnumberPhoton.Data(),cutnumberPhoton.Data());
			fCuts->SetPreSelectionCutFlag(kTRUE);
			fCuts->SetIsHeavyIon(isHeavyIon);
			if(fCuts->InitializeCutsFromCutString(cutnumberPhoton.Data())){
				fV0ReaderV1->SetConversionCuts(fCuts);
				fCuts->SetFillCutHistograms("",kTRUE);
			}
		}

		if(inputHandler->IsA()==AliAODInputHandler::Class()){
		// AOD mode
			fV0ReaderV1->SetDeltaAODBranchName(Form("GammaConv_%s_gamma",cutnumberAODBranch.Data()));
		}
		fV0ReaderV1->Init();

		AliLog::SetGlobalLogLevel(AliLog::kFatal);

		//connect input V0Reader
		mgr->AddTask(fV0ReaderV1);
		mgr->ConnectInput(fV0ReaderV1,0,cinput);

	}

	//================================================
	//========= Add task to the ANALYSIS manager =====
	//================================================
	AliAnalysisTaskGammaConvCalo *task=NULL;
	task= new AliAnalysisTaskGammaConvCalo(Form("GammaConvCalo_%i",trainConfig));
	task->SetIsHeavyIon(isHeavyIon);
	task->SetIsMC(isMC);
	// Cut Numbers to use in Analysis
	Int_t numberOfCuts = 5;

	TString *eventCutArray = new TString[numberOfCuts];
	TString *photonCutArray = new TString[numberOfCuts];
	TString *clusterCutArray = new TString[numberOfCuts];
	TString *mesonCutArray = new TString[numberOfCuts];
  
	if (trainConfig == 1){ // EMCAL clusters
		eventCutArray[ 0] = "6010001"; photonCutArray[ 0] = "002000092970028250400000"; clusterCutArray[0] = "10000040032030000"; mesonCutArray[ 0] = "01631031000000"; // 0-5%
		eventCutArray[ 1] = "6120001"; photonCutArray[ 1] = "002000092970028250400000"; clusterCutArray[1] = "10000040032030000"; mesonCutArray[ 1] = "01631031000000"; // 5-10%
		eventCutArray[ 2] = "5010001"; photonCutArray[ 2] = "002000092970028250400000"; clusterCutArray[2] = "10000040032030000"; mesonCutArray[ 2] = "01631031000000"; // 0-10%
		eventCutArray[ 3] = "5240001"; photonCutArray[ 3] = "002000092970028250400000"; clusterCutArray[3] = "10000040032030000"; mesonCutArray[ 3] = "01631031000000"; // 20-40%
		eventCutArray[ 4] = "5250001"; photonCutArray[ 4] = "002000092970028250400000"; clusterCutArray[4] = "10000040032030000"; mesonCutArray[ 4] = "01631031000000"; // 20-50%
	} else if (trainConfig == 2){ // EMCAL clusters
		eventCutArray[ 0] = "6010001"; photonCutArray[ 0] = "002000092970028250400000"; clusterCutArray[0] = "10000040032030000"; mesonCutArray[ 0] = "01631031000000"; // 0-5%
		eventCutArray[ 1] = "6120001"; photonCutArray[ 1] = "002000092970028250400000"; clusterCutArray[1] = "10000040032030000"; mesonCutArray[ 1] = "01631031000000"; // 5-10%
		eventCutArray[ 2] = "5010001"; photonCutArray[ 2] = "002000092970028250400000"; clusterCutArray[2] = "10000040032030000"; mesonCutArray[ 2] = "01631031000000"; // 0-10%
		eventCutArray[ 3] = "5120001"; photonCutArray[ 3] = "002000092970028250400000"; clusterCutArray[3] = "10000040032030000"; mesonCutArray[ 3] = "01631031000000"; // 10-20%
		eventCutArray[ 4] = "5240001"; photonCutArray[ 4] = "002000092970028250400000"; clusterCutArray[4] = "10000040032030000"; mesonCutArray[ 4] = "01631031000000"; // 20-40%		
	} else if (trainConfig == 3){ // EMCAL clusters
		eventCutArray[ 0] = "5460001"; photonCutArray[ 0] = "002000092970028250400000"; clusterCutArray[0] = "10000040032030000"; mesonCutArray[ 0] = "01631031000000"; // 40-60%
		eventCutArray[ 1] = "5680001"; photonCutArray[ 1] = "002000092970028250400000"; clusterCutArray[1] = "10000040032030000"; mesonCutArray[ 1] = "01631031000000"; // 60-80%
		eventCutArray[ 2] = "5260001"; photonCutArray[ 2] = "002000092970028250400000"; clusterCutArray[2] = "10000040032030000"; mesonCutArray[ 2] = "01631031000000"; // 20-60%
		eventCutArray[ 3] = "5480001"; photonCutArray[ 3] = "002000092970028250400000"; clusterCutArray[3] = "10000040032030000"; mesonCutArray[ 3] = "01631031000000"; // 40-80%
		eventCutArray[ 4] = "5250001"; photonCutArray[ 4] = "002000092970028250400000"; clusterCutArray[4] = "10000040032030000"; mesonCutArray[ 4] = "01631031000000"; // 20-50%				
	} else if (trainConfig == 4){ // EMCAL clusters
		eventCutArray[ 0] = "6010001"; photonCutArray[ 0] = "002000092970028250400000"; clusterCutArray[0] = "10000043032030000"; mesonCutArray[ 0] = "01631031000000"; // 0-5%
		eventCutArray[ 1] = "6120001"; photonCutArray[ 1] = "002000092970028250400000"; clusterCutArray[1] = "10000043032030000"; mesonCutArray[ 1] = "01631031000000"; // 5-10%
		eventCutArray[ 2] = "5010001"; photonCutArray[ 2] = "002000092970028250400000"; clusterCutArray[2] = "10000043032030000"; mesonCutArray[ 2] = "01631031000000"; // 0-10%
		eventCutArray[ 3] = "5240001"; photonCutArray[ 3] = "002000092970028250400000"; clusterCutArray[3] = "10000043032030000"; mesonCutArray[ 3] = "01631031000000"; // 20-40%
		eventCutArray[ 4] = "5250001"; photonCutArray[ 4] = "002000092970028250400000"; clusterCutArray[4] = "10000043032030000"; mesonCutArray[ 4] = "01631031000000"; // 20-50%
	} else if (trainConfig == 5){ // EMCAL clusters
		eventCutArray[ 0] = "6010001"; photonCutArray[ 0] = "002000092970028250400000"; clusterCutArray[0] = "10000043032030000"; mesonCutArray[ 0] = "01631031000000"; // 0-5%
		eventCutArray[ 1] = "6120001"; photonCutArray[ 1] = "002000092970028250400000"; clusterCutArray[1] = "10000043032030000"; mesonCutArray[ 1] = "01631031000000"; // 5-10%
		eventCutArray[ 2] = "5010001"; photonCutArray[ 2] = "002000092970028250400000"; clusterCutArray[2] = "10000043032030000"; mesonCutArray[ 2] = "01631031000000"; // 0-10%
		eventCutArray[ 3] = "5120001"; photonCutArray[ 3] = "002000092970028250400000"; clusterCutArray[3] = "10000043032030000"; mesonCutArray[ 3] = "01631031000000"; // 10-20%
		eventCutArray[ 4] = "5240001"; photonCutArray[ 4] = "002000092970028250400000"; clusterCutArray[4] = "10000043032030000"; mesonCutArray[ 4] = "01631031000000"; // 20-40%		
	} else if (trainConfig == 6){ // EMCAL clusters
		eventCutArray[ 0] = "5460001"; photonCutArray[ 0] = "002000092970028250400000"; clusterCutArray[0] = "10000043032030000"; mesonCutArray[ 0] = "01631031000000"; // 40-60%
		eventCutArray[ 1] = "5680001"; photonCutArray[ 1] = "002000092970028250400000"; clusterCutArray[1] = "10000043032030000"; mesonCutArray[ 1] = "01631031000000"; // 60-80%
		eventCutArray[ 2] = "5260001"; photonCutArray[ 2] = "002000092970028250400000"; clusterCutArray[2] = "10000043032030000"; mesonCutArray[ 2] = "01631031000000"; // 20-60%
		eventCutArray[ 3] = "5480001"; photonCutArray[ 3] = "002000092970028250400000"; clusterCutArray[3] = "10000043032030000"; mesonCutArray[ 3] = "01631031000000"; // 40-80%
		eventCutArray[ 4] = "5250001"; photonCutArray[ 4] = "002000092970028250400000"; clusterCutArray[4] = "10000043032030000"; mesonCutArray[ 4] = "01631031000000"; // 20-50%				
	} else if (trainConfig == 31){ // PHOS clusters
		eventCutArray[ 0] = "6010001"; photonCutArray[ 0] = "002000092970028250400000"; clusterCutArray[0] = "20000042033200000"; mesonCutArray[ 0] = "01631031000000"; // 0-5%
		eventCutArray[ 1] = "6120001"; photonCutArray[ 1] = "002000092970028250400000"; clusterCutArray[1] = "20000042033200000"; mesonCutArray[ 1] = "01631031000000"; // 5-10%
		eventCutArray[ 2] = "5010001"; photonCutArray[ 2] = "002000092970028250400000"; clusterCutArray[2] = "20000042033200000"; mesonCutArray[ 2] = "01631031000000"; // 0-10%
		eventCutArray[ 3] = "5240001"; photonCutArray[ 3] = "002000092970028250400000"; clusterCutArray[3] = "20000042033200000"; mesonCutArray[ 3] = "01631031000000"; // 20-40%
		eventCutArray[ 4] = "5250001"; photonCutArray[ 4] = "002000092970028250400000"; clusterCutArray[4] = "20000042033200000"; mesonCutArray[ 4] = "01631031000000"; // 20-50%
	} else if (trainConfig == 32){ // PHOS clusters
		eventCutArray[ 0] = "6010001"; photonCutArray[ 0] = "002000092970028250400000"; clusterCutArray[0] = "20000042033200000"; mesonCutArray[ 0] = "01631031000000"; // 0-5%
		eventCutArray[ 1] = "6120001"; photonCutArray[ 1] = "002000092970028250400000"; clusterCutArray[1] = "20000042033200000"; mesonCutArray[ 1] = "01631031000000"; // 5-10%
		eventCutArray[ 2] = "5010001"; photonCutArray[ 2] = "002000092970028250400000"; clusterCutArray[2] = "20000042033200000"; mesonCutArray[ 2] = "01631031000000"; // 0-10%
		eventCutArray[ 3] = "5120001"; photonCutArray[ 3] = "002000092970028250400000"; clusterCutArray[3] = "20000042033200000"; mesonCutArray[ 3] = "01631031000000"; // 10-20%
		eventCutArray[ 4] = "5240001"; photonCutArray[ 4] = "002000092970028250400000"; clusterCutArray[4] = "20000042033200000"; mesonCutArray[ 4] = "01631031000000"; // 20-40%		
	} else if (trainConfig == 33){ // PHOS clusters
		eventCutArray[ 0] = "5460001"; photonCutArray[ 0] = "002000092970028250400000"; clusterCutArray[0] = "20000042033200000"; mesonCutArray[ 0] = "01631031000000"; // 40-60%
		eventCutArray[ 1] = "5680001"; photonCutArray[ 1] = "002000092970028250400000"; clusterCutArray[1] = "20000042033200000"; mesonCutArray[ 1] = "01631031000000"; // 60-80%
		eventCutArray[ 2] = "5260001"; photonCutArray[ 2] = "002000092970028250400000"; clusterCutArray[2] = "20000042033200000"; mesonCutArray[ 2] = "01631031000000"; // 20-60%
		eventCutArray[ 3] = "5480001"; photonCutArray[ 3] = "002000092970028250400000"; clusterCutArray[3] = "20000042033200000"; mesonCutArray[ 3] = "01631031000000"; // 40-80%
		eventCutArray[ 4] = "5250001"; photonCutArray[ 4] = "002000092970028250400000"; clusterCutArray[4] = "20000042033200000"; mesonCutArray[ 4] = "01631031000000"; // 20-50%						
	} else if (trainConfig == 34){ // PHOS clusters
		eventCutArray[ 0] = "6010001"; photonCutArray[ 0] = "002000092970028250400000"; clusterCutArray[0] = "20000043033200000"; mesonCutArray[ 0] = "01631031000000"; // 0-5%
		eventCutArray[ 1] = "6120001"; photonCutArray[ 1] = "002000092970028250400000"; clusterCutArray[1] = "20000043033200000"; mesonCutArray[ 1] = "01631031000000"; // 5-10%
		eventCutArray[ 2] = "5010001"; photonCutArray[ 2] = "002000092970028250400000"; clusterCutArray[2] = "20000043033200000"; mesonCutArray[ 2] = "01631031000000"; // 0-10%
		eventCutArray[ 3] = "5240001"; photonCutArray[ 3] = "002000092970028250400000"; clusterCutArray[3] = "20000043033200000"; mesonCutArray[ 3] = "01631031000000"; // 20-40%
		eventCutArray[ 4] = "5250001"; photonCutArray[ 4] = "002000092970028250400000"; clusterCutArray[4] = "20000043033200000"; mesonCutArray[ 4] = "01631031000000"; // 20-50%
	} else if (trainConfig == 35){ // PHOS clusters
		eventCutArray[ 0] = "6010001"; photonCutArray[ 0] = "002000092970028250400000"; clusterCutArray[0] = "20000043033200000"; mesonCutArray[ 0] = "01631031000000"; // 0-5%
		eventCutArray[ 1] = "6120001"; photonCutArray[ 1] = "002000092970028250400000"; clusterCutArray[1] = "20000043033200000"; mesonCutArray[ 1] = "01631031000000"; // 5-10%
		eventCutArray[ 2] = "5010001"; photonCutArray[ 2] = "002000092970028250400000"; clusterCutArray[2] = "20000043033200000"; mesonCutArray[ 2] = "01631031000000"; // 0-10%
		eventCutArray[ 3] = "5120001"; photonCutArray[ 3] = "002000092970028250400000"; clusterCutArray[3] = "20000043033200000"; mesonCutArray[ 3] = "01631031000000"; // 10-20%
		eventCutArray[ 4] = "5240001"; photonCutArray[ 4] = "002000092970028250400000"; clusterCutArray[4] = "20000043033200000"; mesonCutArray[ 4] = "01631031000000"; // 20-40%		
	} else if (trainConfig == 36){ // PHOS clusters
		eventCutArray[ 0] = "5460001"; photonCutArray[ 0] = "002000092970028250400000"; clusterCutArray[0] = "20000043033200000"; mesonCutArray[ 0] = "01631031000000"; // 40-60%
		eventCutArray[ 1] = "5680001"; photonCutArray[ 1] = "002000092970028250400000"; clusterCutArray[1] = "20000043033200000"; mesonCutArray[ 1] = "01631031000000"; // 60-80%
		eventCutArray[ 2] = "5260001"; photonCutArray[ 2] = "002000092970028250400000"; clusterCutArray[2] = "20000043033200000"; mesonCutArray[ 2] = "01631031000000"; // 20-60%
		eventCutArray[ 3] = "5480001"; photonCutArray[ 3] = "002000092970028250400000"; clusterCutArray[3] = "20000043033200000"; mesonCutArray[ 3] = "01631031000000"; // 40-80%
		eventCutArray[ 4] = "5250001"; photonCutArray[ 4] = "002000092970028250400000"; clusterCutArray[4] = "20000043033200000"; mesonCutArray[ 4] = "01631031000000"; // 20-50%								
	} else {
		Error(Form("GammaConvCalo_%i",trainConfig), "wrong trainConfig variable no cuts have been specified for the configuration");
		return;
	}

	TList *EventCutList = new TList();
	TList *ConvCutList = new TList();
	TList *ClusterCutList = new TList();
	TList *MesonCutList = new TList();

	TList *HeaderList = new TList();
	if (periodName.CompareTo("LHC13d2")==0){
		TObjString *Header1 = new TObjString("pi0_1");
		HeaderList->Add(Header1);
	//    TObjString *Header3 = new TObjString("eta_2");
	//    HeaderList->Add(Header3);

	} else if (periodName.CompareTo("LHC12a17x_fix")==0){
		TObjString *Header1 = new TObjString("PARAM");
		HeaderList->Add(Header1);
	} else if (periodName.CompareTo("LHC14a1a")==0){
		if (headerSelectionInt == 1){ 
			TObjString *Header1 = new TObjString("pi0_1");
			HeaderList->Add(Header1);
		} else if (headerSelectionInt == 2){
			TObjString *Header1 = new TObjString("eta_2");
			HeaderList->Add(Header1);
		} else {
			TObjString *Header1 = new TObjString("pi0_1");
			HeaderList->Add(Header1);
			TObjString *Header2 = new TObjString("eta_2");
			HeaderList->Add(Header2);
		}  
	} else if (periodName.CompareTo("LHC14a1b")==0 || periodName.CompareTo("LHC14a1c")==0){
		TObjString *Header1 = new TObjString("BOX");
		HeaderList->Add(Header1);
	}	

	EventCutList->SetOwner(kTRUE);
	AliConvEventCuts **analysisEventCuts = new AliConvEventCuts*[numberOfCuts];
	ConvCutList->SetOwner(kTRUE);
	AliConversionPhotonCuts **analysisCuts = new AliConversionPhotonCuts*[numberOfCuts];
   	ClusterCutList->SetOwner(kTRUE);
	AliCaloPhotonCuts **analysisClusterCuts = new AliCaloPhotonCuts*[numberOfCuts];
	MesonCutList->SetOwner(kTRUE);
	AliConversionMesonCuts **analysisMesonCuts = new AliConversionMesonCuts*[numberOfCuts];

	for(Int_t i = 0; i<numberOfCuts; i++){
		
		analysisEventCuts[i] = new AliConvEventCuts();
// 		if ( trainConfig == 1){
// 			if (periodName.CompareTo("LHC14a1a") ==0 || periodName.CompareTo("LHC14a1b") ==0 || periodName.CompareTo("LHC14a1c") ==0 ){
// 				if ( i == 0 && doWeighting)  analysisEventCuts[i]->SetUseReweightingWithHistogramFromFile(kTRUE, kTRUE, kFALSE,fileNameInputForWeighting, Form("Pi0_Hijing_%s_PbPb_2760GeV_0005TPC",periodName.Data()), Form("Eta_Hijing_%s_PbPb_2760GeV_0005TPC",periodName.Data()), "","Pi0_Fit_Data_PbPb_2760GeV_0005V0M","Eta_Fit_Data_PbPb_2760GeV_0005V0M");
// 				if ( i == 1 && doWeighting)  analysisEventCuts[i]->SetUseReweightingWithHistogramFromFile(kTRUE, kTRUE, kFALSE,fileNameInputForWeighting, Form("Pi0_Hijing_%s_PbPb_2760GeV_0510TPC",periodName.Data()), Form("Eta_Hijing_%s_PbPb_2760GeV_0510TPC",periodName.Data()), "","Pi0_Fit_Data_PbPb_2760GeV_0510V0M","Eta_Fit_Data_PbPb_2760GeV_0510V0M");
// 				if ( i == 2 && doWeighting)  analysisEventCuts[i]->SetUseReweightingWithHistogramFromFile(kTRUE, kTRUE, kFALSE,fileNameInputForWeighting, Form("Pi0_Hijing_%s_PbPb_2760GeV_0010TPC",periodName.Data()), Form("Eta_Hijing_%s_PbPb_2760GeV_0010TPC",periodName.Data()), "","Pi0_Fit_Data_PbPb_2760GeV_0010V0M","Eta_Fit_Data_PbPb_2760GeV_0010V0M");
// 				if ( i == 3 && doWeighting)  analysisEventCuts[i]->SetUseReweightingWithHistogramFromFile(kTRUE, kTRUE, kFALSE,fileNameInputForWeighting, Form("Pi0_Hijing_%s_PbPb_2760GeV_2040TPC",periodName.Data()), Form("Eta_Hijing_%s_PbPb_2760GeV_2040TPC",periodName.Data()), "","Pi0_Fit_Data_PbPb_2760GeV_2040V0M","Eta_Fit_Data_PbPb_2760GeV_2040V0M");
// 				if ( i == 4 && doWeighting)  analysisEventCuts[i]->SetUseReweightingWithHistogramFromFile(kTRUE, kTRUE, kFALSE,fileNameInputForWeighting, Form("Pi0_Hijing_%s_PbPb_2760GeV_2050TPC",periodName.Data()), Form("Eta_Hijing_%s_PbPb_2760GeV_2050TPC",periodName.Data()), "","Pi0_Fit_Data_PbPb_2760GeV_2050V0M","Eta_Fit_Data_PbPb_2760GeV_2050V0M");
// 			}	
// 		} 
		analysisEventCuts[i]->InitializeCutsFromCutString(eventCutArray[i].Data());
		if (periodName.CompareTo("LHC14a1b") ==0 || periodName.CompareTo("LHC14a1c") ==0 ){
			if (headerSelectionInt == 1) analysisEventCuts[i]->SetAddedSignalPDGCode(111);
			if (headerSelectionInt == 2) analysisEventCuts[i]->SetAddedSignalPDGCode(221);
		}
		EventCutList->Add(analysisEventCuts[i]);
		analysisEventCuts[i]->SetFillCutHistograms("",kFALSE);

		analysisCuts[i] = new AliConversionPhotonCuts();
		analysisCuts[i]->InitializeCutsFromCutString(photonCutArray[i].Data());
		ConvCutList->Add(analysisCuts[i]);
		analysisCuts[i]->SetFillCutHistograms("",kFALSE);
				
		analysisClusterCuts[i] = new AliCaloPhotonCuts();
		analysisClusterCuts[i]->InitializeCutsFromCutString(clusterCutArray[i].Data());
		ClusterCutList->Add(analysisClusterCuts[i]);
        analysisClusterCuts[i]->SetExtendedMatching(enableExtendedMatching);
		analysisClusterCuts[i]->SetFillCutHistograms("");

		analysisMesonCuts[i] = new AliConversionMesonCuts();
		analysisMesonCuts[i]->InitializeCutsFromCutString(mesonCutArray[i].Data());
		MesonCutList->Add(analysisMesonCuts[i]);
		analysisMesonCuts[i]->SetFillCutHistograms("");
		analysisEventCuts[i]->SetAcceptedHeader(HeaderList);
	
	}

	task->SetEventCutList(numberOfCuts,EventCutList);
	task->SetConversionCutList(numberOfCuts,ConvCutList);
	task->SetCaloCutList(numberOfCuts,ClusterCutList);
	task->SetMesonCutList(numberOfCuts,MesonCutList);
	task->SetMoveParticleAccordingToVertex(kTRUE);
	task->SetDoMesonAnalysis(kTRUE);
	task->SetDoMesonQA(enableQAMesonTask); //Attention new switch for Pi0 QA
	task->SetDoPhotonQA(enableQAPhotonTask);  //Attention new switch small for Photon QA
	task->SetDoClusterQA(1);  //Attention new switch small for Cluster QA
	
	//connect containers
	AliAnalysisDataContainer *coutput =
		mgr->CreateContainer(Form("GammaConvCalo_%i",trainConfig), TList::Class(),
							AliAnalysisManager::kOutputContainer,Form("GammaConvCalo_%i.root",trainConfig));

	mgr->AddTask(task);
	mgr->ConnectInput(task,0,cinput);
	mgr->ConnectOutput(task,1,coutput);

	return;

}
 AddTask_GammaConvCalo_PbPb.C:1
 AddTask_GammaConvCalo_PbPb.C:2
 AddTask_GammaConvCalo_PbPb.C:3
 AddTask_GammaConvCalo_PbPb.C:4
 AddTask_GammaConvCalo_PbPb.C:5
 AddTask_GammaConvCalo_PbPb.C:6
 AddTask_GammaConvCalo_PbPb.C:7
 AddTask_GammaConvCalo_PbPb.C:8
 AddTask_GammaConvCalo_PbPb.C:9
 AddTask_GammaConvCalo_PbPb.C:10
 AddTask_GammaConvCalo_PbPb.C:11
 AddTask_GammaConvCalo_PbPb.C:12
 AddTask_GammaConvCalo_PbPb.C:13
 AddTask_GammaConvCalo_PbPb.C:14
 AddTask_GammaConvCalo_PbPb.C:15
 AddTask_GammaConvCalo_PbPb.C:16
 AddTask_GammaConvCalo_PbPb.C:17
 AddTask_GammaConvCalo_PbPb.C:18
 AddTask_GammaConvCalo_PbPb.C:19
 AddTask_GammaConvCalo_PbPb.C:20
 AddTask_GammaConvCalo_PbPb.C:21
 AddTask_GammaConvCalo_PbPb.C:22
 AddTask_GammaConvCalo_PbPb.C:23
 AddTask_GammaConvCalo_PbPb.C:24
 AddTask_GammaConvCalo_PbPb.C:25
 AddTask_GammaConvCalo_PbPb.C:26
 AddTask_GammaConvCalo_PbPb.C:27
 AddTask_GammaConvCalo_PbPb.C:28
 AddTask_GammaConvCalo_PbPb.C:29
 AddTask_GammaConvCalo_PbPb.C:30
 AddTask_GammaConvCalo_PbPb.C:31
 AddTask_GammaConvCalo_PbPb.C:32
 AddTask_GammaConvCalo_PbPb.C:33
 AddTask_GammaConvCalo_PbPb.C:34
 AddTask_GammaConvCalo_PbPb.C:35
 AddTask_GammaConvCalo_PbPb.C:36
 AddTask_GammaConvCalo_PbPb.C:37
 AddTask_GammaConvCalo_PbPb.C:38
 AddTask_GammaConvCalo_PbPb.C:39
 AddTask_GammaConvCalo_PbPb.C:40
 AddTask_GammaConvCalo_PbPb.C:41
 AddTask_GammaConvCalo_PbPb.C:42
 AddTask_GammaConvCalo_PbPb.C:43
 AddTask_GammaConvCalo_PbPb.C:44
 AddTask_GammaConvCalo_PbPb.C:45
 AddTask_GammaConvCalo_PbPb.C:46
 AddTask_GammaConvCalo_PbPb.C:47
 AddTask_GammaConvCalo_PbPb.C:48
 AddTask_GammaConvCalo_PbPb.C:49
 AddTask_GammaConvCalo_PbPb.C:50
 AddTask_GammaConvCalo_PbPb.C:51
 AddTask_GammaConvCalo_PbPb.C:52
 AddTask_GammaConvCalo_PbPb.C:53
 AddTask_GammaConvCalo_PbPb.C:54
 AddTask_GammaConvCalo_PbPb.C:55
 AddTask_GammaConvCalo_PbPb.C:56
 AddTask_GammaConvCalo_PbPb.C:57
 AddTask_GammaConvCalo_PbPb.C:58
 AddTask_GammaConvCalo_PbPb.C:59
 AddTask_GammaConvCalo_PbPb.C:60
 AddTask_GammaConvCalo_PbPb.C:61
 AddTask_GammaConvCalo_PbPb.C:62
 AddTask_GammaConvCalo_PbPb.C:63
 AddTask_GammaConvCalo_PbPb.C:64
 AddTask_GammaConvCalo_PbPb.C:65
 AddTask_GammaConvCalo_PbPb.C:66
 AddTask_GammaConvCalo_PbPb.C:67
 AddTask_GammaConvCalo_PbPb.C:68
 AddTask_GammaConvCalo_PbPb.C:69
 AddTask_GammaConvCalo_PbPb.C:70
 AddTask_GammaConvCalo_PbPb.C:71
 AddTask_GammaConvCalo_PbPb.C:72
 AddTask_GammaConvCalo_PbPb.C:73
 AddTask_GammaConvCalo_PbPb.C:74
 AddTask_GammaConvCalo_PbPb.C:75
 AddTask_GammaConvCalo_PbPb.C:76
 AddTask_GammaConvCalo_PbPb.C:77
 AddTask_GammaConvCalo_PbPb.C:78
 AddTask_GammaConvCalo_PbPb.C:79
 AddTask_GammaConvCalo_PbPb.C:80
 AddTask_GammaConvCalo_PbPb.C:81
 AddTask_GammaConvCalo_PbPb.C:82
 AddTask_GammaConvCalo_PbPb.C:83
 AddTask_GammaConvCalo_PbPb.C:84
 AddTask_GammaConvCalo_PbPb.C:85
 AddTask_GammaConvCalo_PbPb.C:86
 AddTask_GammaConvCalo_PbPb.C:87
 AddTask_GammaConvCalo_PbPb.C:88
 AddTask_GammaConvCalo_PbPb.C:89
 AddTask_GammaConvCalo_PbPb.C:90
 AddTask_GammaConvCalo_PbPb.C:91
 AddTask_GammaConvCalo_PbPb.C:92
 AddTask_GammaConvCalo_PbPb.C:93
 AddTask_GammaConvCalo_PbPb.C:94
 AddTask_GammaConvCalo_PbPb.C:95
 AddTask_GammaConvCalo_PbPb.C:96
 AddTask_GammaConvCalo_PbPb.C:97
 AddTask_GammaConvCalo_PbPb.C:98
 AddTask_GammaConvCalo_PbPb.C:99
 AddTask_GammaConvCalo_PbPb.C:100
 AddTask_GammaConvCalo_PbPb.C:101
 AddTask_GammaConvCalo_PbPb.C:102
 AddTask_GammaConvCalo_PbPb.C:103
 AddTask_GammaConvCalo_PbPb.C:104
 AddTask_GammaConvCalo_PbPb.C:105
 AddTask_GammaConvCalo_PbPb.C:106
 AddTask_GammaConvCalo_PbPb.C:107
 AddTask_GammaConvCalo_PbPb.C:108
 AddTask_GammaConvCalo_PbPb.C:109
 AddTask_GammaConvCalo_PbPb.C:110
 AddTask_GammaConvCalo_PbPb.C:111
 AddTask_GammaConvCalo_PbPb.C:112
 AddTask_GammaConvCalo_PbPb.C:113
 AddTask_GammaConvCalo_PbPb.C:114
 AddTask_GammaConvCalo_PbPb.C:115
 AddTask_GammaConvCalo_PbPb.C:116
 AddTask_GammaConvCalo_PbPb.C:117
 AddTask_GammaConvCalo_PbPb.C:118
 AddTask_GammaConvCalo_PbPb.C:119
 AddTask_GammaConvCalo_PbPb.C:120
 AddTask_GammaConvCalo_PbPb.C:121
 AddTask_GammaConvCalo_PbPb.C:122
 AddTask_GammaConvCalo_PbPb.C:123
 AddTask_GammaConvCalo_PbPb.C:124
 AddTask_GammaConvCalo_PbPb.C:125
 AddTask_GammaConvCalo_PbPb.C:126
 AddTask_GammaConvCalo_PbPb.C:127
 AddTask_GammaConvCalo_PbPb.C:128
 AddTask_GammaConvCalo_PbPb.C:129
 AddTask_GammaConvCalo_PbPb.C:130
 AddTask_GammaConvCalo_PbPb.C:131
 AddTask_GammaConvCalo_PbPb.C:132
 AddTask_GammaConvCalo_PbPb.C:133
 AddTask_GammaConvCalo_PbPb.C:134
 AddTask_GammaConvCalo_PbPb.C:135
 AddTask_GammaConvCalo_PbPb.C:136
 AddTask_GammaConvCalo_PbPb.C:137
 AddTask_GammaConvCalo_PbPb.C:138
 AddTask_GammaConvCalo_PbPb.C:139
 AddTask_GammaConvCalo_PbPb.C:140
 AddTask_GammaConvCalo_PbPb.C:141
 AddTask_GammaConvCalo_PbPb.C:142
 AddTask_GammaConvCalo_PbPb.C:143
 AddTask_GammaConvCalo_PbPb.C:144
 AddTask_GammaConvCalo_PbPb.C:145
 AddTask_GammaConvCalo_PbPb.C:146
 AddTask_GammaConvCalo_PbPb.C:147
 AddTask_GammaConvCalo_PbPb.C:148
 AddTask_GammaConvCalo_PbPb.C:149
 AddTask_GammaConvCalo_PbPb.C:150
 AddTask_GammaConvCalo_PbPb.C:151
 AddTask_GammaConvCalo_PbPb.C:152
 AddTask_GammaConvCalo_PbPb.C:153
 AddTask_GammaConvCalo_PbPb.C:154
 AddTask_GammaConvCalo_PbPb.C:155
 AddTask_GammaConvCalo_PbPb.C:156
 AddTask_GammaConvCalo_PbPb.C:157
 AddTask_GammaConvCalo_PbPb.C:158
 AddTask_GammaConvCalo_PbPb.C:159
 AddTask_GammaConvCalo_PbPb.C:160
 AddTask_GammaConvCalo_PbPb.C:161
 AddTask_GammaConvCalo_PbPb.C:162
 AddTask_GammaConvCalo_PbPb.C:163
 AddTask_GammaConvCalo_PbPb.C:164
 AddTask_GammaConvCalo_PbPb.C:165
 AddTask_GammaConvCalo_PbPb.C:166
 AddTask_GammaConvCalo_PbPb.C:167
 AddTask_GammaConvCalo_PbPb.C:168
 AddTask_GammaConvCalo_PbPb.C:169
 AddTask_GammaConvCalo_PbPb.C:170
 AddTask_GammaConvCalo_PbPb.C:171
 AddTask_GammaConvCalo_PbPb.C:172
 AddTask_GammaConvCalo_PbPb.C:173
 AddTask_GammaConvCalo_PbPb.C:174
 AddTask_GammaConvCalo_PbPb.C:175
 AddTask_GammaConvCalo_PbPb.C:176
 AddTask_GammaConvCalo_PbPb.C:177
 AddTask_GammaConvCalo_PbPb.C:178
 AddTask_GammaConvCalo_PbPb.C:179
 AddTask_GammaConvCalo_PbPb.C:180
 AddTask_GammaConvCalo_PbPb.C:181
 AddTask_GammaConvCalo_PbPb.C:182
 AddTask_GammaConvCalo_PbPb.C:183
 AddTask_GammaConvCalo_PbPb.C:184
 AddTask_GammaConvCalo_PbPb.C:185
 AddTask_GammaConvCalo_PbPb.C:186
 AddTask_GammaConvCalo_PbPb.C:187
 AddTask_GammaConvCalo_PbPb.C:188
 AddTask_GammaConvCalo_PbPb.C:189
 AddTask_GammaConvCalo_PbPb.C:190
 AddTask_GammaConvCalo_PbPb.C:191
 AddTask_GammaConvCalo_PbPb.C:192
 AddTask_GammaConvCalo_PbPb.C:193
 AddTask_GammaConvCalo_PbPb.C:194
 AddTask_GammaConvCalo_PbPb.C:195
 AddTask_GammaConvCalo_PbPb.C:196
 AddTask_GammaConvCalo_PbPb.C:197
 AddTask_GammaConvCalo_PbPb.C:198
 AddTask_GammaConvCalo_PbPb.C:199
 AddTask_GammaConvCalo_PbPb.C:200
 AddTask_GammaConvCalo_PbPb.C:201
 AddTask_GammaConvCalo_PbPb.C:202
 AddTask_GammaConvCalo_PbPb.C:203
 AddTask_GammaConvCalo_PbPb.C:204
 AddTask_GammaConvCalo_PbPb.C:205
 AddTask_GammaConvCalo_PbPb.C:206
 AddTask_GammaConvCalo_PbPb.C:207
 AddTask_GammaConvCalo_PbPb.C:208
 AddTask_GammaConvCalo_PbPb.C:209
 AddTask_GammaConvCalo_PbPb.C:210
 AddTask_GammaConvCalo_PbPb.C:211
 AddTask_GammaConvCalo_PbPb.C:212
 AddTask_GammaConvCalo_PbPb.C:213
 AddTask_GammaConvCalo_PbPb.C:214
 AddTask_GammaConvCalo_PbPb.C:215
 AddTask_GammaConvCalo_PbPb.C:216
 AddTask_GammaConvCalo_PbPb.C:217
 AddTask_GammaConvCalo_PbPb.C:218
 AddTask_GammaConvCalo_PbPb.C:219
 AddTask_GammaConvCalo_PbPb.C:220
 AddTask_GammaConvCalo_PbPb.C:221
 AddTask_GammaConvCalo_PbPb.C:222
 AddTask_GammaConvCalo_PbPb.C:223
 AddTask_GammaConvCalo_PbPb.C:224
 AddTask_GammaConvCalo_PbPb.C:225
 AddTask_GammaConvCalo_PbPb.C:226
 AddTask_GammaConvCalo_PbPb.C:227
 AddTask_GammaConvCalo_PbPb.C:228
 AddTask_GammaConvCalo_PbPb.C:229
 AddTask_GammaConvCalo_PbPb.C:230
 AddTask_GammaConvCalo_PbPb.C:231
 AddTask_GammaConvCalo_PbPb.C:232
 AddTask_GammaConvCalo_PbPb.C:233
 AddTask_GammaConvCalo_PbPb.C:234
 AddTask_GammaConvCalo_PbPb.C:235
 AddTask_GammaConvCalo_PbPb.C:236
 AddTask_GammaConvCalo_PbPb.C:237
 AddTask_GammaConvCalo_PbPb.C:238
 AddTask_GammaConvCalo_PbPb.C:239
 AddTask_GammaConvCalo_PbPb.C:240
 AddTask_GammaConvCalo_PbPb.C:241
 AddTask_GammaConvCalo_PbPb.C:242
 AddTask_GammaConvCalo_PbPb.C:243
 AddTask_GammaConvCalo_PbPb.C:244
 AddTask_GammaConvCalo_PbPb.C:245
 AddTask_GammaConvCalo_PbPb.C:246
 AddTask_GammaConvCalo_PbPb.C:247
 AddTask_GammaConvCalo_PbPb.C:248
 AddTask_GammaConvCalo_PbPb.C:249
 AddTask_GammaConvCalo_PbPb.C:250
 AddTask_GammaConvCalo_PbPb.C:251
 AddTask_GammaConvCalo_PbPb.C:252
 AddTask_GammaConvCalo_PbPb.C:253
 AddTask_GammaConvCalo_PbPb.C:254
 AddTask_GammaConvCalo_PbPb.C:255
 AddTask_GammaConvCalo_PbPb.C:256
 AddTask_GammaConvCalo_PbPb.C:257
 AddTask_GammaConvCalo_PbPb.C:258
 AddTask_GammaConvCalo_PbPb.C:259
 AddTask_GammaConvCalo_PbPb.C:260
 AddTask_GammaConvCalo_PbPb.C:261
 AddTask_GammaConvCalo_PbPb.C:262
 AddTask_GammaConvCalo_PbPb.C:263
 AddTask_GammaConvCalo_PbPb.C:264
 AddTask_GammaConvCalo_PbPb.C:265
 AddTask_GammaConvCalo_PbPb.C:266
 AddTask_GammaConvCalo_PbPb.C:267
 AddTask_GammaConvCalo_PbPb.C:268
 AddTask_GammaConvCalo_PbPb.C:269
 AddTask_GammaConvCalo_PbPb.C:270
 AddTask_GammaConvCalo_PbPb.C:271
 AddTask_GammaConvCalo_PbPb.C:272
 AddTask_GammaConvCalo_PbPb.C:273
 AddTask_GammaConvCalo_PbPb.C:274
 AddTask_GammaConvCalo_PbPb.C:275
 AddTask_GammaConvCalo_PbPb.C:276
 AddTask_GammaConvCalo_PbPb.C:277
 AddTask_GammaConvCalo_PbPb.C:278
 AddTask_GammaConvCalo_PbPb.C:279
 AddTask_GammaConvCalo_PbPb.C:280
 AddTask_GammaConvCalo_PbPb.C:281
 AddTask_GammaConvCalo_PbPb.C:282
 AddTask_GammaConvCalo_PbPb.C:283
 AddTask_GammaConvCalo_PbPb.C:284
 AddTask_GammaConvCalo_PbPb.C:285
 AddTask_GammaConvCalo_PbPb.C:286
 AddTask_GammaConvCalo_PbPb.C:287
 AddTask_GammaConvCalo_PbPb.C:288
 AddTask_GammaConvCalo_PbPb.C:289
 AddTask_GammaConvCalo_PbPb.C:290
 AddTask_GammaConvCalo_PbPb.C:291
 AddTask_GammaConvCalo_PbPb.C:292
 AddTask_GammaConvCalo_PbPb.C:293
 AddTask_GammaConvCalo_PbPb.C:294
 AddTask_GammaConvCalo_PbPb.C:295
 AddTask_GammaConvCalo_PbPb.C:296
 AddTask_GammaConvCalo_PbPb.C:297
 AddTask_GammaConvCalo_PbPb.C:298
 AddTask_GammaConvCalo_PbPb.C:299
 AddTask_GammaConvCalo_PbPb.C:300
 AddTask_GammaConvCalo_PbPb.C:301
 AddTask_GammaConvCalo_PbPb.C:302