Belle II Software  release-08-01-10
RootMergeable< T > Class Template Reference

Wrap a root histogram or TNtuple to make it mergeable. More...

#include <RootMergeable.h>

Inheritance diagram for RootMergeable< T >:
Collaboration diagram for RootMergeable< T >:

Public Member Functions

 RootMergeable ()
 default constructor for root.
 
template<class ... Args>
 RootMergeable (Args &&... params)
 Constructor, forwards all arguments to T constructor.
 
void assign (T *p)
 Replace wrapped object with p (takes ownership).
 
T & get ()
 Get the wrapped root object.
 
const T & get () const
 Get the wrapped root object.
 
void write (TDirectory *file)
 Write the wrapped object into 'file', overwriting existing objects of same name. More...
 
virtual void merge (const Mergeable *other) override
 Merge object 'other' into this one. More...
 
virtual void clear () override
 Clear content of this object (e.g. More...
 
virtual void removeSideEffects () override
 An ugly little method that is called before event() for input and worker processes. More...
 
virtual void RecursiveRemove (TObject *obj) override
 Called from ROOT if obj is deleted. More...
 
virtual Long64_t Merge (TCollection *hlist)
 Allow merging using TFileMerger if saved directly to a file. More...
 
virtual void Reset ()
 Root-like Reset function for "template compatibility" with ROOT objects. More...
 
virtual void SetDirectory (TDirectory *)
 Root-like SetDirectory function for "template compatibility" with ROOT objects. More...
 

Private Member Functions

 ClassDefOverride (RootMergeable, 2)
 Wrap a root histogram or ntuple to make them mergeable.
 
 ClassDef (Mergeable, 0)
 Abstract base class for objects that can be merged.
 

Private Attributes

T * m_wrapped
 Wrapped root object.
 

Detailed Description

template<class T>
class Belle2::RootMergeable< T >

Wrap a root histogram or TNtuple to make it mergeable.

To use it to save data in your module:

setPropertyFlags(c_ParallelProcessingCertified | c_TerminateInAllProcesses);

create RootMergeable<X> in initalize (or in your constructor) of durability DataStore::c_Persistent, register it by calling registerInDataStore() and construct() the actual histogram. Especially for larger TTrees, you should also create a TFile and cd() into it before creating the histogram. To actually save the objects, use the following in terminate() to ensure this is done only in the output process (where the data from all events will be collected):

//use TFile you created in initialize()
mergeablePtr->write(m_file);
}
static bool isOutputProcess()
Return true if the process is an output process.
Definition: ProcHandler.cc:232
static bool parallelProcessingUsed()
Returns true if multiple processes have been spawned, false in single-core mode.
Definition: ProcHandler.cc:226

This should work out of the box for TTree, TNtuple, TH1F, TH2F, TH1D, and TH2D. Additional template instantiations need an entry in framework/pcore/include/linkdef.h, please contact the framework librarian if your use case requires other classes.

Be aware that for larger histograms, this way of sharing the data may not be a good idea. E.g. for hundred thousand bins, basf2 would transfer about half a megabyte in each event, which may take a significant fraction of total processing time. Trees or Ntuples will however only transfer the newly added data, which is probably manageable.

To deal with ownership issues arising from objects belonging to TFiles, each RootMergeable object is added to the global list gROOT->GetListOfCleanups(), which will ensure RootMergeable::RecursiveRemove() is called when m_wrapped is deleted.

See also
Mergeable

Definition at line 61 of file RootMergeable.h.

Member Function Documentation

◆ clear()

virtual void clear ( void  )
inlineoverridevirtual

Clear content of this object (e.g.

set to zeroes).

Called after sending the objects to another process. If no clearing is performed, the same data (e.g. histogram entries) might be added again and again in each event.

Implements Mergeable.

Definition at line 130 of file RootMergeable.h.

131  {
132  m_wrapped->Reset();
133  }
T * m_wrapped
Wrapped root object.

◆ merge()

virtual void merge ( const Mergeable other)
inlineoverridevirtual

Merge object 'other' into this one.

Your derived class should implement this function. You can static_cast 'other' to your own type (when called, this and other are guaranteed to point to objects of the same type).

Note that 'other' will be deleted after the merge, so make sure you copy all data from it that you will need.

Implements Mergeable.

Definition at line 115 of file RootMergeable.h.

◆ Merge()

Long64_t Merge ( TCollection *  hlist)
virtualinherited

Allow merging using TFileMerger if saved directly to a file.

Note
dictionaries containing your Mergeable class need to be loaded, so 'hadd' will not work currently.

Definition at line 14 of file Mergeable.cc.

◆ RecursiveRemove()

virtual void RecursiveRemove ( TObject *  obj)
inlineoverridevirtual

Called from ROOT if obj is deleted.

Kill pointer to avoid double free.

Definition at line 150 of file RootMergeable.h.

◆ removeSideEffects()

virtual void removeSideEffects ( )
inlineoverridevirtual

An ugly little method that is called before event() for input and worker processes.

Main use case is to detach any attached TFile from this object. In the output process, it can stay attached (and grow as much as it likes).

Reimplemented from Mergeable.

Definition at line 140 of file RootMergeable.h.

◆ Reset()

virtual void Reset ( )
inlinevirtualinherited

Root-like Reset function for "template compatibility" with ROOT objects.

Alias for clear().

Definition at line 66 of file Mergeable.h.

◆ SetDirectory()

virtual void SetDirectory ( TDirectory *  )
inlinevirtualinherited

Root-like SetDirectory function for "template compatibility" with ROOT objects.

Does nothing.

Definition at line 68 of file Mergeable.h.

◆ write()

void write ( TDirectory *  file)
inline

Write the wrapped object into 'file', overwriting existing objects of same name.

This function should be prefered to calling Write() by hand.

Note
wrapped object must already be in 'file' before filled, or not part of any file at all. This function will throw an error and might crash if this is not the case.

Definition at line 98 of file RootMergeable.h.


The documentation for this class was generated from the following file: