Project
Loading...
Searching...
No Matches
TrackCosmicsReaderSpec.cxx
Go to the documentation of this file.
1// Copyright 2019-2020 CERN and copyright holders of ALICE O2.
2// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders.
3// All rights not expressly granted are reserved.
4//
5// This software is distributed under the terms of the GNU General Public
6// License v3 (GPL Version 3), copied verbatim in the file "COPYING".
7//
8// In applying this license CERN does not waive the privileges and immunities
9// granted to it by virtue of its status as an Intergovernmental Organization
10// or submit itself to any jurisdiction.
11
13
14#include <vector>
15
22
23using namespace o2::framework;
24using namespace o2::globaltracking;
25
26namespace o2
27{
28namespace globaltracking
29{
31{
32 mFileName = o2::utils::Str::concat_string(o2::utils::Str::rectifyDirectory(ic.options().get<std::string>("input-dir")),
33 ic.options().get<std::string>("cosmics-infile"));
34 connectTree(mFileName);
35}
36
38{
39 auto ent = mTree->GetReadEntry() + 1;
40 assert(ent < mTree->GetEntries()); // this should not happen
41 mTree->GetEntry(ent);
42 LOG(info) << "Pushing " << mTracks.size() << " Cosmic Tracks at entry " << ent;
43
44 pc.outputs().snapshot(Output{"GLO", "COSMICTRC", 0}, mTracks);
45 if (mUseMC) {
46 pc.outputs().snapshot(Output{"GLO", "COSMICTRC_MC", 0}, mLabels);
47 }
48
49 if (mTree->GetReadEntry() + 1 >= mTree->GetEntries()) {
51 pc.services().get<ControlService>().readyToQuit(QuitRequest::Me);
52 }
53}
54
55void TrackCosmicsReader::connectTree(const std::string& filename)
56{
57 mTree.reset(nullptr); // in case it was already loaded
58 mFile.reset(TFile::Open(filename.c_str()));
59 assert(mFile && !mFile->IsZombie());
60 mTree.reset((TTree*)mFile->Get("cosmics"));
61 assert(mTree);
62 mTree->SetBranchAddress("tracks", &mTracksPtr);
63 if (mUseMC) {
64 mTree->SetBranchAddress("MCTruth", &mLabelsPtr);
65 }
66 LOG(info) << "Loaded tree from " << filename << " with " << mTree->GetEntries() << " entries";
67}
68
70{
71 std::vector<OutputSpec> outputs;
72 outputs.emplace_back("GLO", "COSMICTRC", 0, Lifetime::Timeframe);
73 if (useMC) {
74 outputs.emplace_back("GLO", "COSMICTRC_MC", 0, Lifetime::Timeframe);
75 }
76
77 return DataProcessorSpec{
78 "cosmic-track-reader",
79 Inputs{},
80 outputs,
81 AlgorithmSpec{adaptFromTask<TrackCosmicsReader>(useMC)},
82 Options{
83 {"cosmics-infile", VariantType::String, "cosmics.root", {"Name of the input file"}},
84 {"input-dir", VariantType::String, "none", {"Input directory"}}}};
85}
86
87} // namespace globaltracking
88} // namespace o2
Header of the General Run Parameters object.
Definition of the Names Generator class.
Type wrappers for enfording a specific serialization method.
void snapshot(const Output &spec, T const &object)
ConfigParamRegistry const & options()
Definition InitContext.h:33
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.
Definition Task.h:43
void run(ProcessingContext &pc) final
Defining PrimaryVertex explicitly as messageable.
Definition TFIDInfo.h:20
std::vector< ConfigParamSpec > Options
std::vector< InputSpec > Inputs
framework::DataProcessorSpec getTrackCosmicsReaderSpec(bool useMC)
create a processor spec to read cosmic tracks from a root file
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...
std::string filename()
static std::string rectifyDirectory(const std::string_view p)
static std::string concat_string(Ts const &... ts)
LOG(info)<< "Compressed in "<< sw.CpuTime()<< " s"