ROOT logo

void InitHistograms(AliDielectron *die, Int_t cutDefinition);
void InitCF(AliDielectron* die, Int_t cutDefinition);

void SetupCuts(AliDielectron *die, Int_t cutDefinition);

AliESDtrackCuts *SetupESDtrackCuts(Int_t cutDefinition);
AliDielectronPID *SetPIDcuts(Int_t cutDefinition);


//start systematics
TString names= ("TPCTOFPhiV");


	Bool_t kRot = 0;
	Bool_t kMix = 1;

TObjArray *arrNames=names.Tokenize(";");
const Int_t nDie=arrNames->GetEntriesFast();

AliDielectron* Config_lowmasspPb(Int_t cutDefinition=1)
{
  //
  // Setup the instance of AliDielectron
  //
  
  // create the actual framework object
  TString name=Form("%02d",cutDefinition);
  if (cutDefinition<arrNames->GetEntriesFast()){
    name=arrNames->At(cutDefinition)->GetName();
  }
  AliDielectron *die =
    new AliDielectron(Form("%s",name.Data()),
                      Form("Track cuts: %s",name.Data()));

  
	if(kRot){
	AliDielectronTrackRotator *rot = new AliDielectronTrackRotator;
	rot->SetConeAnglePhi(TMath::Pi());
	rot->SetIterations(10);
	die->SetTrackRotator(rot);
	}//kRot
 

	if(kMix){
	AliDielectronMixingHandler *mix = new AliDielectronMixingHandler;
	mix->SetMixType(AliDielectronMixingHandler::kAll);
	mix->AddVariable(AliDielectronVarManager::kZvPrim,"-10., -7.5, -5., -2.5 , 0., 2.5, 5., 7.5 , 10.");
	mix->SetDepth(10);
	die->SetMixingHandler(mix);
	}//kMix


	// set track cuts
 SetupCuts(die,cutDefinition);



  //
  // histogram setup
  // only if an AliDielectronHistos object is attached to the
  // dielectron framework histograms will be filled
  //

  InitHistograms(die,cutDefinition);
//  InitCF(die,cutDefinition);


  // eta correction
//  SetEtaCorrection();

  return die;

}

//______________________________________________________________________________________
void SetupCuts(AliDielectron *die, Int_t cutDefinition)
{
  //
  // Setup the track cuts
  //
	//options
        die->SetPreFilterAllSigns();

	//pairing with TLorentzVector
	die->SetUseKF(kFALSE);

	//track cuts
        die->GetTrackFilter().AddCuts(SetupESDtrackCuts(cutDefinition));
	//pid cuts
//if(cutDefinition > 0)
	die->GetTrackFilter().AddCuts(SetPIDcuts(cutDefinition));


  
	if(cutDefinition >= 0){
             AliDielectronTrackCuts *noconv=new AliDielectronTrackCuts("noConv","conversion tagging");
             noconv->SetV0DaughterCut(AliPID::kElectron,kTRUE);
             die->GetTrackFilter().AddCuts(noconv);
	     
	     AliDielectronVarCuts *PhiV = new AliDielectronVarCuts("PhiV","PhiV");//mass and Phiv together
             PhiV->AddCut(AliDielectronVarManager::kM, 0. , 0.15);
             PhiV->AddCut(AliDielectronVarManager::kPhivPair, 2. , 3.2);
             die->GetPairPreFilter().AddCuts(PhiV);

	     
	}
		
		
	if(cutDefinition >= 0){
	
	     AliDielectronVarCuts *PhiVhard = new AliDielectronVarCuts("PhiVhard","PhiVhard");//mass and PhiVhard together (hard PhiVhard)
             PhiVhard->AddCut(AliDielectronVarManager::kM, 0. , 0.05);
             PhiVhard->AddCut(AliDielectronVarManager::kPhivPair, 1.5 , 3.2);
             die->GetPairPreFilter().AddCuts(PhiVhard);
	}
		



}
//______________________________________________________________________________________
//-----------------------------------pid------------------------------------------------

AliDielectronPID *SetPIDcuts(Int_t cutDefinition){

  AliDielectronPID *pid = new AliDielectronPID();

//if(cutDefinition == 0 ){
    pid->AddCut(AliDielectronPID::kTPC,AliPID::kElectron,-1.5,2.5,0.2,100.,kFALSE);
    pid->AddCut(AliDielectronPID::kTPC,AliPID::kPion,-100.,4.,0.2,100.,kTRUE);
    pid->AddCut(AliDielectronPID::kTOF,AliPID::kElectron,-3.,3.,0.4, 5., kFALSE);

//}
/*
if(cutDefinition == 7 ){
        pid->AddCut(AliDielectronPID::kTPC,AliPID::kElectron,-3,3.,0.2,100.,kFALSE);
}

 if(cutDefinition == 1 || cutDefinition == 3 ){//TPC+TOF pT200
   //stronger electron inclusion
        pid->AddCut(AliDielectronPID::kTPC,AliPID::kElectron,-3,3.,0.2,100.,kFALSE);
        pid->AddCut(AliDielectronPID::kTPC,AliPID::kPion,-100.,4.,0.2,100.,kTRUE);
 }
 if(cutDefinition == 2 || cutDefinition == 4 || cutDefinition == 5 || cutDefinition == 6 ){//TPC+TOF pT200
   //stronger electron inclusion
        pid->AddCut(AliDielectronPID::kTPC,AliPID::kElectron,-1.5,2.5,0.2,100.,kFALSE);
        pid->AddCut(AliDielectronPID::kTPC,AliPID::kPion,-100.,4.,0.2,100.,kTRUE);
 }


 if(cutDefinition == 3 || cutDefinition == 4 || cutDefinition == 5 || cutDefinition == 6 || cutDefinition == 8 ){
     pid->AddCut(AliDielectronPID::kTOF,AliPID::kElectron,-3.,3.,0.4, 5., kFALSE);
 }

 if(cutDefinition == 3){//TPC+TOF pT200 shift in sigma_e (TPC)
   //stronger electron inclusion
        pid->AddCut(AliDielectronPID::kTPC,AliPID::kElectron,-2.,2.5,0.2,100.,kFALSE);
        pid->AddCut(AliDielectronPID::kTPC,AliPID::kPion,-100.,4.,0.2,100.,kTRUE);
        //TOF
        pid->AddCut(AliDielectronPID::kTOF,AliPID::kElectron,-3.,3.,0.4, 5., kFALSE);
 }//complete PID
 

 if(cutDefinition == 4){//TPC+TOF pT200 tighter sigma_e (TOF)
   //stronger electron inclusion
        pid->AddCut(AliDielectronPID::kTPC,AliPID::kElectron,-1.5,3.,0.2,100.,kFALSE);
        pid->AddCut(AliDielectronPID::kTPC,AliPID::kPion,-100.,4.,0.2,100.,kTRUE);
        //TOF
        pid->AddCut(AliDielectronPID::kTOF,AliPID::kElectron,-2.,2.,0.4, 5., kFALSE);
 }//complete PID
*/


 return pid;

}

//______________________________________________________________________________________
AliESDtrackCuts *SetupESDtrackCuts(Int_t cutDefinition)
{

  AliESDtrackCuts *fesdTrackCuts = new AliESDtrackCuts;


  //global
  
  fesdTrackCuts->SetPtRange( 0.2 , 100. );
  fesdTrackCuts->SetAcceptKinkDaughters(kFALSE);
  fesdTrackCuts->SetRequireSigmaToVertex(kFALSE);
  fesdTrackCuts->SetDCAToVertex2D(kFALSE);
  fesdTrackCuts->SetMaxDCAToVertexZ(3.);
  fesdTrackCuts->SetMaxDCAToVertexXY(1.);
  fesdTrackCuts->SetEtaRange( -0.8 , 0.8 );

  //ITS
  fesdTrackCuts->SetRequireITSRefit(kTRUE);
  fesdTrackCuts->SetMinNClustersITS(3);
  if(cutDefinition == 6)fesdTrackCuts->SetClusterRequirementITS(AliESDtrackCuts::kSPD,AliESDtrackCuts::kBoth); 
  else fesdTrackCuts->SetClusterRequirementITS(AliESDtrackCuts::kSPD,AliESDtrackCuts::kFirst);


  //TPC
  fesdTrackCuts->SetRequireTPCRefit(kTRUE);
  fesdTrackCuts->SetMinNClustersTPC(80);
  fesdTrackCuts->SetMinNCrossedRowsTPC(100);
  fesdTrackCuts->SetMinRatioCrossedRowsOverFindableClustersTPC(0.5);
  fesdTrackCuts->SetMaxChi2PerClusterTPC(4);
  return fesdTrackCuts;


}

//______________________________________________________________________________________
void InitHistograms(AliDielectron *die, Int_t cutDefinition)
{
  //
  // Initialise the histograms
  //
  
  //Setup histogram classes
  AliDielectronHistos *histos=
    new AliDielectronHistos(die->GetName(),
                            die->GetTitle());
  


  //Initialise histogram classes
  histos->SetReservedWords("Track;Pair");
  
  //Event class
  histos->AddClass("Event");
  

  //Track classes
  //to fill also track info from 2nd event loop until 2
  for (Int_t i=0; i<2; ++i){
    histos->AddClass(Form("Track_%s",AliDielectron::TrackClassName(i)));
  }
  
  //Pair classes
  // to fill also mixed event histograms loop until 10

  for (Int_t i=0; i<3; ++i){
    histos->AddClass(Form("Pair_%s",AliDielectron::PairClassName(i)));

  }

  if(kMix){
  histos->AddClass(Form("Pair_%s",AliDielectron::PairClassName(3))); //ME ++
  histos->AddClass(Form("Pair_%s",AliDielectron::PairClassName(4)));//ME -+
  histos->AddClass(Form("Pair_%s",AliDielectron::PairClassName(6)));//ME +-
  histos->AddClass(Form("Pair_%s",AliDielectron::PairClassName(7))); // ME --
  }

  if(kRot)histos->AddClass(Form("Pair_%s",AliDielectron::PairClassName(10)));//Rot


  //add histograms to event class
  histos->UserHistogram("Event","nEvents","Number of processed events after cuts;Number events",1,0,1,AliDielectronVarManager::kNevents);
  histos->UserHistogram("Event","ZVertex","ZVertex;ZVertex/cm",480,-12.,12.,AliDielectronVarManager::kZvPrim);
  histos->UserHistogram("Event","nESDTracks","ESD tracks;ESD tracks;Number events",100,0,200,AliDielectronVarManager::kTracks);
  histos->UserHistogram("Event","Nacc","Number of accepted tracks;Number events",100,0,200,AliDielectronVarManager::kNacc);
  histos->UserHistogram("Event","NVtxContrib","Number of Vertex Contributor;NVtx;Number events",100,0,100,AliDielectronVarManager::kNVtxContrib);


  //add histograms to Track classes
  histos->UserHistogram("Track","P","P;P [GeV];#tracks",500,0.,10.,AliDielectronVarManager::kPIn);
  histos->UserHistogram("Track","Pt","Pt;Pt [GeV];#tracks",500,0.,10.,AliDielectronVarManager::kPt);
  histos->UserHistogram("Track","Eta","Eta; Eta ;#tracks",100,-1.,1.,AliDielectronVarManager::kEta);
  histos->UserHistogram("Track","Phi","Phi; Phi ;#tracks",640,0.,6.4,AliDielectronVarManager::kPhi);


  histos->UserHistogram("Track","Eta_phi","Eta vs Phi;Eta;Phi",100,-1.,1.,320,0.,6.4,AliDielectronVarManager::kEta,AliDielectronVarManager::kPhi);
  histos->UserHistogram("Track","Eta_pt","Eta vs Pt;Eta;Pt",100,-1.,1.,500,0.,10.,AliDielectronVarManager::kEta,AliDielectronVarManager::kPt);
  histos->UserHistogram("Track","ImpParXY_Pt","ImpParXY_Pt; Pt; ÍmpParXY",500,0.,10.,500,-5.,5.,AliDielectronVarManager::kPt,AliDielectronVarManager::kImpactParXY);
  histos->UserHistogram("Track","ImpParZ_Pt","ImpParZ_Pt; Pt; ÍmpParZ",500,0.,10.,500,-5.,5.,AliDielectronVarManager::kPt,AliDielectronVarManager::kImpactParZ);
 

  //track checks (ITS)
//  histos->UserHistogram("Track","ITSchi2Cl_Mom","ITS Chi2 vs Momentum;Mom;ITS chi2",500,0.,5.,50,0.,5.,AliDielectronVarManager::kPIn,AliDielectronVarManager::kITSchi2Cl);
//  histos->UserHistogram("Track","NclsITS_Mom",";Mom;kNclsITS",500,0.,5.,7,0,7,AliDielectronVarManager::kPIn,AliDielectronVarManager::kNclsITS);

  //track checks (TPC)
//  histos->UserHistogram("Track","TPCsignalNfrac_Mom",";fraction TPCSignalN/TPCncls vs Momentum;Mom;TPCSignalN/TPCncls",500,0.,5.,60,0.,1.2,AliDielectronVarManager::kPIn,AliDielectronVarManager::kTPCsignalNfrac);
//  histos->UserHistogram("Track","TPCchi2Cl_Mom","TPC Chi2 vs Momentum;Mom;TPC Chi2",500,0.,10.,100,0,5,AliDielectronVarManager::kPIn,AliDielectronVarManager::kTPCchi2Cl);
//  histos->UserHistogram("Track","TPCclsDiff_Mom","kTPCclsDiff vs Momentum;Mom;kTPCclsDiff",500,0.,10.,100,-10,10,AliDielectronVarManager::kPIn,AliDielectronVarManager::kTPCclsDiff);
//  histos->UserHistogram("Track","FindableTPCcls_Mom","kNFclsTPC vs Momentum;Mom;kNFclsTPC",500,0.,10.,200,0.,200.,AliDielectronVarManager::kPIn,AliDielectronVarManager::kNFclsTPC);
//  histos->UserHistogram("Track","TPCcls_Mom","kNclsTPC vs Momentum;Mom;kNclsTPC",500,0.,10.,200,0.,200.,AliDielectronVarManager::kPIn,AliDielectronVarManager::kNclsTPC);
//  histos->UserHistogram("Track","kNclsSFracTPC_Mom","kNclsSFracTPC vs Momentum;Mom;kTPCclsSFrac",500,0.,10.,1000,0.,1.,AliDielectronVarManager::kPIn,AliDielectronVarManager::kNclsSFracTPC);
//  histos->UserHistogram("Track","kNFclsTPCrFrac_Mom","kNFclsTPCrFrac vs Momentum;Mom;kNFclsTPCrFrac",500,0.,10.,60,0.,1.2.,AliDielectronVarManager::kPIn,AliDielectronVarManager::kNFclsTPCrFrac);

  //track checks (TOF)
//  histos->UserHistogram("Track","TOFbeta_Mom","kTOFbeta vs Momentum;Mom;TOFbeta",500,0.,5.,120,0.,1.2,AliDielectronVarManager::kPIn,AliDielectronVarManager::kTOFbeta);
//  histos->UserHistogram("Track","TOFPIDBit_Mom","kTOFPIDBit vs Momentum;Mom;TOFPIDbit",500,0.,5.,2,0.,1.,AliDielectronVarManager::kPIn,AliDielectronVarManager::kTOFPIDBit);

  //track checks (PID)
//  histos->UserHistogram("Track","ITSnSigma_MomPio","ITS number of sigmas Pion vs Momentum;Mom;ITSsigmaPion",500,0.,5.,1000,-20,20,AliDielectronVarManager::kPIn,AliDielectronVarManager::kITSnSigmaPio);
//  histos->UserHistogram("Track","TPCnSigma_MomPio","TPC number of sigmas Pions vs Momentum;Mom;TPCsigmaPion",500,0.,5.,1000,-20,20,AliDielectronVarManager::kPIn,AliDielectronVarManager::kTPCnSigmaPio);

//  histos->UserHistogram("Track","ITSnSigma_MomEle","ITS number of sigmas Electrons vs Momentum;Mom;ITSsigmaEle",500,0.,5.,800,-40,40,AliDielectronVarManager::kPIn,AliDielectronVarManager::kITSnSigmaEle);
//  histos->UserHistogram("Track","TPCnSigma_MomEle","TPC number of sigmas Electrons vs Momentum;Mom;TPCsigmaEle",1000,0.,10.,800,-40,40,AliDielectronVarManager::kPIn,AliDielectronVarManager::kTPCnSigmaEle);
//  histos->UserHistogram("Track","TOFnSigma_MomEle","TOF number of sigmas Electrons vs Momentum;Mom;TOFsigmaEle",500,0.,5.,800,-40,40,AliDielectronVarManager::kPIn,AliDielectronVarManager::kTOFnSigmaEle);

  histos->UserHistogram("Track","ITSdEdx_P","dEdx;P [GeV];ITS signal (arb units) vs Momentum;Mom;ITSsignal", 500,0,5,800,0,200,AliDielectronVarManager::kPIn,AliDielectronVarManager::kITSsignal);
  histos->UserHistogram("Track","TPCdEdx_P","dEdx;P [GeV];TPC signal (arb units) vs Momentum;Mom;TPCsignal", 500,0,10.,800,0,200,AliDielectronVarManager::kPIn,AliDielectronVarManager::kTPCsignal);

  //
  //add histograms to Pair classes
  //

  histos->UserHistogram("Pair","InvMass","Inv.Mass;Inv. Mass [GeV];#pairs",
                        500,0,4,AliDielectronVarManager::kM);

  histos->UserHistogram("Pair","InvMass_low","Inv.Mass;Inv. Mass [GeV];#pairs",
                        500,0,0.5,AliDielectronVarManager::kM);

//  histos->UserHistogram("Pair","InvMass10","Inv.Mass;Inv. Mass [GeV];#pairs",
//                        500,0.,5.,AliDielectronVarManager::kM);

  histos->UserHistogram("Pair","kDeltaEta","kDeltaEta;kDeltaEta;#pairs",
                        160,0.,1.6,AliDielectronVarManager::kDeltaEta);

  histos->UserHistogram("Pair","kDeltaEta_low","kDeltaEta;kDeltaEta;#pairs",
                        500,0.,0.5,AliDielectronVarManager::kDeltaEta);

  histos->UserHistogram("Pair","kDeltaPhi","kDeltaPhi;kDeltaPhi;#pairs",
                        320,0.,6.4,AliDielectronVarManager::kDeltaPhi);

//  histos->UserHistogram("Pair",
//                        "kDeltaEta_kDeltaPhi","kDeltaEta_kDeltaPhi;kDeltaEta;kDeltaPhi",
//                        160, 0. , 1.6, 320 , 0., 6.4 ,
//                         AliDielectronVarManager::kDeltaEta , AliDielectronVarManager::kDeltaPhi );

  histos->UserHistogram("Pair","PhiV",";PhiV;#pairs",
                        320,0.,6.4,AliDielectronVarManager::kPhivPair);


//   histos->UserHistogram("Pair","PhiV_Pt",";Pt;PhiV",
//			 100,0.,10.,320,0.,6.4,AliDielectronVarManager::kPt,AliDielectronVarManager::kPhivPair);

//   histos->UserHistogram("Pair","InvMass_bin2","Inv.Mass;Inv. Mass [GeV];#pairs",
//	"0. , 0.025, 0.05 , 0.075 ,0.1 ,0.15 , 0.2 , 0.25 , 0.3 , 
// 	0.4 ,  0.5 , 0.6, 0.65 , 0.688 , 0.725, 0.75, 0.775, 0.8 , 0.85 ,
//	 0.95,  0.975 , 1.0 , 1.025 , 1.05, 1.125 , 1.25 , 1.5 , 1.75 , 2.0 , 
//	2.25, 2.5 , 2.75 , 2.85, 2.95,3.05, 3.1 , 3.15 , 
//	3.3 , 3.5, 3.75 , 4.0",AliDielectronVarManager::kM);


//  histos->UserHistogram("Pair",
//                        "InvMass_Pt","InvMass_Pt;InvMass;Pt",
//                        500, 0. , 4., 100 , 0., 5. ,
//                         AliDielectronVarManager::kM , AliDielectronVarManager::kPt );

//  histos->UserHistogram("Pair",
//                        "InvMass_PhivPair","InvMass_PhivPair;InvMass;PhivPair",
//                        500, 0. , 4., 320 , 0., 3.2 ,
//                         AliDielectronVarManager::kM , AliDielectronVarManager::kPhivPair );

  histos->UserHistogram("Pair",
                        "OpAngle","Opening angle;Opening angle;#pairs",
                        320, 0. , 3.2, 
                         AliDielectronVarManager::kOpeningAngle);

//  histos->UserHistogram("Pair",
//                        "OpAngle_InvMass","OpAngle_InvMass;Opening angle;Invariant Mass",
//                        320, 0. , 3.2, 500 , 0. , 4. ,
//                         AliDielectronVarManager::kOpeningAngle,AliDielectronVarManager::kM);


  histos->UserHistogram("Pair",
                        "Phi","Phi;counts;Phi",
                        320, 0. , 6.4, AliDielectronVarManager::kPhi);

  histos->UserHistogram("Pair",
                        "Y","Y;counts;Y",
                        120, -1.2 , 1.2, AliDielectronVarManager::kY);

  die->SetHistogramManager(histos);
}




void InitCF(AliDielectron* die, Int_t cutDefinition)
{
  //
  // Setup the CF Manager if needed
  //
  
  AliDielectronCF *cf=new AliDielectronCF(die->GetName(),die->GetTitle());

    
   //pair variables
//  cf->AddVariable(AliDielectronVarManager::kM,500,0.,4.);
  cf->AddVariable(AliDielectronVarManager::kM,"0. , 0.025, 0.05 , 0.075 ,0.1 ,0.15 , 0.2 , 0.25 , 0.3 , 
 	0.4 ,  0.5 , 0.6, 0.65 , 0.688 , 0.725, 0.75, 0.775, 0.8 , 0.85 ,
	 0.95,  0.975 , 1.0 , 1.025 , 1.05, 1.125 , 1.25 , 1.5 , 1.75 , 2.0 , 
	2.25, 2.5 , 2.75 , 2.85, 2.95,3.05, 3.1 , 3.15 , 
	3.3 , 3.5, 3.75 , 4.0");//data
  cf->AddVariable(AliDielectronVarManager::kY,20,-1.,1.);
  cf->AddVariable(AliDielectronVarManager::kPhi,32, 0., 3.2);
  cf->AddVariable(AliDielectronVarManager::kPt,100,0.,5.);


  cf->AddVariable(AliDielectronVarManager::kOpeningAngle,62,0.,6.2);
  cf->AddVariable(AliDielectronVarManager::kPhivPair,64, 0., 6.4);
  cf->AddVariable(AliDielectronVarManager::kPairType,4,-0.5,3.5);
  
  
  
  //leg 
  cf->AddVariable(AliDielectronVarManager::kPt,100,0.,10.,kTRUE);
  cf->AddVariable(AliDielectronVarManager::kPhi,36,0.,360.,kTRUE);
  cf->AddVariable(AliDielectronVarManager::kEta,100,-1.,1.,kTRUE);

  
/*  
  cf->AddVariable(AliDielectronVarManager::kTPCsignal,200,0.,200.,kTRUE);
  cf->AddVariable(AliDielectronVarManager::kImpactParXY,40,-2.,2.,kTRUE);
  cf->AddVariable(AliDielectronVarManager::kImpactParZ,40,-2.,2.,kTRUE);
  cf->AddVariable(AliDielectronVarManager::kNclsITS,10,0.,10.,kTRUE);
  cf->AddVariable(AliDielectronVarManager::kNFclsTPCrFrac,10,0.,1.,kTRUE);
*/


  die->SetCFManagerPair(cf);
  
}





void SetEtaCorrection()
{
  if (AliDielectronPID::GetEtaCorrFunction()) return;

  TString list=gSystem->Getenv("LIST");
  
  TFile f("$TRAIN_ROOT/jpsi_JPSI/EtaCorrMaps.root");
  if (!f.IsOpen()) return;
  TList *keys=f.GetListOfKeys();

  for (Int_t i=0; i<keys->GetEntries(); ++i){
    TString kName=keys->At(i)->GetName();
    TPRegexp reg(kName);
    if (reg.MatchB(list)){
      printf("Using Eta Correction Function: %s\n",kName.Data());
      AliDielectronPID::SetEtaCorrFunction((TF1*)f.Get(kName.Data()));
    }
  }
}



 Config_lowmasspPb.C:1
 Config_lowmasspPb.C:2
 Config_lowmasspPb.C:3
 Config_lowmasspPb.C:4
 Config_lowmasspPb.C:5
 Config_lowmasspPb.C:6
 Config_lowmasspPb.C:7
 Config_lowmasspPb.C:8
 Config_lowmasspPb.C:9
 Config_lowmasspPb.C:10
 Config_lowmasspPb.C:11
 Config_lowmasspPb.C:12
 Config_lowmasspPb.C:13
 Config_lowmasspPb.C:14
 Config_lowmasspPb.C:15
 Config_lowmasspPb.C:16
 Config_lowmasspPb.C:17
 Config_lowmasspPb.C:18
 Config_lowmasspPb.C:19
 Config_lowmasspPb.C:20
 Config_lowmasspPb.C:21
 Config_lowmasspPb.C:22
 Config_lowmasspPb.C:23
 Config_lowmasspPb.C:24
 Config_lowmasspPb.C:25
 Config_lowmasspPb.C:26
 Config_lowmasspPb.C:27
 Config_lowmasspPb.C:28
 Config_lowmasspPb.C:29
 Config_lowmasspPb.C:30
 Config_lowmasspPb.C:31
 Config_lowmasspPb.C:32
 Config_lowmasspPb.C:33
 Config_lowmasspPb.C:34
 Config_lowmasspPb.C:35
 Config_lowmasspPb.C:36
 Config_lowmasspPb.C:37
 Config_lowmasspPb.C:38
 Config_lowmasspPb.C:39
 Config_lowmasspPb.C:40
 Config_lowmasspPb.C:41
 Config_lowmasspPb.C:42
 Config_lowmasspPb.C:43
 Config_lowmasspPb.C:44
 Config_lowmasspPb.C:45
 Config_lowmasspPb.C:46
 Config_lowmasspPb.C:47
 Config_lowmasspPb.C:48
 Config_lowmasspPb.C:49
 Config_lowmasspPb.C:50
 Config_lowmasspPb.C:51
 Config_lowmasspPb.C:52
 Config_lowmasspPb.C:53
 Config_lowmasspPb.C:54
 Config_lowmasspPb.C:55
 Config_lowmasspPb.C:56
 Config_lowmasspPb.C:57
 Config_lowmasspPb.C:58
 Config_lowmasspPb.C:59
 Config_lowmasspPb.C:60
 Config_lowmasspPb.C:61
 Config_lowmasspPb.C:62
 Config_lowmasspPb.C:63
 Config_lowmasspPb.C:64
 Config_lowmasspPb.C:65
 Config_lowmasspPb.C:66
 Config_lowmasspPb.C:67
 Config_lowmasspPb.C:68
 Config_lowmasspPb.C:69
 Config_lowmasspPb.C:70
 Config_lowmasspPb.C:71
 Config_lowmasspPb.C:72
 Config_lowmasspPb.C:73
 Config_lowmasspPb.C:74
 Config_lowmasspPb.C:75
 Config_lowmasspPb.C:76
 Config_lowmasspPb.C:77
 Config_lowmasspPb.C:78
 Config_lowmasspPb.C:79
 Config_lowmasspPb.C:80
 Config_lowmasspPb.C:81
 Config_lowmasspPb.C:82
 Config_lowmasspPb.C:83
 Config_lowmasspPb.C:84
 Config_lowmasspPb.C:85
 Config_lowmasspPb.C:86
 Config_lowmasspPb.C:87
 Config_lowmasspPb.C:88
 Config_lowmasspPb.C:89
 Config_lowmasspPb.C:90
 Config_lowmasspPb.C:91
 Config_lowmasspPb.C:92
 Config_lowmasspPb.C:93
 Config_lowmasspPb.C:94
 Config_lowmasspPb.C:95
 Config_lowmasspPb.C:96
 Config_lowmasspPb.C:97
 Config_lowmasspPb.C:98
 Config_lowmasspPb.C:99
 Config_lowmasspPb.C:100
 Config_lowmasspPb.C:101
 Config_lowmasspPb.C:102
 Config_lowmasspPb.C:103
 Config_lowmasspPb.C:104
 Config_lowmasspPb.C:105
 Config_lowmasspPb.C:106
 Config_lowmasspPb.C:107
 Config_lowmasspPb.C:108
 Config_lowmasspPb.C:109
 Config_lowmasspPb.C:110
 Config_lowmasspPb.C:111
 Config_lowmasspPb.C:112
 Config_lowmasspPb.C:113
 Config_lowmasspPb.C:114
 Config_lowmasspPb.C:115
 Config_lowmasspPb.C:116
 Config_lowmasspPb.C:117
 Config_lowmasspPb.C:118
 Config_lowmasspPb.C:119
 Config_lowmasspPb.C:120
 Config_lowmasspPb.C:121
 Config_lowmasspPb.C:122
 Config_lowmasspPb.C:123
 Config_lowmasspPb.C:124
 Config_lowmasspPb.C:125
 Config_lowmasspPb.C:126
 Config_lowmasspPb.C:127
 Config_lowmasspPb.C:128
 Config_lowmasspPb.C:129
 Config_lowmasspPb.C:130
 Config_lowmasspPb.C:131
 Config_lowmasspPb.C:132
 Config_lowmasspPb.C:133
 Config_lowmasspPb.C:134
 Config_lowmasspPb.C:135
 Config_lowmasspPb.C:136
 Config_lowmasspPb.C:137
 Config_lowmasspPb.C:138
 Config_lowmasspPb.C:139
 Config_lowmasspPb.C:140
 Config_lowmasspPb.C:141
 Config_lowmasspPb.C:142
 Config_lowmasspPb.C:143
 Config_lowmasspPb.C:144
 Config_lowmasspPb.C:145
 Config_lowmasspPb.C:146
 Config_lowmasspPb.C:147
 Config_lowmasspPb.C:148
 Config_lowmasspPb.C:149
 Config_lowmasspPb.C:150
 Config_lowmasspPb.C:151
 Config_lowmasspPb.C:152
 Config_lowmasspPb.C:153
 Config_lowmasspPb.C:154
 Config_lowmasspPb.C:155
 Config_lowmasspPb.C:156
 Config_lowmasspPb.C:157
 Config_lowmasspPb.C:158
 Config_lowmasspPb.C:159
 Config_lowmasspPb.C:160
 Config_lowmasspPb.C:161
 Config_lowmasspPb.C:162
 Config_lowmasspPb.C:163
 Config_lowmasspPb.C:164
 Config_lowmasspPb.C:165
 Config_lowmasspPb.C:166
 Config_lowmasspPb.C:167
 Config_lowmasspPb.C:168
 Config_lowmasspPb.C:169
 Config_lowmasspPb.C:170
 Config_lowmasspPb.C:171
 Config_lowmasspPb.C:172
 Config_lowmasspPb.C:173
 Config_lowmasspPb.C:174
 Config_lowmasspPb.C:175
 Config_lowmasspPb.C:176
 Config_lowmasspPb.C:177
 Config_lowmasspPb.C:178
 Config_lowmasspPb.C:179
 Config_lowmasspPb.C:180
 Config_lowmasspPb.C:181
 Config_lowmasspPb.C:182
 Config_lowmasspPb.C:183
 Config_lowmasspPb.C:184
 Config_lowmasspPb.C:185
 Config_lowmasspPb.C:186
 Config_lowmasspPb.C:187
 Config_lowmasspPb.C:188
 Config_lowmasspPb.C:189
 Config_lowmasspPb.C:190
 Config_lowmasspPb.C:191
 Config_lowmasspPb.C:192
 Config_lowmasspPb.C:193
 Config_lowmasspPb.C:194
 Config_lowmasspPb.C:195
 Config_lowmasspPb.C:196
 Config_lowmasspPb.C:197
 Config_lowmasspPb.C:198
 Config_lowmasspPb.C:199
 Config_lowmasspPb.C:200
 Config_lowmasspPb.C:201
 Config_lowmasspPb.C:202
 Config_lowmasspPb.C:203
 Config_lowmasspPb.C:204
 Config_lowmasspPb.C:205
 Config_lowmasspPb.C:206
 Config_lowmasspPb.C:207
 Config_lowmasspPb.C:208
 Config_lowmasspPb.C:209
 Config_lowmasspPb.C:210
 Config_lowmasspPb.C:211
 Config_lowmasspPb.C:212
 Config_lowmasspPb.C:213
 Config_lowmasspPb.C:214
 Config_lowmasspPb.C:215
 Config_lowmasspPb.C:216
 Config_lowmasspPb.C:217
 Config_lowmasspPb.C:218
 Config_lowmasspPb.C:219
 Config_lowmasspPb.C:220
 Config_lowmasspPb.C:221
 Config_lowmasspPb.C:222
 Config_lowmasspPb.C:223
 Config_lowmasspPb.C:224
 Config_lowmasspPb.C:225
 Config_lowmasspPb.C:226
 Config_lowmasspPb.C:227
 Config_lowmasspPb.C:228
 Config_lowmasspPb.C:229
 Config_lowmasspPb.C:230
 Config_lowmasspPb.C:231
 Config_lowmasspPb.C:232
 Config_lowmasspPb.C:233
 Config_lowmasspPb.C:234
 Config_lowmasspPb.C:235
 Config_lowmasspPb.C:236
 Config_lowmasspPb.C:237
 Config_lowmasspPb.C:238
 Config_lowmasspPb.C:239
 Config_lowmasspPb.C:240
 Config_lowmasspPb.C:241
 Config_lowmasspPb.C:242
 Config_lowmasspPb.C:243
 Config_lowmasspPb.C:244
 Config_lowmasspPb.C:245
 Config_lowmasspPb.C:246
 Config_lowmasspPb.C:247
 Config_lowmasspPb.C:248
 Config_lowmasspPb.C:249
 Config_lowmasspPb.C:250
 Config_lowmasspPb.C:251
 Config_lowmasspPb.C:252
 Config_lowmasspPb.C:253
 Config_lowmasspPb.C:254
 Config_lowmasspPb.C:255
 Config_lowmasspPb.C:256
 Config_lowmasspPb.C:257
 Config_lowmasspPb.C:258
 Config_lowmasspPb.C:259
 Config_lowmasspPb.C:260
 Config_lowmasspPb.C:261
 Config_lowmasspPb.C:262
 Config_lowmasspPb.C:263
 Config_lowmasspPb.C:264
 Config_lowmasspPb.C:265
 Config_lowmasspPb.C:266
 Config_lowmasspPb.C:267
 Config_lowmasspPb.C:268
 Config_lowmasspPb.C:269
 Config_lowmasspPb.C:270
 Config_lowmasspPb.C:271
 Config_lowmasspPb.C:272
 Config_lowmasspPb.C:273
 Config_lowmasspPb.C:274
 Config_lowmasspPb.C:275
 Config_lowmasspPb.C:276
 Config_lowmasspPb.C:277
 Config_lowmasspPb.C:278
 Config_lowmasspPb.C:279
 Config_lowmasspPb.C:280
 Config_lowmasspPb.C:281
 Config_lowmasspPb.C:282
 Config_lowmasspPb.C:283
 Config_lowmasspPb.C:284
 Config_lowmasspPb.C:285
 Config_lowmasspPb.C:286
 Config_lowmasspPb.C:287
 Config_lowmasspPb.C:288
 Config_lowmasspPb.C:289
 Config_lowmasspPb.C:290
 Config_lowmasspPb.C:291
 Config_lowmasspPb.C:292
 Config_lowmasspPb.C:293
 Config_lowmasspPb.C:294
 Config_lowmasspPb.C:295
 Config_lowmasspPb.C:296
 Config_lowmasspPb.C:297
 Config_lowmasspPb.C:298
 Config_lowmasspPb.C:299
 Config_lowmasspPb.C:300
 Config_lowmasspPb.C:301
 Config_lowmasspPb.C:302
 Config_lowmasspPb.C:303
 Config_lowmasspPb.C:304
 Config_lowmasspPb.C:305
 Config_lowmasspPb.C:306
 Config_lowmasspPb.C:307
 Config_lowmasspPb.C:308
 Config_lowmasspPb.C:309
 Config_lowmasspPb.C:310
 Config_lowmasspPb.C:311
 Config_lowmasspPb.C:312
 Config_lowmasspPb.C:313
 Config_lowmasspPb.C:314
 Config_lowmasspPb.C:315
 Config_lowmasspPb.C:316
 Config_lowmasspPb.C:317
 Config_lowmasspPb.C:318
 Config_lowmasspPb.C:319
 Config_lowmasspPb.C:320
 Config_lowmasspPb.C:321
 Config_lowmasspPb.C:322
 Config_lowmasspPb.C:323
 Config_lowmasspPb.C:324
 Config_lowmasspPb.C:325
 Config_lowmasspPb.C:326
 Config_lowmasspPb.C:327
 Config_lowmasspPb.C:328
 Config_lowmasspPb.C:329
 Config_lowmasspPb.C:330
 Config_lowmasspPb.C:331
 Config_lowmasspPb.C:332
 Config_lowmasspPb.C:333
 Config_lowmasspPb.C:334
 Config_lowmasspPb.C:335
 Config_lowmasspPb.C:336
 Config_lowmasspPb.C:337
 Config_lowmasspPb.C:338
 Config_lowmasspPb.C:339
 Config_lowmasspPb.C:340
 Config_lowmasspPb.C:341
 Config_lowmasspPb.C:342
 Config_lowmasspPb.C:343
 Config_lowmasspPb.C:344
 Config_lowmasspPb.C:345
 Config_lowmasspPb.C:346
 Config_lowmasspPb.C:347
 Config_lowmasspPb.C:348
 Config_lowmasspPb.C:349
 Config_lowmasspPb.C:350
 Config_lowmasspPb.C:351
 Config_lowmasspPb.C:352
 Config_lowmasspPb.C:353
 Config_lowmasspPb.C:354
 Config_lowmasspPb.C:355
 Config_lowmasspPb.C:356
 Config_lowmasspPb.C:357
 Config_lowmasspPb.C:358
 Config_lowmasspPb.C:359
 Config_lowmasspPb.C:360
 Config_lowmasspPb.C:361
 Config_lowmasspPb.C:362
 Config_lowmasspPb.C:363
 Config_lowmasspPb.C:364
 Config_lowmasspPb.C:365
 Config_lowmasspPb.C:366
 Config_lowmasspPb.C:367
 Config_lowmasspPb.C:368
 Config_lowmasspPb.C:369
 Config_lowmasspPb.C:370
 Config_lowmasspPb.C:371
 Config_lowmasspPb.C:372
 Config_lowmasspPb.C:373
 Config_lowmasspPb.C:374
 Config_lowmasspPb.C:375
 Config_lowmasspPb.C:376
 Config_lowmasspPb.C:377
 Config_lowmasspPb.C:378
 Config_lowmasspPb.C:379
 Config_lowmasspPb.C:380
 Config_lowmasspPb.C:381
 Config_lowmasspPb.C:382
 Config_lowmasspPb.C:383
 Config_lowmasspPb.C:384
 Config_lowmasspPb.C:385
 Config_lowmasspPb.C:386
 Config_lowmasspPb.C:387
 Config_lowmasspPb.C:388
 Config_lowmasspPb.C:389
 Config_lowmasspPb.C:390
 Config_lowmasspPb.C:391
 Config_lowmasspPb.C:392
 Config_lowmasspPb.C:393
 Config_lowmasspPb.C:394
 Config_lowmasspPb.C:395
 Config_lowmasspPb.C:396
 Config_lowmasspPb.C:397
 Config_lowmasspPb.C:398
 Config_lowmasspPb.C:399
 Config_lowmasspPb.C:400
 Config_lowmasspPb.C:401
 Config_lowmasspPb.C:402
 Config_lowmasspPb.C:403
 Config_lowmasspPb.C:404
 Config_lowmasspPb.C:405
 Config_lowmasspPb.C:406
 Config_lowmasspPb.C:407
 Config_lowmasspPb.C:408
 Config_lowmasspPb.C:409
 Config_lowmasspPb.C:410
 Config_lowmasspPb.C:411
 Config_lowmasspPb.C:412
 Config_lowmasspPb.C:413
 Config_lowmasspPb.C:414
 Config_lowmasspPb.C:415
 Config_lowmasspPb.C:416
 Config_lowmasspPb.C:417
 Config_lowmasspPb.C:418
 Config_lowmasspPb.C:419
 Config_lowmasspPb.C:420
 Config_lowmasspPb.C:421
 Config_lowmasspPb.C:422
 Config_lowmasspPb.C:423
 Config_lowmasspPb.C:424
 Config_lowmasspPb.C:425
 Config_lowmasspPb.C:426
 Config_lowmasspPb.C:427
 Config_lowmasspPb.C:428
 Config_lowmasspPb.C:429
 Config_lowmasspPb.C:430
 Config_lowmasspPb.C:431
 Config_lowmasspPb.C:432
 Config_lowmasspPb.C:433
 Config_lowmasspPb.C:434
 Config_lowmasspPb.C:435
 Config_lowmasspPb.C:436
 Config_lowmasspPb.C:437
 Config_lowmasspPb.C:438
 Config_lowmasspPb.C:439
 Config_lowmasspPb.C:440
 Config_lowmasspPb.C:441
 Config_lowmasspPb.C:442
 Config_lowmasspPb.C:443
 Config_lowmasspPb.C:444
 Config_lowmasspPb.C:445
 Config_lowmasspPb.C:446
 Config_lowmasspPb.C:447
 Config_lowmasspPb.C:448
 Config_lowmasspPb.C:449
 Config_lowmasspPb.C:450
 Config_lowmasspPb.C:451
 Config_lowmasspPb.C:452
 Config_lowmasspPb.C:453
 Config_lowmasspPb.C:454
 Config_lowmasspPb.C:455
 Config_lowmasspPb.C:456
 Config_lowmasspPb.C:457