Skip to content
Merged
Show file tree
Hide file tree
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
16 changes: 8 additions & 8 deletions PWGUD/Core/UPCHelpers.h
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,6 @@
#include "CommonConstants/LHCConstants.h"
#include "Framework/AnalysisDataModel.h"

#include "TLorentzVector.h"

using BCsWithBcSels = o2::soa::Join<o2::aod::BCs, o2::aod::BcSels>;

using ForwardTracks = o2::soa::Join<o2::aod::FwdTracks, o2::aod::FwdTracksCov>;
Expand Down Expand Up @@ -96,14 +94,16 @@ struct FITInfo {
int32_t distClosestBcT0A = 999;
};

constexpr double AbsorberMid = 26.5;

template <typename T, typename TSelectorsArray>
void applyFwdCuts(UPCCutparHolder& upcCuts, const T& track, TSelectorsArray& fwdSelectors)
{
fwdSelectors[kFwdSelPt] = track.pt() > upcCuts.getFwdPtLow() && track.pt() < upcCuts.getFwdPtHigh(); // check pt
fwdSelectors[kFwdSelEta] = track.eta() > upcCuts.getFwdEtaLow() && track.eta() < upcCuts.getFwdEtaHigh(); // check pseudorapidity
fwdSelectors[kFwdSelRabs] = track.rAtAbsorberEnd() > upcCuts.getMuonRAtAbsorberEndLow() && track.rAtAbsorberEnd() < upcCuts.getMuonRAtAbsorberEndHigh(); // check muon R
fwdSelectors[kFwdSelpDCA] = track.pDca() < 26.5 ? track.pDca() < upcCuts.getMuonPDcaHighFirst() : track.pDca() < upcCuts.getMuonPDcaHighSecond(); // check pDCA
fwdSelectors[kFwdSelChi2] = track.chi2() > upcCuts.getFwdChi2Low() && track.chi2() < upcCuts.getFwdChi2High(); // check chi2
fwdSelectors[kFwdSelPt] = track.pt() > upcCuts.getFwdPtLow() && track.pt() < upcCuts.getFwdPtHigh(); // check pt
fwdSelectors[kFwdSelEta] = track.eta() > upcCuts.getFwdEtaLow() && track.eta() < upcCuts.getFwdEtaHigh(); // check pseudorapidity
fwdSelectors[kFwdSelRabs] = track.rAtAbsorberEnd() > upcCuts.getMuonRAtAbsorberEndLow() && track.rAtAbsorberEnd() < upcCuts.getMuonRAtAbsorberEndHigh(); // check muon R
fwdSelectors[kFwdSelpDCA] = track.rAtAbsorberEnd() < AbsorberMid ? track.pDca() < upcCuts.getMuonPDcaHighFirst() : track.pDca() < upcCuts.getMuonPDcaHighSecond(); // check pDCA
fwdSelectors[kFwdSelChi2] = track.chi2() > upcCuts.getFwdChi2Low() && track.chi2() < upcCuts.getFwdChi2High(); // check chi2
}

template <typename T, typename TSelectorsArray>
Expand Down Expand Up @@ -131,7 +131,7 @@ void applyBarrelCuts(UPCCutparHolder& upcCuts, const T& track, TSelectorsArray&

if (upcCuts.getCheckMaxDcaXY()) {
float dca = track.dcaXY();
float maxDCA = 0.0105f + 0.0350f / pow(track.pt(), 1.1f);
float maxDCA = 0.0105f + 0.0350f / std::pow(track.pt(), 1.1f);
barrelSelectors[kBarrelSelDCAXY] = dca < maxDCA;
} else {
barrelSelectors[kBarrelSelDCAXY] = true;
Expand Down
7 changes: 6 additions & 1 deletion PWGUD/TableProducer/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# Copyright 2019-2020 CERN and copyright holders of ALICE O2.

Check failure on line 1 in PWGUD/TableProducer/CMakeLists.txt

View workflow job for this annotation

GitHub Actions / O2 linter

[name/o2-workflow]

Use kebab-case for names of workflows and match the name of the workflow file.
# See https://alice-o2.web.cern.ch/copyright for details of the copyright holders.
# All rights not expressly granted are reserved.
#
Expand All @@ -11,22 +11,22 @@

add_subdirectory(Converters)

o2physics_add_dpl_workflow(dgcand-producer

Check failure on line 14 in PWGUD/TableProducer/CMakeLists.txt

View workflow job for this annotation

GitHub Actions / O2 linter

[name/o2-workflow]

Workflow name dgcand-producer does not match its file name DGCandProducer.cxx. (Matches dgcandProducer.cxx.)
SOURCES DGCandProducer.cxx
PUBLIC_LINK_LIBRARIES O2::Framework O2Physics::AnalysisCore O2Physics::DGCutparHolder O2Physics::AnalysisCCDB O2Physics::EventFilteringUtils
COMPONENT_NAME Analysis)

o2physics_add_dpl_workflow(sgcand-producer

Check failure on line 19 in PWGUD/TableProducer/CMakeLists.txt

View workflow job for this annotation

GitHub Actions / O2 linter

[name/o2-workflow]

Workflow name sgcand-producer does not match its file name SGCandProducer.cxx. (Matches sgcandProducer.cxx.)
SOURCES SGCandProducer.cxx
PUBLIC_LINK_LIBRARIES O2::Framework O2Physics::AnalysisCore O2Physics::SGCutParHolder O2Physics::AnalysisCCDB
COMPONENT_NAME Analysis)

o2physics_add_dpl_workflow(dgbccand-producer

Check failure on line 24 in PWGUD/TableProducer/CMakeLists.txt

View workflow job for this annotation

GitHub Actions / O2 linter

[name/o2-workflow]

Workflow name dgbccand-producer does not match its file name DGBCCandProducer.cxx. (Matches dgbccandProducer.cxx.)
SOURCES DGBCCandProducer.cxx
PUBLIC_LINK_LIBRARIES O2::Framework O2Physics::AnalysisCore O2Physics::DGCutparHolder
COMPONENT_NAME Analysis)

o2physics_add_dpl_workflow(upccand-producer

Check failure on line 29 in PWGUD/TableProducer/CMakeLists.txt

View workflow job for this annotation

GitHub Actions / O2 linter

[name/o2-workflow]

Workflow name upccand-producer does not match its file name UPCCandidateProducer.cxx. (Matches upccandProducer.cxx.)
SOURCES UPCCandidateProducer.cxx
PUBLIC_LINK_LIBRARIES O2::Framework O2Physics::AnalysisCore O2Physics::UPCCutparHolder
COMPONENT_NAME Analysis)
Expand All @@ -41,17 +41,17 @@
PUBLIC_LINK_LIBRARIES O2::Framework O2Physics::AnalysisCore
COMPONENT_NAME Analysis)

o2physics_add_dpl_workflow(fwdtrack-propagation
o2physics_add_dpl_workflow(fwd-track-propagation
SOURCES fwdTrackPropagation.cxx
PUBLIC_LINK_LIBRARIES O2::Framework O2Physics::AnalysisCore O2::GlobalTracking
COMPONENT_NAME Analysis)

o2physics_add_dpl_workflow(udmcparticles-to-udtracks

Check failure on line 49 in PWGUD/TableProducer/CMakeLists.txt

View workflow job for this annotation

GitHub Actions / O2 linter

[name/o2-workflow]

Workflow name udmcparticles-to-udtracks does not match its file name udMcParticles2udTracks.cxx. (Matches udmcparticlesToUdtracks.cxx.)
SOURCES udMcParticles2udTracks.cxx
PUBLIC_LINK_LIBRARIES O2::Framework O2Physics::AnalysisCore
COMPONENT_NAME Analysis)

o2physics_add_dpl_workflow(udmccollisions-to-udcollisions

Check failure on line 54 in PWGUD/TableProducer/CMakeLists.txt

View workflow job for this annotation

GitHub Actions / O2 linter

[name/o2-workflow]

Workflow name udmccollisions-to-udcollisions does not match its file name udMcCollisions2udCollisions.cxx. (Matches udmccollisionsToUdcollisions.cxx.)
SOURCES udMcCollisions2udCollisions.cxx
PUBLIC_LINK_LIBRARIES O2::Framework O2Physics::AnalysisCore
COMPONENT_NAME Analysis)
Expand All @@ -60,3 +60,8 @@
SOURCES tauThreeProngEventTableProducer.cxx
PUBLIC_LINK_LIBRARIES O2::Framework O2Physics::AnalysisCore
COMPONENT_NAME Analysis)

o2physics_add_dpl_workflow(upc-cand-producer-muon
SOURCES upcCandProducerMuon.cxx
PUBLIC_LINK_LIBRARIES O2::Framework O2Physics::AnalysisCore O2Physics::UPCCutparHolder O2::GlobalTracking
COMPONENT_NAME Analysis)
55 changes: 32 additions & 23 deletions PWGUD/TableProducer/fwdTrackPropagation.cxx
Original file line number Diff line number Diff line change
Expand Up @@ -8,29 +8,37 @@
// In applying this license CERN does not waive the privileges and immunities
// granted to it by virtue of its status as an Intergovernmental Organization
// or submit itself to any jurisdiction.

/// \file fwdTrackPropagation.cxx
/// \brief Forward track propagation task for UD tasks
/// \author Nazar Burmasov, nazar.burmasov@cern.ch
/// \author Diana Krupova, diana.krupova@cern.ch
/// \since 04.06.2024

#include "Framework/AnalysisDataModel.h"
#include "Framework/AnalysisTask.h"
#include "Framework/runDataProcessing.h"
#include "PWGUD/DataModel/UDTables.h"

#include "CCDB/BasicCCDBManager.h"
#include "DataFormatsParameters/GRPMagField.h"
#include "TGeoGlobalMagField.h"
#include "Field/MagneticField.h"
#include "DetectorsBase/Propagator.h"
#include "Field/MagneticField.h"
#include "Framework/AnalysisDataModel.h"
#include "Framework/AnalysisTask.h"
#include "Framework/DataTypes.h"
#include "Framework/runDataProcessing.h"
#include "GlobalTracking/MatchGlobalFwd.h"
#include "MCHTracking/TrackExtrap.h"
#include "MCHTracking/TrackParam.h"
#include "Math/SMatrix.h"
#include "ReconstructionDataFormats/TrackFwd.h"

#include "PWGUD/DataModel/UDTables.h"
#include "Math/SMatrix.h"
#include "TGeoGlobalMagField.h"

#include <map>
#include <string>
#include <vector>

using namespace o2::framework;
using namespace o2::framework::expressions;
using o2::aod::fwdtrack::ForwardTrackTypeEnum;

struct FwdTrackPropagation {
using ForwardTracks = o2::soa::Join<o2::aod::FwdTracks, o2::aod::FwdTracksCov>;
Expand Down Expand Up @@ -65,27 +73,27 @@ struct FwdTrackPropagation {
muon.cPhiPhi(), muon.cTglX(), muon.cTglY(), muon.cTglPhi(), muon.cTglTgl(),
muon.c1PtX(), muon.c1PtY(), muon.c1PtPhi(), muon.c1PtTgl(), muon.c1Pt21Pt2()};
SMatrix55 tcovs(v1.begin(), v1.end());
o2::track::TrackParCovFwd fwdtrack{muon.z(), tpars, tcovs, chi2};
o2::dataformats::GlobalFwdTrack propmuon;

if (static_cast<int>(muon.trackType()) > 2) {
if (muon.trackType() > ForwardTrackTypeEnum::GlobalForwardTrack) { // tracks without MFT
o2::dataformats::GlobalFwdTrack track;
track.setParameters(tpars);
track.setZ(fwdtrack.getZ());
track.setZ(muon.z());
track.setCovariances(tcovs);
auto mchTrack = fMatching.FwdtoMCH(track);
o2::mch::TrackExtrap::extrapToVertex(mchTrack, vtx[0], vtx[1], vtx[2], vtxCov[0], vtxCov[1]);
auto proptrack = fMatching.MCHtoFwd(mchTrack);
propmuon.setParameters(proptrack.getParameters());
propmuon.setZ(proptrack.getZ());
propmuon.setCovariances(proptrack.getCovariances());
} else if (static_cast<int>(muon.trackType()) < 2) {
} else if (muon.trackType() <= ForwardTrackTypeEnum::GlobalForwardTrack) { // tracks with MFT
double centerMFT[3] = {0, 0, -61.4};
o2::field::MagneticField* field = static_cast<o2::field::MagneticField*>(TGeoGlobalMagField::Instance()->GetField());
auto Bz = field->getBz(centerMFT); // Get field at centre of MFT
o2::track::TrackParCovFwd fwdtrack{muon.z(), tpars, tcovs, chi2};
auto* field = dynamic_cast<o2::field::MagneticField*>(TGeoGlobalMagField::Instance()->GetField());
auto bz = field->getBz(centerMFT); // Get field at centre of MFT
auto geoMan = o2::base::GeometryManager::meanMaterialBudget(muon.x(), muon.y(), muon.z(), vtx[0], vtx[1], vtx[2]);
auto x2x0 = static_cast<float>(geoMan.meanX2X0);
fwdtrack.propagateToVtxhelixWithMCS(vtx[2], {vtx[0], vtx[1]}, {vtxCov[0], vtxCov[1]}, Bz, x2x0);
fwdtrack.propagateToVtxhelixWithMCS(vtx[2], {vtx[0], vtx[1]}, {vtxCov[0], vtxCov[1]}, bz, x2x0);
propmuon.setParameters(fwdtrack.getParameters());
propmuon.setZ(fwdtrack.getZ());
propmuon.setCovariances(fwdtrack.getCovariances());
Expand All @@ -112,11 +120,12 @@ struct FwdTrackPropagation {
propFwdTracks.reserve(fwdTracks.size());
propFwdTracksCov.reserve(fwdTracks.size());

constexpr float ZAbsorberFront = -90.f;
for (const auto& t : fwdTracks) {
if (t.z() < -90.f) {
if (t.z() < ZAbsorberFront) {
std::array<float, 3> vtx = {0.f, 0.f, 0.f};
std::array<float, 2> vtxCov = {0.f, 0.f};
if (t.has_collision()) {
if (t.has_collision() && t.trackType() <= ForwardTrackTypeEnum::GlobalForwardTrack) { // propagate only global muon tracks to collision vtx
auto col = cols.iteratorAt(t.collisionId());
vtx[0] = col.posX();
vtx[1] = col.posY();
Expand All @@ -129,19 +138,19 @@ struct FwdTrackPropagation {
pft.getX(), pft.getY(), pft.getZ(), pft.getPhi(), pft.getTgl(), pft.getInvQPt(),
pft.getEta(), pft.getPt(), pft.getP(),
t.nClusters(), t.pDca(), t.rAtAbsorberEnd(),
pft.getTrackChi2(), t.chi2MatchMCHMID(), t.chi2MatchMCHMFT(),
t.chi2(), t.chi2MatchMCHMID(), t.chi2MatchMCHMFT(),
t.matchScoreMCHMFT(), t.matchMFTTrackId(), t.matchMCHTrackId(),
t.mchBitMap(), t.midBoards(), t.midBitMap(),
t.trackTime(), t.trackTimeRes());
// debug
// LOGP(info, "track {}, before: {} {} {} {} {} {}", t.globalIndex(), t.x(), t.y(), t.z(), t.phi(), t.tgl(), t.signed1Pt());
// LOGP(info, "track {}, after: {} {} {} {} {} {}", t.globalIndex(), pft.getX(), pft.getY(), pft.getZ(), pft.getPhi(), pft.getTgl(), pft.getInvQPt());
SMatrix55 cov = pft.getCovariances();
float sigX = TMath::Sqrt(cov(0, 0));
float sigY = TMath::Sqrt(cov(1, 1));
float sigPhi = TMath::Sqrt(cov(2, 2));
float sigTgl = TMath::Sqrt(cov(3, 3));
float sig1Pt = TMath::Sqrt(cov(4, 4));
float sigX = std::sqrt(cov(0, 0));
float sigY = std::sqrt(cov(1, 1));
float sigPhi = std::sqrt(cov(2, 2));
float sigTgl = std::sqrt(cov(3, 3));
float sig1Pt = std::sqrt(cov(4, 4));
auto rhoXY = static_cast<int8_t>(128. * cov(0, 1) / (sigX * sigY));
auto rhoPhiX = static_cast<int8_t>(128. * cov(0, 2) / (sigPhi * sigX));
auto rhoPhiY = static_cast<int8_t>(128. * cov(1, 2) / (sigPhi * sigY));
Expand Down
Loading
Loading