11#ifndef ROOT_RVARIEDACTION
12#define ROOT_RVARIEDACTION
37template <
typename Helper,
typename PrevNode,
typename ColumnTypes_t>
39 using TypeInd_t = std::make_index_sequence<ColumnTypes_t::list_size>;
49 std::vector<std::vector<std::array<std::unique_ptr<RColumnReaderBase>, ColumnTypes_t::list_size>>>
fInputValues;
52 std::array<bool, ColumnTypes_t::list_size>
fIsDefine;
54 std::vector<std::shared_ptr<PrevNodeType>>
MakePrevFilters(std::shared_ptr<PrevNode> nominal)
const
56 const auto &variations = GetVariations();
57 std::vector<std::shared_ptr<PrevNodeType>> prevFilters;
58 prevFilters.reserve(variations.size());
59 if (
static_cast<RNodeBase *
>(nominal.get()) == fLoopManager) {
61 prevFilters.resize(variations.size(), nominal);
64 const auto &prevVariations = nominal->GetVariations();
65 for (
const auto &variation : variations) {
67 prevFilters.emplace_back(std::static_pointer_cast<PrevNodeType>(nominal->GetVariedFilter(variation)));
69 prevFilters.emplace_back(nominal);
80 :
RActionBase(prevNode->GetLoopManagerUnchecked(), columns, colRegister, prevNode->GetVariations()),
81 fHelpers(std::move(helpers)), fPrevNodes(MakePrevFilters(prevNode)), fInputValues(
GetNSlots())
83 fLoopManager->Book(
this);
85 const auto &defines = colRegister.
GetColumns();
86 for (
auto i = 0u; i < columns.size(); ++i) {
87 auto it = defines.find(columns[i]);
88 fIsDefine[i] = it != defines.end();
90 (it->second)->MakeVariations(GetVariations());
100 RActionBase::GetColRegister().Clear();
101 fLoopManager->Deregister(
this);
106 std::for_each(fHelpers.begin(), fHelpers.end(), [](
Helper &
h) { h.Initialize(); });
112 fLoopManager->GetDSValuePtrs(), fLoopManager->GetDataSource()};
115 for (
const auto &variation : GetVariations())
116 fInputValues[slot].emplace_back(
MakeColumnReaders(slot,
r, ColumnTypes_t{}, info, variation));
118 std::for_each(fHelpers.begin(), fHelpers.end(), [=](
Helper &
h) { h.InitTask(r, slot); });
121 template <
typename... ColTypes, std::size_t... S>
125 fHelpers[varIdx].Exec(slot, fInputValues[slot][varIdx][S]->
template Get<ColTypes>(entry)...);
131 for (
auto varIdx = 0u; varIdx < GetVariations().size(); ++varIdx) {
132 if (fPrevNodes[varIdx]->CheckFilters(slot, entry))
133 CallExec(slot, varIdx, entry, ColumnTypes_t{},
TypeInd_t{});
139 std::for_each(fPrevNodes.begin(), fPrevNodes.end(), [](
auto &
f) { f->IncrChildrenCount(); });
145 fInputValues[slot].clear();
146 std::for_each(fHelpers.begin(), fHelpers.end(), [=](
Helper &
h) { h.CallFinalizeTask(slot); });
153 std::for_each(fHelpers.begin(), fHelpers.end(), [](
Helper &
h) { h.Finalize(); });
158 void *
PartialUpdate(
unsigned int slot)
final {
return PartialUpdateImpl(slot); }
163 std::shared_ptr<ROOT::Internal::RDF::GraphDrawing::GraphNode>
GetGraph() final
165 auto prevNode = fPrevNodes[0]->GetGraph();
166 auto prevColumns = prevNode->GetDefinedColumns();
169 auto thisNode = std::make_shared<RDFGraphDrawing::GraphNode>(
"Varied " + fHelpers[0].GetActionName());
171 auto upmostNode = AddDefinesToGraph(thisNode, GetColRegister(), prevColumns);
173 thisNode->AddDefinedColumns(GetColRegister().GetNames());
174 thisNode->SetAction(HasRun());
175 upmostNode->SetPrevNode(prevNode);
181 throw std::logic_error(
"Varied actions cannot provide mergeable values");
186 throw std::logic_error(
"Cannot produce a varied action from a varied action.");
192 template <
typename H = Helper>
193 auto PartialUpdateImpl(
unsigned int slot) ->
decltype(std::declval<H>().PartialUpdate(slot), (
void *)(
nullptr))
195 return &fHelpers[0].PartialUpdate(slot);
199 void *
PartialUpdateImpl(...) {
throw std::runtime_error(
"This action does not support callbacks!"); }
typedef void(GLAPIENTRYP _GLUfuncptr)(void)
Base class for non-leaf nodes of the computational graph.
A binder for user-defined columns and aliases.
const DefinesMap_t & GetColumns() const
Returns a map of pointers to the defined columns.
Just like an RAction, but it has N action helpers (one per variation + nominal) and N previous nodes.
void Finalize() final
Clean-up and finalize the action result (e.g.
void Run(unsigned int slot, Long64_t entry) final
std::vector< std::shared_ptr< PrevNodeType > > fPrevNodes
Owning pointers to upstream nodes for each systematic variation (with the "nominal" at index 0).
RVariedAction(std::vector< Helper > &&helpers, const ColumnNames_t &columns, std::shared_ptr< PrevNode > prevNode, const RColumnRegister &colRegister)
void CallExec(unsigned int slot, unsigned int varIdx, Long64_t entry, TypeList< ColTypes... >, std::index_sequence< S... >)
auto PartialUpdateImpl(unsigned int slot) -> decltype(std::declval< H >().PartialUpdate(slot),(void *)(nullptr))
ROOT::RDF::SampleCallback_t GetSampleCallback() final
Return the per-sample callback connected to the nominal result.
void FinalizeSlot(unsigned int slot) final
Clean-up operations to be performed at the end of a task.
std::vector< std::shared_ptr< PrevNodeType > > MakePrevFilters(std::shared_ptr< PrevNode > nominal) const
std::make_index_sequence< ColumnTypes_t::list_size > TypeInd_t
std::unique_ptr< RActionBase > MakeVariedAction(std::vector< void * > &&)
std::vector< Helper > fHelpers
Action helpers per variation.
void * PartialUpdateImpl(...)
RVariedAction & operator=(const RVariedAction &)=delete
void InitSlot(TTreeReader *r, unsigned int slot) final
std::unique_ptr< RMergeableValueBase > GetMergeableValue() const
Retrieve a wrapper to the result of the action that knows how to merge with others of the same type.
std::conditional_t< std::is_same< PrevNode, RJittedFilter >::value, RFilterBase, PrevNode > PrevNodeType
std::shared_ptr< ROOT::Internal::RDF::GraphDrawing::GraphNode > GetGraph() final
std::array< bool, ColumnTypes_t::list_size > fIsDefine
The nth flag signals whether the nth input column is a custom column or not.
std::vector< std::vector< std::array< std::unique_ptr< RColumnReaderBase >, ColumnTypes_t::list_size > > > fInputValues
Column readers per slot (outer dimension), per variation and per input column (inner dimension,...
void * PartialUpdate(unsigned int slot) final
Return the partially-updated value connected to the nominal result.
RVariedAction(const RVariedAction &)=delete
void TriggerChildrenCount() final
A simple, robust and fast interface to read values from ROOT columnar datasets such as TTree,...
bool IsStrInVec(const std::string &str, const std::vector< std::string > &vec)
std::array< std::unique_ptr< RDFDetail::RColumnReaderBase >, sizeof...(ColTypes)> MakeColumnReaders(unsigned int slot, TTreeReader *r, TypeList< ColTypes... >, const RColumnReadersInfo &colInfo, const std::string &variationName="nominal")
Create a group of column readers, one per type in the parameter pack.
std::vector< std::string > ColumnNames_t
std::function< void(unsigned int, const ROOT::RDF::RSampleInfo &)> SampleCallback_t
The type of a data-block callback, registered with a RDataFrame computation graph via e....
tbb::task_arena is an alias of tbb::interface7::task_arena, which doesn't allow to forward declare tb...
This type aggregates some of the arguments passed to MakeColumnReaders.
Lightweight storage for a collection of types.