From b8782ae86cf2c129f81e571d101d966dd6e9c2ad Mon Sep 17 00:00:00 2001 From: Matteo Concas Date: Thu, 15 Aug 2024 19:00:29 +0200 Subject: [PATCH] Add support for bitmap in ROFRecords (#13385) --- .../include/DataFormatsITSMFT/ROFRecord.h | 12 ++++- .../ITSMFT/ITS/tracking/src/TrackerTraits.cxx | 2 +- .../ITS/tracking/src/TrackingInterface.cxx | 47 ++++++++++--------- .../ITS/tracking/src/VertexerTraits.cxx | 2 +- 4 files changed, 38 insertions(+), 25 deletions(-) diff --git a/DataFormats/Detectors/ITSMFT/common/include/DataFormatsITSMFT/ROFRecord.h b/DataFormats/Detectors/ITSMFT/common/include/DataFormatsITSMFT/ROFRecord.h index f5af1deeedd85..b25086fe42f30 100644 --- a/DataFormats/Detectors/ITSMFT/common/include/DataFormatsITSMFT/ROFRecord.h +++ b/DataFormats/Detectors/ITSMFT/common/include/DataFormatsITSMFT/ROFRecord.h @@ -45,6 +45,14 @@ class ROFRecord void setFirstEntry(int idx) { mROFEntry.setFirstEntry(idx); } void setNEntries(int n) { mROFEntry.setEntries(n); } + uint32_t getFlags() const { return mBits; } + void setFlags(uint32_t flags) { mBits = flags; } + void setFlag(uint8_t flagIndex) { mBits |= (1 << flagIndex); } + void resetFlag(uint8_t flagIndex) { mBits &= ~(1 << flagIndex); } + bool getFlag(uint8_t flagIndex) const { return mBits & (1 << flagIndex); } + void clearAllFlags() { mBits = 0; } + void setAllFlags() { mBits = ~0; } + const BCData& getBCData() const { return mBCData; } BCData& getBCData() { return mBCData; } EvIdx getEntry() const { return mROFEntry; } @@ -91,8 +99,8 @@ class ROFRecord o2::InteractionRecord mBCData; // BC data for given trigger EvIdx mROFEntry; //< reference on the 1st object of the ROF in data ROFtype mROFrame = 0; //< frame ID - - ClassDefNV(ROFRecord, 2); + uint32_t mBits = 0; + ClassDefNV(ROFRecord, 3); }; /// this is a simple reference connecting (composed) MC event ID (from the EventRecord of the RunContext) diff --git a/Detectors/ITSMFT/ITS/tracking/src/TrackerTraits.cxx b/Detectors/ITSMFT/ITS/tracking/src/TrackerTraits.cxx index 1722c05ecb4f6..4ea39e29310bf 100644 --- a/Detectors/ITSMFT/ITS/tracking/src/TrackerTraits.cxx +++ b/Detectors/ITSMFT/ITS/tracking/src/TrackerTraits.cxx @@ -98,7 +98,7 @@ void TrackerTraits::computeLayerTracklets(const int iteration, int iROFslice, in for (int iV{startVtx}; iV < endVtx; ++iV) { auto& primaryVertex{primaryVertices[iV]}; - if (primaryVertex.isFlagSet(1) && iteration != 3) { + if (primaryVertex.isFlagSet(2) && iteration != 3) { continue; } const float resolution = o2::gpu::CAMath::Sqrt(Sq(mTrkParams[iteration].PVres) / primaryVertex.getNContributors() + Sq(tf->getPositionResolution(iLayer))); diff --git a/Detectors/ITSMFT/ITS/tracking/src/TrackingInterface.cxx b/Detectors/ITSMFT/ITS/tracking/src/TrackingInterface.cxx index 6419f5072c480..0fdf77e9e29fa 100644 --- a/Detectors/ITSMFT/ITS/tracking/src/TrackingInterface.cxx +++ b/Detectors/ITSMFT/ITS/tracking/src/TrackingInterface.cxx @@ -118,15 +118,14 @@ void ITSTrackingInterface::run(framework::ProcessingContext& pc) } auto rofsinput = pc.inputs().get>("ROframes"); - auto& rofs = pc.outputs().make>(Output{"ITS", "ITSTrackROF", 0}, rofsinput.begin(), rofsinput.end()); + auto& trackROFvec = pc.outputs().make>(Output{"ITS", "ITSTrackROF", 0}, rofsinput.begin(), rofsinput.end()); auto& irFrames = pc.outputs().make>(Output{"ITS", "IRFRAMES", 0}); const auto& alpParams = o2::itsmft::DPLAlpideParam::Instance(); // RS: this should come from CCDB - irFrames.reserve(rofs.size()); + irFrames.reserve(trackROFvec.size()); int nBCPerTF = alpParams.roFrameLengthInBC; - LOGP(info, "ITSTracker pulled {} clusters, {} RO frames", compClusters.size(), rofs.size()); - + LOGP(info, "ITSTracker pulled {} clusters, {} RO frames", compClusters.size(), trackROFvec.size()); const dataformats::MCTruthContainer* labels = nullptr; gsl::span mc2rofs; if (mIsMC) { @@ -165,8 +164,8 @@ void ITSTrackingInterface::run(framework::ProcessingContext& pc) gsl::span::iterator pattIt = patterns.begin(); - gsl::span rofspan(rofs); - mTimeFrame->loadROFrameData(rofspan, compClusters, pattIt, mDict, labels); + gsl::span trackROFspan(trackROFvec); + mTimeFrame->loadROFrameData(trackROFspan, compClusters, pattIt, mDict, labels); pattIt = patterns.begin(); std::vector savedROF; auto logger = [&](std::string s) { LOG(info) << s; }; @@ -175,12 +174,12 @@ void ITSTrackingInterface::run(framework::ProcessingContext& pc) FastMultEst multEst; // mult estimator std::vector processingMask, processUPCMask; - int cutVertexMult{0}, cutUPCVertex{0}, cutRandomMult = int(rofs.size()) - multEst.selectROFs(rofs, compClusters, physTriggers, processingMask); + int cutVertexMult{0}, cutUPCVertex{0}, cutRandomMult = int(trackROFvec.size()) - multEst.selectROFs(trackROFvec, compClusters, physTriggers, processingMask); processUPCMask.resize(processingMask.size(), false); mTimeFrame->setMultiplicityCutMask(processingMask); float vertexerElapsedTime{0.f}; if (mRunVertexer) { - vertROFvec.reserve(rofs.size()); + vertROFvec.reserve(trackROFvec.size()); // Run seeding vertexer if constexpr (isGPU) { vertexerElapsedTime = mVertexer->clustersToVerticesHybrid(logger); @@ -192,9 +191,9 @@ void ITSTrackingInterface::run(framework::ProcessingContext& pc) } const auto& multEstConf = FastMultEstConfig::Instance(); // parameters for mult estimation and cuts gsl::span> vMCRecInfo; - for (auto iRof{0}; iRof < rofspan.size(); ++iRof) { + for (auto iRof{0}; iRof < trackROFspan.size(); ++iRof) { std::vector vtxVecLoc; - auto& vtxROF = vertROFvec.emplace_back(rofspan[iRof]); + auto& vtxROF = vertROFvec.emplace_back(trackROFspan[iRof]); vtxROF.setFirstEntry(vertices.size()); if (mRunVertexer) { auto vtxSpan = mTimeFrame->getPrimaryVertices(iRof); @@ -219,6 +218,11 @@ void ITSTrackingInterface::run(framework::ProcessingContext& pc) allVerticesLabels.push_back(vMCRecInfo[iV].first); allVerticesPurities.push_back(vMCRecInfo[iV].second); } + if (v.isFlagSet(2)) { // Vertex is reconstructed in a second iteration + vtxROF.setFlag(2); // flag that at least one vertex is from the second iteration + } else { + vtxROF.setFlag(1); // flag that at least one vertex is from the first iteration + } } if (processingMask[iRof] && !selROF) { // passed selection in clusters and not in vertex multiplicity LOGP(info, "ROF {} rejected by the vertex multiplicity selection [{},{}]", iRof, multEstConf.cutMultVtxLow, multEstConf.cutMultVtxHigh); @@ -236,14 +240,14 @@ void ITSTrackingInterface::run(framework::ProcessingContext& pc) } } if (mRunVertexer) { - LOG(info) << fmt::format(" - rejected {}/{} ROFs: random/mult.sel:{} (seed {}), vtx.sel:{}, upc.sel:{}", cutRandomMult + cutVertexMult + cutUPCVertex, rofspan.size(), cutRandomMult, multEst.lastRandomSeed, cutVertexMult, cutUPCVertex); + LOG(info) << fmt::format(" - rejected {}/{} ROFs: random/mult.sel:{} (seed {}), vtx.sel:{}, upc.sel:{}", cutRandomMult + cutVertexMult + cutUPCVertex, trackROFspan.size(), cutRandomMult, multEst.lastRandomSeed, cutVertexMult, cutUPCVertex); LOG(info) << fmt::format(" - Vertex seeding total elapsed time: {} ms for {} ({} + {}) vertices found in {}/{} ROFs", vertexerElapsedTime, mTimeFrame->getPrimaryVerticesNum(), mTimeFrame->getTotVertIteration()[0], o2::its::VertexerParamConfig::Instance().nIterations > 1 ? mTimeFrame->getTotVertIteration()[1] : 0, - rofspan.size() - mTimeFrame->getNoVertexROF(), - rofspan.size()); + trackROFspan.size() - mTimeFrame->getNoVertexROF(), + trackROFspan.size()); } if (mOverrideBeamEstimation) { @@ -251,7 +255,7 @@ void ITSTrackingInterface::run(framework::ProcessingContext& pc) } else { LOG(info) << fmt::format(" - Beam position computed for the TF: {}, {}", mTimeFrame->getBeamX(), mTimeFrame->getBeamY()); } - if (mCosmicsProcessing && compClusters.size() > 1500 * rofspan.size()) { + if (mCosmicsProcessing && compClusters.size() > 1500 * trackROFspan.size()) { LOG(error) << "Cosmics processing was requested with an average detector occupancy exceeding 1.e-7, skipping TF processing."; } else { @@ -279,17 +283,18 @@ void ITSTrackingInterface::run(framework::ProcessingContext& pc) LOG(warning) << fmt::format(" - The processed timeframe had {} clusters with wild z coordinates, check the dictionaries", mTimeFrame->hasBogusClusters()); } - for (unsigned int iROF{0}; iROF < rofs.size(); ++iROF) { - auto& rof{rofs[iROF]}; + for (unsigned int iROF{0}; iROF < trackROFvec.size(); ++iROF) { + auto& tracksROF{trackROFvec[iROF]}; + auto& vtxROF = vertROFvec[iROF]; auto& tracks = mTimeFrame->getTracks(iROF); auto number{tracks.size()}; auto first{allTracks.size()}; - int offset = -rof.getFirstEntry(); // cluster entry!!! - rof.setFirstEntry(first); - rof.setNEntries(number); - + int offset = -tracksROF.getFirstEntry(); // cluster entry!!! + tracksROF.setFirstEntry(first); + tracksROF.setNEntries(number); + tracksROF.setFlags(number ? vtxROF.getFlags() : 0); // copies 0xffffffff if cosmics if (processingMask[iROF]) { - irFrames.emplace_back(rof.getBCData(), rof.getBCData() + nBCPerTF - 1).info = tracks.size(); + irFrames.emplace_back(tracksROF.getBCData(), tracksROF.getBCData() + nBCPerTF - 1).info = tracks.size(); } allTrackLabels.reserve(mTimeFrame->getTracksLabel(iROF).size()); // should be 0 if not MC std::copy(mTimeFrame->getTracksLabel(iROF).begin(), mTimeFrame->getTracksLabel(iROF).end(), std::back_inserter(allTrackLabels)); diff --git a/Detectors/ITSMFT/ITS/tracking/src/VertexerTraits.cxx b/Detectors/ITSMFT/ITS/tracking/src/VertexerTraits.cxx index 2196e04752484..1d210cbf6a9a6 100644 --- a/Detectors/ITSMFT/ITS/tracking/src/VertexerTraits.cxx +++ b/Detectors/ITSMFT/ITS/tracking/src/VertexerTraits.cxx @@ -469,7 +469,7 @@ void VertexerTraits::computeVertices(const int iteration) mTimeFrame->getTrackletClusters(rofId)[iCluster].getAvgDistance2()); // In place of chi2 vertices.back().setTimeStamp(rofId); - vertices.back().setFlags(iteration); + vertices.back().setFlags(iteration + 1); // This can be interpreted as the UPC flag if it is > 0 if (mTimeFrame->hasMCinformation()) { std::vector labels; for (auto& index : mTimeFrame->getTrackletClusters(rofId)[iCluster].getLabels()) {