Skip to content
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
57 changes: 20 additions & 37 deletions PWGLF/Tasks/Strangeness/strangenessInJets.cxx
Original file line number Diff line number Diff line change
Expand Up @@ -182,6 +182,10 @@ struct StrangenessInJets {
Configurable<double> nsigmaTOFmax{"nsigmaTOFmax", +3.0f, "Maximum nsigma TOF"};
Configurable<bool> requireITS{"requireITS", false, "Require ITS hit"};
Configurable<bool> requireTOF{"requireTOF", false, "Require TOF hit"};
Configurable<bool> doK0sRej{"doK0sRej", false, "K0 mass rejection for Lambda candidates"};
Configurable<bool> doLamRej{"doLamRej", false, "Lambda mass rejection for K0s candidates"};
Configurable<double> lamRejWindow{"lamRejWindow", 0.01f, "Mass window for Lam rejection"};
Configurable<double> k0sRejWindow{"k0sRejWindow", 0.01f, "Mass window for K0 rejection"};

// V0 analysis parameters
Configurable<double> minimumV0Radius{"minimumV0Radius", 0.5f, "Minimum V0 Radius"};
Expand Down Expand Up @@ -286,6 +290,7 @@ struct StrangenessInJets {
// Event counters
registryData.add("number_of_events_data", "number of events in data", HistType::kTH1D, {{20, 0, 20, "Event Cuts"}});
registryData.add("number_of_events_vsmultiplicity", "number of events in data vs multiplicity", HistType::kTH1D, {{101, 0, 101, "Multiplicity percentile"}});
registryData.add("number_of_jets_vsmultiplicity", "number of jets in data vs multiplicity", HistType::kTH1D, {{101, 0, 101, "Multiplicity percentile"}});

// Histograms for analysis of strange hadrons
if (enabledSignals.value[ParticleOfInterest::kV0Particles]) {
Expand Down Expand Up @@ -323,6 +328,7 @@ struct StrangenessInJets {
// Event counter
registryMC.add("number_of_events_mc_gen", "number of gen events in mc", HistType::kTH1D, {{10, 0, 10, "Event Cuts"}});
registryMC.add("number_of_events_vsmultiplicity_gen", "number of events vs multiplicity", HistType::kTH1D, {{101, 0, 101, "Multiplicity percentile"}});
registryMC.add("number_of_jets_vsmultiplicity", "number of jets in mc gen vs multiplicity", HistType::kTH1D, {{101, 0, 101, "Multiplicity percentile"}});

// Histograms for analysis
if (enabledSignals.value[ParticleOfInterest::kV0Particles]) {
Expand Down Expand Up @@ -638,6 +644,9 @@ struct StrangenessInJets {
if (ntrack.tpcNSigmaPi() < nsigmaTPCmin || ntrack.tpcNSigmaPi() > nsigmaTPCmax)
return false;

if (doK0sRej && std::abs(v0.mK0Short() - o2::constants::physics::MassK0Short) < k0sRejWindow)
return false;

// PID selections (TOF): positive track = proton, negative track = pion
if (requireTOF) {
if (ptrack.tofNSigmaPr() < nsigmaTOFmin || ptrack.tofNSigmaPr() > nsigmaTOFmax)
Expand Down Expand Up @@ -730,6 +739,10 @@ struct StrangenessInJets {
if (ntrack.tpcNSigmaPi() < nsigmaTPCmin || ntrack.tpcNSigmaPi() > nsigmaTPCmax)
return false;

if (doLamRej && std::abs(v0.mLambda() - o2::constants::physics::MassLambda) < lamRejWindow)
return false;
;

// PID selections (TOF)
if (requireTOF) {
if (ptrack.tofNSigmaPi() < nsigmaTOFmin || ptrack.tofNSigmaPi() > nsigmaTOFmax)
Expand Down Expand Up @@ -1075,7 +1088,10 @@ struct StrangenessInJets {
selectedJet.emplace_back(jetAxis);
ue1.emplace_back(ueAxis1);
ue2.emplace_back(ueAxis2);

registryData.fill(HIST("number_of_jets_vsmultiplicity"), collision.centFT0M());
}

if (!isAtLeastOneJetSelected)
return;

Expand Down Expand Up @@ -1415,6 +1431,8 @@ struct StrangenessInJets {
continue;
}

registryMC.fill(HIST("number_of_jets_vsmultiplicity"), genMultiplicity);

// Loop over strange hadrons
for (const auto& hadron : hadronMomentum) {
// Compute distance of particles from jet and UE axes
Expand Down Expand Up @@ -2003,45 +2021,10 @@ struct StrangenessInJets {
continue;
if (std::fabs(v0.v0dcanegtopv()) < dcanegtoPVmin)
continue;
// PID selections (TPC) -- K0s
if (v0.ntpcsigmapospi() < nsigmaTPCmin || v0.ntpcsigmapospi() > nsigmaTPCmax)
continue;
if (v0.ntpcsigmanegpi() < nsigmaTPCmin || v0.ntpcsigmanegpi() > nsigmaTPCmax)
if (doK0sRej && std::abs(v0.massk0short() - o2::constants::physics::MassK0Short) < k0sRejWindow)
continue;

// PID selections (TOF) -- K0s
if (requireTOF) {
if (v0.ntofsigmapospi() < nsigmaTOFmin || v0.ntofsigmapospi() > nsigmaTOFmax)
continue;
if (v0.ntofsigmanegpi() < nsigmaTOFmin || v0.ntofsigmanegpi() > nsigmaTOFmax)
continue;
}
// PID selections (TPC): positive track = proton, negative track = pion -- Lam
if (v0.ntpcsigmapospr() < nsigmaTPCmin || v0.ntpcsigmapospr() > nsigmaTPCmax)
if (doLamRej && std::abs(v0.masslambda() - o2::constants::physics::MassLambda) < lamRejWindow)
continue;
if (v0.ntpcsigmanegpi() < nsigmaTPCmin || v0.ntpcsigmanegpi() > nsigmaTPCmax)
continue;

// PID selections (TOF): positive track = proton, negative track = pion -- Lam
if (requireTOF) {
if (v0.ntofsigmapospr() < nsigmaTOFmin || v0.ntofsigmapospr() > nsigmaTOFmax)
continue;
if (v0.ntofsigmanegpi() < nsigmaTOFmin || v0.ntofsigmanegpi() > nsigmaTOFmax)
continue;
}
// PID selections (TPC): negative track = proton, positive track = pion --- ALam
if (v0.ntpcsigmapospi() < nsigmaTPCmin || v0.ntpcsigmapospi() > nsigmaTPCmax)
continue;
if (v0.ntpcsigmanegpr() < nsigmaTPCmin || v0.ntpcsigmanegpr() > nsigmaTPCmax)
continue;

// PID selections (TOF): negative track = proton, positive track = pion --- ALam
if (requireTOF) {
if (v0.ntofsigmapospi() < nsigmaTOFmin || v0.ntofsigmapospi() > nsigmaTOFmax)
continue;
if (v0.ntofsigmanegpr() < nsigmaTOFmin || v0.ntofsigmanegpr() > nsigmaTOFmax)
continue;
}

// PID selections
bool isPIDK0s = false, isPIDLam = false, isPIDALam = false;
Expand Down
Loading