18#include "fairlogger/Logger.h"
31 LOG(info) <<
"Init TRD PH reader!";
33 ic.
options().
get<std::string>(
"trd-ph-infile"));
39void TRDPHReader::connectTree()
42 mFile.reset(TFile::Open(mInFileName.c_str()));
43 assert(mFile && !mFile->IsZombie());
44 mTree.reset((TTree*)mFile->Get(mInTreeName.c_str()));
46 mTree->SetBranchAddress(
"values", &mPHValuesPtr);
47 LOG(info) <<
"Loaded tree from " << mInFileName <<
" with " << mTree->GetEntries() <<
" entries";
52 auto currEntry = mTree->GetReadEntry() + 1;
53 assert(currEntry < mTree->GetEntries());
54 mTree->GetEntry(currEntry);
56 LOG(info) <<
"Pushing vector of PH values filled with " << mPHValues.size() <<
" entries at tree entry " << currEntry;
59 if (mTree->GetReadEntry() + 1 >= mTree->GetEntries()) {
67 std::vector<OutputSpec> outputs;
76 {
"trd-ph-infile", VariantType::String,
"trd_PH.root", {
"Name of the input file"}},
77 {
"input-dir", VariantType::String,
"none", {
"Input directory"}},
78 {
"treename", VariantType::String,
"ph", {
"Name of top-level TTree"}},
Definition of the Names Generator class.
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.
void run(o2::framework::ProcessingContext &pc) final
void init(o2::framework::InitContext &ic) final
constexpr o2::header::DataOrigin gDataOriginTRD
Defining PrimaryVertex explicitly as messageable.
std::vector< ConfigParamSpec > Options
std::vector< InputSpec > Inputs
framework::DataProcessorSpec getTRDPHReaderSpec()
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"