53 auto ent =
mTree->GetReadEntry() + 1;
54 assert(ent < mTree->GetEntries());
71 std::vector<o2::itsmft::PhysTrigger> dummyTrig;
74 if (
mTree->GetReadEntry() + 1 >=
mTree->GetEntries()) {
99 LOG(info) <<
"MC-truth is missing";
103 LOG(info) <<
"Loaded tree from " <<
filename <<
" with " <<
mTree->GetEntries() <<
" entries";
108 std::vector<OutputSpec> outputSpec;
109 outputSpec.emplace_back(
"ITS",
"CLUSTERSROF", 0, Lifetime::Timeframe);
110 outputSpec.emplace_back(
"ITS",
"COMPCLUSTERS", 0, Lifetime::Timeframe);
112 outputSpec.emplace_back(
"ITS",
"PATTERNS", 0, Lifetime::Timeframe);
115 outputSpec.emplace_back(
"ITS",
"CLUSTERSMCTR", 0, Lifetime::Timeframe);
116 outputSpec.emplace_back(
"ITS",
"CLUSTERSMC2ROF", 0, Lifetime::Timeframe);
119 outputSpec.emplace_back(
"ITS",
"PHYSTRIG", 0, Lifetime::Timeframe);
122 "its-cluster-reader",
125 AlgorithmSpec{adaptFromTask<ITSClusterReader>(useMC, usePatterns, triggerOut)},
127 {
"its-cluster-infile", VariantType::String,
"o2clus_its.root", {
"Name of the input cluster file"}},
128 {
"input-dir", VariantType::String,
"none", {
"Input directory"}}}};
133 std::vector<OutputSpec> outputSpec;
134 outputSpec.emplace_back(
"MFT",
"CLUSTERSROF", 0, Lifetime::Timeframe);
135 outputSpec.emplace_back(
"MFT",
"COMPCLUSTERS", 0, Lifetime::Timeframe);
137 outputSpec.emplace_back(
"MFT",
"PATTERNS", 0, Lifetime::Timeframe);
140 outputSpec.emplace_back(
"MFT",
"CLUSTERSMCTR", 0, Lifetime::Timeframe);
141 outputSpec.emplace_back(
"MFT",
"CLUSTERSMC2ROF", 0, Lifetime::Timeframe);
144 outputSpec.emplace_back(
"MFT",
"PHYSTRIG", 0, Lifetime::Timeframe);
147 "mft-cluster-reader",
150 AlgorithmSpec{adaptFromTask<MFTClusterReader>(useMC, usePatterns, triggerOut)},
152 {
"mft-cluster-infile", VariantType::String,
"mftclusters.root", {
"Name of the input cluster file"}},
153 {
"input-dir", VariantType::String,
"none", {
"Input directory"}}}};
Definition of the Names Generator class.
Definition Physics trigger record extracted from the ITS/MFT stream.
Static class with identifiers, bitmasks and names for ALICE detectors.
T get(const char *key) const
void snapshot(const Output &spec, T const &object)
ConfigParamRegistry const & options()
DataAllocator & outputs()
The data allocator is used to allocate memory for the output data.
ServiceRegistryRef services()
The services registry associated with this processing context.
virtual void endOfStream(EndOfStreamContext &context)
This is invoked whenever we have an EndOfStream event.
o2::dataformats::MCTruthContainer< o2::MCCompLabel > * mClusterMCTruthPtr
std::vector< unsigned char > * mPatternsArrayPtr
std::string mClusterCompBranchName
std::unique_ptr< TFile > mFile
std::string mClustMC2ROFBranchName
std::string mClustMCTruthBranchName
std::string mClusterPattBranchName
void init(InitContext &ic) final
o2::dataformats::MCTruthContainer< o2::MCCompLabel > mClusterMCTruth
o2::header::DataOrigin mOrigin
std::vector< o2::itsmft::ROFRecord > mClusROFRec
std::string mClusROFBranchName
void run(ProcessingContext &pc) final
std::vector< unsigned char > mPatternsArray
std::vector< o2::itsmft::MC2ROFRecord > * mClusMC2ROFsPtr
std::vector< o2::itsmft::MC2ROFRecord > mClusMC2ROFs
std::vector< o2::itsmft::CompClusterExt > mClusterCompArray
std::vector< o2::itsmft::ROFRecord > * mClusROFRecPtr
std::vector< o2::itsmft::CompClusterExt > * mClusterCompArrayPtr
void connectTree(const std::string &filename)
std::unique_ptr< TTree > mTree
std::string mClusTreeName
Defining PrimaryVertex explicitly as messageable.
std::vector< ConfigParamSpec > Options
std::vector< InputSpec > Inputs
framework::DataProcessorSpec getMFTClusterReaderSpec(bool useMC=true, bool usePatterns=true, bool useTriggers=true)
framework::DataProcessorSpec getITSClusterReaderSpec(bool useMC=true, bool usePatterns=true, bool useTriggers=true)
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...
static std::string rectifyDirectory(const std::string_view p)
static std::string concat_string(Ts const &... ts)
LOG(info)<< "Compressed in "<< sw.CpuTime()<< " s"