35 assert(
id == o2::detectors::DetID::TRK);
59 auto ent =
mTree->GetReadEntry() + 1;
60 assert(ent < mTree->GetEntries());
68 <<
mDigits.size() <<
" digits at entry " << ent;
85 if (
mTree->GetReadEntry() + 1 >=
mTree->GetEntries()) {
103 throw std::runtime_error(
"GBT calibration data requested but not found in the tree");
109 throw std::runtime_error(
"MC data requested but not found in the tree");
113 LOG(info) <<
"Loaded tree from " <<
filename <<
" with " <<
mTree->GetEntries() <<
" entries";
118 std::vector<OutputSpec> outputSpec;
119 outputSpec.emplace_back(
"TRK",
"DIGITS", 0, Lifetime::Timeframe);
120 outputSpec.emplace_back(
"TRK",
"DIGITSROF", 0, Lifetime::Timeframe);
122 outputSpec.emplace_back(
"TRK",
"GBTCALIB", 0, Lifetime::Timeframe);
125 outputSpec.emplace_back(
"TRK",
"DIGITSMCTR", 0, Lifetime::Timeframe);
126 outputSpec.emplace_back(
"TRK",
"DIGITSMC2ROF", 0, Lifetime::Timeframe);
133 AlgorithmSpec{adaptFromTask<TRKDigitReader>(useMC, useCalib)},
135 {
"trk-digit-infile", VariantType::String, defname, {
"Name of the input digit file"}}}};
A const (ready only) version of MCTruthContainer.
A special IO container - splitting a given vector to enable ROOT IO.
Static class with identifiers, bitmasks and names for ALICE detectors.
T get(const char *key) const
void snapshot(const Output &spec, T const &object)
decltype(auto) make(const Output &spec, Args... args)
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.
std::string mDigtMC2ROFBranchName
void run(ProcessingContext &pc) final
std::vector< o2::itsmft::MC2ROFRecord > * mDigMC2ROFsPtr
std::unique_ptr< TTree > mTree
std::vector< o2::itsmft::ROFRecord > * mDigROFRecPtr
std::vector< o2::itsmft::Digit > * mDigitsPtr
std::string mDigtMCTruthBranchName
std::vector< o2::itsmft::Digit > mDigits
o2::header::DataOrigin mOrigin
std::string mDigitBranchName
std::vector< o2::itsmft::GBTCalibData > * mCalibPtr
std::string mCalibBranchName
std::unique_ptr< TFile > mFile
void init(InitContext &ic) final
std::vector< o2::itsmft::ROFRecord > mDigROFRec
std::string mDigROFBranchName
std::vector< o2::itsmft::GBTCalibData > mCalib
void connectTree(const std::string &filename)
std::vector< o2::itsmft::MC2ROFRecord > mDigMC2ROFs
Defining PrimaryVertex explicitly as messageable.
std::vector< ConfigParamSpec > Options
std::vector< InputSpec > Inputs
framework::DataProcessorSpec getTRKDigitReaderSpec(bool useMC=true, bool useCalib=false, std::string defname="trkdigits.root")
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...
LOG(info)<< "Compressed in "<< sw.CpuTime()<< " s"