16#ifndef TRACKINGITSU_INCLUDE_ROFRAME_H_
17#define TRACKINGITSU_INCLUDE_ROFRAME_H_
42 ROframe(
int ROframeId,
int nLayers);
61 const gsl::span<const o2::MCCompLabel>
getClusterLabels(
int layerId,
const int clId)
const;
64 std::vector<int>
getTracksId(
const int layerId,
const std::vector<Cluster>& cl);
66 template <
typename... T>
68 template <
typename... T>
79 std::vector<float3> mPrimaryVertices;
80 std::vector<std::vector<Cluster>> mClusters;
81 std::vector<std::vector<TrackingFrameInfo>> mTrackingFrameInfo;
82 std::vector<std::vector<int>> mClusterExternalIndices;
95 return mClusters[layerId];
100 return mTrackingFrameInfo[layerId];
105 return mTrackingFrameInfo[layerId][cl.
clusterId];
130 return mClusterExternalIndices[layerId][clId];
135 std::vector<int> tracksId;
136 for (
auto& cluster : cl) {
142template <
typename... T>
145 mClusters[
layer].emplace_back(std::forward<T>(
values)...);
148template <
typename... T>
151 mTrackingFrameInfo[
layer].emplace_back(std::forward<T>(
values)...);
161 mClusterExternalIndices[
layer].push_back(idx);
166 for (
unsigned int iL = 0; iL < mClusters.size(); ++iL) {
167 mClusters[iL].clear();
168 mTrackingFrameInfo[iL].clear();
170 mClusterExternalIndices[iL].clear();
172 mPrimaryVertices.clear();
Definition of a container to keep Monte Carlo truth external to simulation objects.
int getPrimaryVerticesNum() const
void addTrackingFrameInfoToLayer(int layer, T &&... args)
bool hasMCinformation() const
int getClusterExternalIndex(int layerId, const int clId) const
const gsl::span< const o2::MCCompLabel > getClusterLabels(int layerId, const int clId) const
void addPrimaryReconstructedVertex(const float, const float, const float)
const TrackingFrameInfo & getClusterTrackingFrameInfo(int layerId, const Cluster &cl) const
const MCCompLabel & getClusterFirstLabel(int layerId, const Cluster &cl) const
const std::vector< TrackingFrameInfo > & getTrackingFrameInfoOnLayer(int layerId) const
int getTotalClusters() const
void addPrimaryVertex(const float, const float, const float)
void addClusterExternalIndexToLayer(int layer, const int idx)
void addClusterToLayer(int layer, T &&... args)
void addPrimaryVertices(std::vector< Vertex > vertices)
std::vector< int > getTracksId(const int layerId, const std::vector< Cluster > &cl)
const float3 & getPrimaryVertex(const int) const
void setMClabelsContainer(const dataformats::MCTruthContainer< MCCompLabel > *ptr)
const std::vector< Cluster > & getClustersOnLayer(int layerId) const
void printPrimaryVertices() const
const auto & getClusters() const
const auto & getTrackingFrameInfo() const
GLenum GLsizei GLsizei GLint * values
GLenum GLuint GLint GLint layer
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...