13#ifndef TRACKINGITSU_INCLUDE_TIMEFRAME_H_
14#define TRACKINGITSU_INCLUDE_TIMEFRAME_H_
51class TopologyDictionary;
86 gsl::span<const itsmft::CompClusterExt>
clusters,
87 gsl::span<const unsigned char>::iterator& pattIt,
101 void setBeamPosition(
const float x,
const float y,
const float s2,
const float base = 50.f,
const float systematic = 0.f)
104 resetBeamXY(
x,
y, s2 / o2::gpu::CAMath::Sqrt((base * base) + systematic));
209 void setMemoryPool(std::shared_ptr<BoundedMemoryResource> pool);
252 template <
typename... T>
254 template <
typename... T>
262 std::array<const dataformats::MCTruthContainer<MCCompLabel>*, NLayers>
mClusterLabels{
nullptr};
272 std::vector<bounded_vector<CellSeed>>
mCells;
283 virtual bool isGPU() const noexcept {
return false; }
284 virtual const char*
getName() const noexcept {
return "CPU"; }
310 std::vector<bounded_vector<Line>>
mLines;
334template <
int NLayers>
337 if (rofId < 0 || rofId >= getNrof(
layer)) {
340 const auto&
entry = mROFVertexLookupTableView.getVertices(
layer, rofId);
341 return {&mPrimaryVertices[
entry.getFirstEntry()],
static_cast<gsl::span<const Vertex>::size_type
>(
entry.getEntries())};
344template <
int NLayers>
352template <
int NLayers>
355 return {&mROFramesClusters[layerId][0],
static_cast<gsl::span<const int>::size_type
>(mROFramesClusters[layerId].size())};
358template <
int NLayers>
361 if (rofId < 0 || rofId >= getNrof(layerId)) {
364 int startIdx{mROFramesClusters[layerId][rofId]};
365 return {&mClusters[layerId][startIdx],
static_cast<gsl::span<Cluster>::size_type
>(mROFramesClusters[layerId][rofId + 1] - startIdx)};
368template <
int NLayers>
371 if (rofId < 0 || rofId >= getNrof(layerId)) {
374 int startIdx{mROFramesClusters[layerId][rofId]};
375 return {&mClusters[layerId][startIdx],
static_cast<gsl::span<const Cluster>::size_type
>(mROFramesClusters[layerId][rofId + 1] - startIdx)};
378template <
int NLayers>
381 if (rofId < 0 || rofId >= getNrof(layerId)) {
384 int startIdx{mROFramesClusters[layerId][rofId]};
385 return {&mUsedClusters[layerId][startIdx],
static_cast<gsl::span<uint8_t>::size_type
>(mROFramesClusters[layerId][rofId + 1] - startIdx)};
388template <
int NLayers>
391 if (rofId < 0 || rofId >= getNrof(layerId)) {
394 int startIdx{mROFramesClusters[layerId][rofId]};
395 return {&mUsedClusters[layerId][startIdx],
static_cast<gsl::span<const uint8_t>::size_type
>(mROFramesClusters[layerId][rofId + 1] - startIdx)};
398template <
int NLayers>
401 if (rofMin < 0 || rofMin >= getNrof(layerId)) {
404 int startIdx{mROFramesClusters[layerId][rofMin]};
405 int endIdx{mROFramesClusters[layerId][o2::gpu::CAMath::Min(rofMin +
range, getNrof(layerId))]};
406 return {&mClusters[layerId][startIdx],
static_cast<gsl::span<Cluster>::size_type
>(endIdx - startIdx)};
409template <
int NLayers>
412 int chkdRange{o2::gpu::CAMath::Min(
range, getNrof(layerId) - rofMin)};
413 return {&mROFramesClusters[layerId][rofMin],
static_cast<gsl::span<int>::size_type
>(chkdRange)};
416template <
int NLayers>
419 int chkdRange{o2::gpu::CAMath::Min(
range, getNrof(layerId) - rofMin)};
420 return {&mNClustersPerROF[layerId][rofMin],
static_cast<gsl::span<int>::size_type
>(chkdRange)};
423template <
int NLayers>
426 int startIdx{rofMin};
427 int endIdx{o2::gpu::CAMath::Min(rofMin +
range, getNrof(layerId))};
428 return mROFramesClusters[layerId][endIdx] - mROFramesClusters[layerId][startIdx];
431template <
int NLayers>
434 return std::lower_bound(mROFramesClusters[iLayer].begin(), mROFramesClusters[iLayer].
end(), iCluster + 1) - mROFramesClusters[iLayer].begin() - 1;
437template <
int NLayers>
440 if (rofId < 0 || rofId >= getNrof(layerId)) {
443 int startIdx{mROFramesClusters[layerId][rofId]};
444 return {&mUnsortedClusters[layerId][startIdx],
static_cast<gsl::span<Cluster>::size_type
>(mROFramesClusters[layerId][rofId + 1] - startIdx)};
447template <
int NLayers>
450 if (rofId < 0 || rofId >= getNrof(
layer)) {
453 const int tableSize = mIndexTableUtils.getNphiBins() * mIndexTableUtils.getNzBins() + 1;
454 return {&mIndexTables[
layer][rofId * tableSize],
static_cast<gsl::span<int>::size_type
>(tableSize)};
457template <
int NLayers>
458template <
typename... T>
461 mUnsortedClusters[
layer].emplace_back(std::forward<T>(
values)...);
464template <
int NLayers>
465template <
typename... T>
468 mTrackingFrameInfo[
layer].emplace_back(std::forward<T>(
values)...);
471template <
int NLayers>
474 return {&mUsedClusters[
layer][0],
static_cast<gsl::span<uint8_t>::size_type
>(mUsedClusters[
layer].size())};
477template <
int NLayers>
480 if (rofId < 0 || rofId >= getNrof(1)) {
483 auto startIdx{mROFramesClusters[1][rofId]};
484 return {&mNTrackletsPerCluster[combId][startIdx],
static_cast<gsl::span<int>::size_type
>(mROFramesClusters[1][rofId + 1] - startIdx)};
487template <
int NLayers>
490 if (rofId < 0 || rofId >= getNrof(1)) {
493 auto clusStartIdx{mROFramesClusters[1][rofId]};
495 return {&mNTrackletsPerClusterSum[combId][clusStartIdx],
static_cast<gsl::span<int>::size_type
>(mROFramesClusters[1][rofId + 1] - clusStartIdx)};
498template <
int NLayers>
501 if (rofId < 0 || rofId >= getNrof(1) || mTracklets[combId].
empty()) {
504 auto startIdx{mNTrackletsPerROF[combId][rofId]};
505 return {&mTracklets[combId][startIdx],
static_cast<gsl::span<Tracklet>::size_type
>(mNTrackletsPerROF[combId][rofId + 1] - startIdx)};
508template <
int NLayers>
511 if (rofId < 0 || rofId >= getNrof(1)) {
514 auto startIdx{mNTrackletsPerROF[combId][rofId]};
515 return {&mTracklets[combId][startIdx],
static_cast<gsl::span<Tracklet>::size_type
>(mNTrackletsPerROF[combId][rofId + 1] - startIdx)};
518template <
int NLayers>
521 if (rofId < 0 || rofId >= getNrof(1) || !hasMCinformation()) {
524 auto startIdx{mNTrackletsPerROF[combId][rofId]};
525 return {&mTrackletLabels[combId][startIdx],
static_cast<gsl::span<Tracklet>::size_type
>(mNTrackletsPerROF[combId][rofId + 1] - startIdx)};
528template <
int NLayers>
531 size_t totalClusters{0};
532 for (
const auto&
clusters : mUnsortedClusters) {
535 return int(totalClusters);
538template <
int NLayers>
542 for (
const auto&
layer : mClusters) {
548template <
int NLayers>
552 for (
const auto&
layer : mCells) {
553 nCells +=
layer.size();
558template <
int NLayers>
561 size_t nTracklets{0};
562 for (
const auto&
layer : mTracklets) {
563 nTracklets +=
layer.size();
568template <
int NLayers>
572 for (
const auto& l : mCellsNeighbours) {
578template <
int NLayers>
581 return mTracks.size();
584template <
int NLayers>
588 for (
const auto&
layer : mUsedClusters) {
Definition of a container to keep Monte Carlo truth external to simulation objects.
Definition of the ITS track.
HMPID cluster implementation.
GLboolean GLboolean GLboolean b
GLenum GLsizei GLsizei GLint * values
GLuint GLsizei const GLchar * label
GLenum GLuint GLint GLint layer
GLboolean GLboolean GLboolean GLboolean a
GLubyte GLubyte GLubyte GLubyte w
std::pmr::vector< T > bounded_vector
std::pair< o2::MCCompLabel, float > VertexLabel
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...
ROFVertexLookupTable< NLayers > ROFVertexLookupTableN
virtual size_t getNumberOfCells() const
void prepareClusters(const TrackingParameters &trkParam, const int maxLayers=NLayers)
std::vector< bounded_vector< Line > > mLines
std::vector< bounded_vector< int > > mTrackletsLookupTable
bounded_vector< int > mBogusClusters
std::array< float, NLayers > mMaxR
const TrackingFrameInfo & getClusterTrackingFrameInfo(int layerId, const Cluster &cl) const
virtual void setDevicePropagator(const o2::base::PropagatorImpl< float > *)
const auto & getROFVertexLookupTableView() const
size_t getNumberOfUsedClusters() const
std::array< bounded_vector< int >, NLayers > mIndexTables
ROFMaskTableN mUPCCutMask
gsl::span< const Cluster > getUnsortedClustersOnLayer(int rofId, int layerId) const
std::array< bounded_vector< int >, 2 > mNTrackletsPerClusterSum
size_t getNumberOfClusters() const
gsl::span< const Cluster > getClustersOnLayer(int rofId, int layerId) const
auto & getPositionResolutions()
bounded_vector< MCCompLabel > mTracksLabel
void useMultiplictyMask() noexcept
bool checkMemory(unsigned long max)
const auto & getTrackingFrameInfoOnLayer(int layerId) const
std::array< uint32_t, 2 > mTotalTracklets
void setMemoryPool(std::shared_ptr< BoundedMemoryResource > pool)
memory management
size_t getNumberOfTracks() const
void resetBeamXY(const float x, const float y, const float w=0)
void computeTracletsPerClusterScans()
auto & getTrackletsLabel(int layer)
ROFOverlapTableN mROFOverlapTable
std::shared_ptr< BoundedMemoryResource > mExtMemoryPool
bounded_vector< TrackITSExt > mTracks
auto getFrameworkAllocator()
virtual size_t getNumberOfNeighbours() const
ROFVertexLookupTableN::View mROFVertexLookupTableView
gsl::span< Tracklet > getFoundTracklets(int rofId, int combId)
gsl::span< uint8_t > getUsedClustersROF(int rofId, int layerId)
std::array< const dataformats::MCTruthContainer< MCCompLabel > *, NLayers > mClusterLabels
float getPhiCut(int layer) const
std::vector< bounded_vector< CellSeed > > mCells
gsl::span< const MCCompLabel > getLabelsFoundTracklets(int rofId, int combId) const
void printArtefactsMemory() const
void useUPCMask() noexcept
float getMSangle(int layer) const
ROFOverlapTableN::View mROFOverlapTableView
gsl::span< const Tracklet > getFoundTracklets(int rofId, int combId) const
const Vertex & getPrimaryVertex(const int ivtx) const
virtual const char * getName() const noexcept
const o2::base::PropagatorImpl< float > * getDevicePropagator() const
gsl::span< const Cluster > getClustersPerROFrange(int rofMin, int range, int layerId) const
int getClusterSize(int layer, int clusterId) const
void updateROFVertexLookupTable()
void setFrameworkAllocator(ExternalAllocator *ext)
void setClusterSize(int layer, bounded_vector< uint8_t > &v)
const auto & getIndexTableUtils() const
void addPrimaryVertexLabel(const VertexLabel &label)
bool hasFrameworkAllocator() const noexcept
bounded_vector< float > mMSangles
gsl::span< const int > getNClustersROFrange(int rofMin, int range, int layerId) const
int getSortedStartIndex(const int rofId, const int layer) const
auto & getUnsortedClusters()
const auto & getROFMaskView() const
void prepareROFrameData(gsl::span< const itsmft::CompClusterExt > clusters, int layer)
gsl::span< unsigned char > getUsedClusters(const int layer)
auto & getLines(int rofId)
void addClusterExternalIndexToLayer(int layer, const int idx)
virtual bool isGPU() const noexcept
const auto & getPrimaryVertices() const
void markUsedCluster(int layer, int clusterId)
gsl::span< int > getIndexTable(int rofId, int layerId)
void computeTrackletsPerROFScans()
const o2::base::PropagatorImpl< float > * mPropagatorDevice
std::vector< bounded_vector< MCCompLabel > > mLinesLabels
std::array< bounded_vector< TrackingFrameInfo >, NLayers > mTrackingFrameInfo
void addPrimaryVertex(const Vertex &vertex)
int getNrof(int layer) const
int hasBogusClusters() const
std::array< bounded_vector< uint8_t >, NLayers > mUsedClusters
void loadROFrameData(gsl::span< const o2::itsmft::ROFRecord > rofs, gsl::span< const itsmft::CompClusterExt > clusters, gsl::span< const unsigned char >::iterator &pattIt, const itsmft::TopologyDictionary *dict, int layer, const dataformats::MCTruthContainer< MCCompLabel > *mcLabels=nullptr)
std::vector< bounded_vector< int > > mCellsNeighbours
std::array< float, 2 > & getBeamXY()
auto & getCellsNeighbours()
void addTrackingFrameInfoToLayer(int layer, T &&... args)
std::vector< bounded_vector< MCCompLabel > > mTrackletLabels
PV x and alpha for track propagation.
ROFMaskTableN::View mROFMaskView
void resetROFrameData(int iLayer)
bounded_vector< float > mPhiCuts
void initialise(const int iteration, const TrackingParameters &trkParam, const int maxLayers=NLayers, bool resetVertices=true)
int getSortedIndex(int rofId, int layer, int idx) const
auto & getCellsLookupTable()
std::array< float, 2 > mBeamPos
void setUPCCutMask(ROFMaskTableN cutMask)
void setROFVertexLookupTable(ROFVertexLookupTableN table)
unsigned int mNTotalLowPtVertices
int getTotalClusters() const
virtual ~TimeFrame()=default
uint32_t getTotalTrackletsTF(const int iLayer)
std::vector< bounded_vector< int > > mNTrackletsPerROF
auto & getMemoryPool() const noexcept
gsl::span< const int > getROFramesClustersPerROFrange(int rofMin, int range, int layerId) const
ExternalAllocator * mExternalAllocator
State if memory will be externally managed by the GPU framework.
std::array< bounded_vector< int >, NLayers > mNClustersPerROF
int getClusterROF(int iLayer, int iCluster)
int getTotalClustersPerROFrange(int rofMin, int range, int layerId) const
auto getPrimaryVerticesNum()
std::array< bounded_vector< int >, 2 > mTrackletsIndexROF
bounded_vector< float > mPositionResolution
std::array< bounded_vector< Cluster >, NLayers > mUnsortedClusters
std::vector< bounded_vector< Tracklet > > mTracklets
std::vector< bounded_vector< MCCompLabel > > mCellLabels
auto & getLinesLabel(const int rofId)
void setBeamPosition(const float x, const float y, const float s2, const float base=50.f, const float systematic=0.f)
std::vector< bounded_vector< ClusterLines > > mTrackletClusters
ROFMaskTableN mMultiplicityCutMask
auto & getPrimaryVertices()
std::vector< bounded_vector< int > > mCellsNeighboursLUT
gsl::span< const MCCompLabel > getClusterLabels(int layerId, const int clId) const
bounded_vector< VertexLabel > mPrimaryVerticesLabels
gsl::span< const uint8_t > getUsedClustersROF(int rofId, int layerId) const
virtual size_t getNumberOfTracklets() const
bool hasMCinformation() const
float getPositionResolution(int layer) const
std::array< bounded_vector< uint8_t >, NLayers > mClusterSize
gsl::span< const int > getROFrameClusters(int layerId) const
std::pmr::memory_resource * getMaybeFrameworkHostResource(bool forceHost=false)
std::array< bounded_vector< int >, NLayers > mClusterExternalIndices
auto & getCellsLabel(int layer)
std::shared_ptr< BoundedMemoryResource > mMemoryPool
float getMinR(int layer) const
const auto & getROFOverlapTableView() const
gsl::span< Cluster > getClustersOnLayer(int rofId, int layerId)
IndexTableUtilsN mIndexTableUtils
std::array< bounded_vector< int >, NLayers > mROFramesClusters
const auto & getROFVertexLookupTable() const
void setNLinesTotal(uint32_t a) noexcept
void addClusterToLayer(int layer, T &&... args)
unsigned long getArtefactsMemory() const
ROFOverlapTable< NLayers > ROFOverlapTableN
float getMaxR(int layer) const
gsl::span< const MCCompLabel > getClusterLabels(int layerId, const Cluster &cl) const
std::array< bounded_vector< Cluster >, NLayers > mClusters
std::vector< bounded_vector< int > > mCellsLookupTable
bool isBeamPositionOverridden
auto & getPrimaryVerticesLabels()
gsl::span< const Vertex > getPrimaryVertices(int layer, int rofId) const
void setIsStaggered(bool b) noexcept
staggering
int getNLinesTotal() const noexcept
auto & getTrackletClusters(int rofId)
bool isClusterUsed(int layer, int clusterId) const
bounded_vector< Vertex > mPrimaryVertices
keep track of clusters with wild coordinates
void setROFOverlapTable(ROFOverlapTableN table)
gsl::span< int > getExclusiveNTrackletsCluster(int rofId, int combId)
void setMultiplicityCutMask(ROFMaskTableN cutMask)
bounded_vector< std::array< float, 2 > > mPValphaX
auto & getTrackletsLookupTable()
ROFVertexLookupTableN mROFVertexLookupTable
ROFMaskTable< NLayers > ROFMaskTableN
int getClusterExternalIndex(int layerId, const int clId) const
std::array< float, NLayers > mMinR
const auto & getROFOverlapTable() const
int & getNTrackletsROF(int rofId, int combId)
gsl::span< int > getNTrackletsCluster(int rofId, int combId)
auto & getCellsNeighboursLUT()
std::array< bounded_vector< int >, 2 > mNTrackletsPerCluster
std::vector< Cluster > clusters