ROOT 6.10/09 Reference Guide |
A class to process the entries of a TTree in parallel.
By means of its Process method, ROOT::TTreeProcessorMT provides a way to process the entries of a TTree in parallel. When invoking TTreeProcessor::Process, the user passes a function whose only parameter is a TTreeReader. The function iterates on a subrange of entries by using that TTreeReader.
The implementation of ROOT::TTreeProcessorMT parallelizes the processing of the subranges, each corresponding to a cluster in the TTree. This is possible thanks to the use of a ROOT::TThreadedObject, so that each thread works with its own TFile and TTree objects.
Definition at line 273 of file TTreeProcessorMT.hxx.
Public Member Functions | |
TTreeProcessorMT (std::string_view filename, std::string_view treename="") | |
Constructor based on a file name. More... | |
TTreeProcessorMT (const std::vector< std::string_view > &filenames, std::string_view treename="") | |
Constructor based on a collection of file names. More... | |
TTreeProcessorMT (TTree &tree) | |
Constructor based on a TTree. More... | |
TTreeProcessorMT (TTree &tree, TEntryList &entries) | |
Constructor based on a TTree and a TEntryList. More... | |
void | Process (std::function< void(TTreeReader &)> func) |
Process the entries of a TTree in parallel. More... | |
Private Attributes | |
ROOT::TThreadedObject< ROOT::Internal::TTreeView > | treeView |
! Threaded object with <file,tree> per thread More... | |
#include <ROOT/TTreeProcessorMT.hxx>
TTreeProcessorMT::TTreeProcessorMT | ( | std::string_view | filename, |
std::string_view | treename = "" |
||
) |
Constructor based on a file name.
[in] | filename | Name of the file containing the tree to process. |
[in] | treename | Name of the tree to process. If not provided, the implementation will automatically search for a tree in the file. |
Definition at line 38 of file TTreeProcessorMT.cxx.
TTreeProcessorMT::TTreeProcessorMT | ( | const std::vector< std::string_view > & | filenames, |
std::string_view | treename = "" |
||
) |
Constructor based on a collection of file names.
[in] | filenames | Collection of the names of the files containing the tree to process. |
[in] | treename | Name of the tree to process. If not provided, the implementation will automatically search for a tree in the collection of files. |
Definition at line 46 of file TTreeProcessorMT.cxx.
TTreeProcessorMT::TTreeProcessorMT | ( | TTree & | tree | ) |
Constructor based on a TTree.
[in] | tree | Tree or chain of files containing the tree to process. |
Definition at line 51 of file TTreeProcessorMT.cxx.
TTreeProcessorMT::TTreeProcessorMT | ( | TTree & | tree, |
TEntryList & | entries | ||
) |
Constructor based on a TTree and a TEntryList.
[in] | tree | Tree or chain of files containing the tree to process. |
[in] | entries | List of entry numbers to process. |
Definition at line 57 of file TTreeProcessorMT.cxx.
void TTreeProcessorMT::Process | ( | std::function< void(TTreeReader &)> | func | ) |
Process the entries of a TTree in parallel.
The user-provided function receives a TTreeReader which can be used to iterate on a subrange of entries
The user needs to be aware that each of the subranges can potentially be processed in parallel. This means that the code of the user function should be thread safe.
[in] | func | User-defined function that processes a subrange of entries |
Definition at line 76 of file TTreeProcessorMT.cxx.
|
private |
! Threaded object with <file,tree> per thread
Definition at line 275 of file TTreeProcessorMT.hxx.