Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
TTree.h
Go to the documentation of this file.
1// @(#)root/tree:$Id$
2// Author: Rene Brun 12/01/96
3
4/*************************************************************************
5 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
6 * All rights reserved. *
7 * *
8 * For the licensing terms see $ROOTSYS/LICENSE. *
9 * For the list of contributors see $ROOTSYS/README/CREDITS. *
10 *************************************************************************/
11
12#ifndef ROOT_TTree
13#define ROOT_TTree
14
15//////////////////////////////////////////////////////////////////////////
16// //
17// TTree //
18// //
19// A TTree object is a list of TBranch. //
20// To Create a TTree object one must: //
21// - Create the TTree header via the TTree constructor //
22// - Call the TBranch constructor for every branch. //
23// //
24// To Fill this object, use member function Fill with no parameters. //
25// The Fill function loops on all defined TBranch. //
26// //
27//////////////////////////////////////////////////////////////////////////
28
29#include "Compression.h"
30#include "ROOT/TIOFeatures.hxx"
31#include "TArrayD.h"
32#include "TArrayI.h"
33#include "TAttFill.h"
34#include "TAttLine.h"
35#include "TAttMarker.h"
36#include "TClass.h"
37#include "TDataType.h"
38#include "TDirectory.h"
39#include "TObjArray.h"
40#include "TVirtualTreePlayer.h"
41
42#ifdef R__LESS_INCLUDES
43class TBranch;
44class TList;
45#else
46#include "TBranch.h"
47// #include "TBuffer.h"
48#include "TList.h"
49#endif
50
51#include <array>
52#include <atomic>
53#include <vector>
54#include <utility>
55
56class TBuffer;
57class TBrowser;
58class TFile;
59class TLeaf;
60class TH1;
61class TTreeFormula;
62class TPolyMarker;
63class TEventList;
64class TEntryList;
65class TSQLResult;
66class TSelector;
67class TPrincipal;
68class TFriendElement;
69class TCut;
70class TVirtualIndex;
71class TBranchRef;
72class TBasket;
73class TStreamerInfo;
74class TTree;
75class TTreeCache;
76class TTreeCloner;
77class TFileMergeInfo;
79
82}
83
84class TTree : public TNamed, public TAttLine, public TAttFill, public TAttMarker {
85
87
88protected:
89 Long64_t fEntries; ///< Number of entries
90// NOTE: cannot use std::atomic for these counters as it cannot be serialized.
91 Long64_t fTotBytes; ///< Total number of bytes in all branches before compression
92 Long64_t fZipBytes; ///< Total number of bytes in all branches after compression
93 Long64_t fSavedBytes; ///< Number of autosaved bytes
94 Long64_t fFlushedBytes; ///< Number of auto-flushed bytes
95 Double_t fWeight; ///< Tree weight (see TTree::SetWeight)
96 Int_t fTimerInterval; ///< Timer interval in milliseconds
97 Int_t fScanField; ///< Number of runs before prompting in Scan
98 Int_t fUpdate; ///< Update frequency for EntryLoop
99 Int_t fDefaultEntryOffsetLen; ///< Initial Length of fEntryOffset table in the basket buffers
100 Int_t fNClusterRange; ///< Number of Cluster range in addition to the one defined by 'AutoFlush'
101 Int_t fMaxClusterRange; ///<! Memory allocated for the cluster range.
102 Long64_t fMaxEntries; ///< Maximum number of entries in case of circular buffers
103 Long64_t fMaxEntryLoop; ///< Maximum number of entries to process
104 Long64_t fMaxVirtualSize; ///< Maximum total size of buffers kept in memory
105 Long64_t fAutoSave; ///< Autosave tree when fAutoSave entries written or -fAutoSave (compressed) bytes produced
106 Long64_t fAutoFlush; ///< Auto-flush tree when fAutoFlush entries written or -fAutoFlush (compressed) bytes produced
107 Long64_t fEstimate; ///< Number of entries to estimate histogram limits
108 Long64_t *fClusterRangeEnd; ///<[fNClusterRange] Last entry of a cluster range.
109 Long64_t *fClusterSize; ///<[fNClusterRange] Number of entries in each cluster for a given range.
110 Long64_t fCacheSize; ///<! Maximum size of file buffers
111 Long64_t fChainOffset; ///<! Offset of 1st entry of this Tree in a TChain
112 Long64_t fReadEntry; ///<! Number of the entry being processed
113 std::atomic<Long64_t> fTotalBuffers; ///<! Total number of bytes in branch buffers
114 Int_t fPacketSize; ///<! Number of entries in one packet for parallel root
115 Int_t fNfill; ///<! Local for EntryLoop
116 Int_t fDebug; ///<! Debug level
117 Long64_t fDebugMin; ///<! First entry number to debug
118 Long64_t fDebugMax; ///<! Last entry number to debug
119 TIOFeatures fIOFeatures{0}; ///< IO features to define for newly-written baskets and branches.
120 Int_t fMakeClass; ///<! not zero when processing code generated by MakeClass
121 Int_t fFileNumber; ///<! current file number (if file extensions)
122 /// Object to be notified when loading a Tree.
123 /// TTree::LoadTree() and TChain::LoadTree() will call fNotify->Notify().
124 /// Usually points to a TNotifyLink if this is a TChain.
126 TDirectory *fDirectory; ///<! Pointer to directory holding this tree
127 TObjArray fBranches; ///< List of Branches
128 TObjArray fLeaves; ///< Direct pointers to individual branch leaves
129 TList *fAliases; ///< List of aliases for expressions based on the tree branches.
130 TEventList *fEventList; ///<! Pointer to event selection list (if one)
131 TEntryList *fEntryList; ///<! Pointer to event selection list (if one)
132 TArrayD fIndexValues; ///< Sorted index values
133 TArrayI fIndex; ///< Index of sorted values
134 TVirtualIndex *fTreeIndex; ///< Pointer to the tree Index (if any)
135 TList *fFriends; ///< pointer to list of friend elements
136 TList *fExternalFriends; ///<! List of TFriendsElement pointing to us and need to be notified of LoadTree. Content not owned.
137 TVirtualPerfStats *fPerfStats; ///<! pointer to the current perf stats object
138 TList *fUserInfo; ///< pointer to a list of user objects associated to this Tree
139 TVirtualTreePlayer *fPlayer; ///<! Pointer to current Tree player
140 TList *fClones; ///<! List of cloned trees which share our addresses
141 TBranchRef *fBranchRef; ///< Branch supporting the TRefTable (if any)
142 UInt_t fFriendLockStatus; ///<! Record which method is locking the friend recursion
143 TBuffer *fTransientBuffer; ///<! Pointer to the current transient buffer.
144 bool fCacheDoAutoInit; ///<! true if cache auto creation or resize check is needed
145 bool fCacheDoClusterPrefetch;///<! true if cache is prefetching whole clusters
146 bool fCacheUserSet; ///<! true if the cache setting was explicitly given by user
147 bool fIMTEnabled; ///<! true if implicit multi-threading is enabled for this tree
148 UInt_t fNEntriesSinceSorting; ///<! Number of entries processed since the last re-sorting of branches
149 std::vector<std::pair<Long64_t,TBranch*>> fSortedBranches; ///<! Branches to be processed in parallel when IMT is on, sorted by average task time
150 std::vector<TBranch*> fSeqBranches; ///<! Branches to be processed sequentially when IMT is on
151 Float_t fTargetMemoryRatio{1.1f}; ///<! Ratio for memory usage in uncompressed buffers versus actual occupancy. 1.0
152 /// indicates basket should be resized to exact memory usage, but causes significant
153/// memory churn.
154#ifdef R__TRACK_BASKET_ALLOC_TIME
155 mutable std::atomic<ULong64_t> fAllocationTime{0}; ///<! Time spent reallocating basket memory buffers, in microseconds.
156#endif
157 mutable std::atomic<UInt_t> fAllocationCount{0}; ///<! Number of reallocations basket memory buffers.
158
159 static Int_t fgBranchStyle; ///< Old/New branch style
160 static Long64_t fgMaxTreeSize; ///< Maximum size of a file containing a Tree
161
162private:
163 // For simplicity, although fIMTFlush is always disabled in non-IMT builds, we don't #ifdef it out.
164 mutable bool fIMTFlush{false}; ///<! True if we are doing a multithreaded flush.
165 mutable std::atomic<Long64_t> fIMTTotBytes; ///<! Total bytes for the IMT flush baskets
166 mutable std::atomic<Long64_t> fIMTZipBytes; ///<! Zip bytes for the IMT flush baskets.
167
168 std::unordered_map<std::string, TBranch *>
169 fNamesToBranches; ///<! maps names to their branches, useful when retrieving branches by name
170
172 void SortBranchesByTime();
173 Int_t FlushBasketsImpl() const;
174 void MarkEventCluster();
176
177 void RegisterBranchFullName(std::pair<std::string, TBranch *> &&kv) { fNamesToBranches.insert(kv); }
179
180protected:
181 virtual void KeepCircular();
182 virtual TBranch *BranchImp(const char* branchname, const char* classname, TClass* ptrClass, void* addobj, Int_t bufsize, Int_t splitlevel);
184 virtual TBranch *BranchImpRef(const char* branchname, const char* classname, TClass* ptrClass, void* addobj, Int_t bufsize, Int_t splitlevel);
186 virtual TBranch *BranchImpArr(const char* branchname, EDataType datatype, std::size_t N, void* addobj, Int_t bufsize, Int_t splitlevel);
188 virtual TBranch *BronchExec(const char* name, const char* classname, void* addobj, bool isptrptr, Int_t bufsize, Int_t splitlevel);
191 virtual TLeaf *GetLeafImpl(const char* branchname, const char* leafname);
192
194 char GetNewlineValue(std::istream &inputStream);
196 void MoveReadCache(TFile *src, TDirectory *dir);
197 Int_t SetCacheSizeAux(bool autocache = true, Long64_t cacheSize = 0);
198
200 // Helper class to prevent infinite recursion in the
201 // usage of TTree Friends. Implemented in TTree.cxx.
202 TTree *fTree; // Pointer to the locked tree
203 UInt_t fMethodBit; // BIT for the locked method
204 bool fPrevious; // Previous value of the BIT.
205
206 protected:
207 TFriendLock(const TFriendLock&);
209
210 public:
212 ~TFriendLock();
213 };
214 friend class TFriendLock;
215 // So that the index class can use TFriendLock:
216 friend class TTreeIndex;
217 friend class TChainIndex;
218 // So that the TTreeCloner can access the protected interfaces
219 friend class TTreeCloner;
220
221 // use to update fFriendLockStatus
238
239public:
240 // Used as the max value for any TTree range operation.
242
243 // SetBranchAddress return values
260
261 // TTree status bits
265 /// If set, the branch's buffers will grow until an event cluster boundary is hit,
266 /// guaranteeing a basket per cluster. This mode does not provide any guarantee on the
267 /// memory bounds in the case of extremely large events.
269 /// If set, signals that this TTree is the output of the processing of another TTree, and
270 /// the entries are reshuffled w.r.t. to the original TTree. As a safety measure, a TTree
271 /// with this bit set cannot add friends nor can be added as a friend. If you know what
272 /// you are doing, you can manually unset this bit with `ResetBit(EStatusBits::kEntriesReshuffled)`.
273 kEntriesReshuffled = BIT(19) // bits 15-18 are used by TChain
274 };
275
276 // Split level modifier
277 enum {
279 };
280
282 {
283 private:
284 TTree *fTree; // TTree upon which we are iterating.
285 Int_t fClusterRange; // Which cluster range are we looking at.
286 Long64_t fStartEntry; // Where does the cluster start.
287 Long64_t fNextEntry; // Where does the cluster end (exclusive).
288 Long64_t fEstimatedSize; // If positive, the calculated estimated tree size.
289
291
292 protected:
293 friend class TTree;
295
296 public:
297 // Intentionally used the default copy constructor and default destructor
298 // as the TClusterIterator does not own the TTree.
299 // TClusterIterator(const TClusterIterator&);
300 // ~TClusterIterator();
301
302 // No public constructors, the iterator must be
303 // created via TTree::GetClusterIterator
304
305 // Move on to the next cluster and return the starting entry
306 // of this next cluster
307 Long64_t Next();
308
309 // Move on to the previous cluster and return the starting entry
310 // of this previous cluster
312
313 // Return the start entry of the current cluster.
315 return fStartEntry;
316 }
317
318 // Return the first entry of the next cluster.
320 return fNextEntry;
321 }
322
323 Long64_t operator()() { return Next(); }
324 };
325
326 TTree();
327 TTree(const char* name, const char* title, Int_t splitlevel = 99, TDirectory* dir = gDirectory);
328 ~TTree() override;
329
330 TTree(const TTree& tt) = delete;
331 TTree& operator=(const TTree& tt) = delete;
332
333 virtual Int_t AddBranchToCache(const char *bname, bool subbranches = false);
334 virtual Int_t AddBranchToCache(TBranch *branch, bool subbranches = false);
335 virtual Int_t DropBranchFromCache(const char *bname, bool subbranches = false);
336 virtual Int_t DropBranchFromCache(TBranch *branch, bool subbranches = false);
337 void AddClone(TTree*);
338 virtual TFriendElement *AddFriend(const char* treename, const char* filename = "");
339 virtual TFriendElement *AddFriend(const char* treename, TFile* file);
340 virtual TFriendElement *AddFriend(TTree* tree, const char* alias = "", bool warn = false);
341 // As the TBasket invokes Add{Tot,Zip}Bytes on its parent tree, we must do these updates in a thread-safe
342 // manner only when we are flushing multiple baskets in parallel.
343 virtual void AddTotBytes(Int_t tot) { if (fIMTFlush) { fIMTTotBytes += tot; } else { fTotBytes += tot; } }
344 virtual void AddZipBytes(Int_t zip) { if (fIMTFlush) { fIMTZipBytes += zip; } else { fZipBytes += zip; } }
345// NOTE: these counters aren't thread safe like the ones above.
346#ifdef R__TRACK_BASKET_ALLOC_TIME
347 void AddAllocationTime(ULong64_t time) { fAllocationTime += time; }
348#endif
350 virtual Long64_t AutoSave(Option_t* option = "");
351
352 /// Add a new branch, and infer the data type from the type of `obj` being passed.
353 ///
354 /// \note This and the next overload should cover most cases for creating a branch. Try to use these two whenever
355 /// possible, unless e.g. type conversions are needed.
356 ///
357 /// \param[in] name Name of the branch to be created.
358 /// \param[in] obj Address of the object to be added. Make sure to pass a pointer to the actual type/class that
359 /// should be stored in the tree (no pointers to base classes). When calling Fill(), the current value of the type/object will be saved.
360 /// \param[in] bufsize The buffer size in bytes for this branch. When the buffer is full, it is compressed and written to disc.
361 /// The default value of 32000 bytes and should be ok for most simple types. Larger buffers (e.g. 256000) if your Tree is not split and each entry is large (Megabytes).
362 /// A small value for bufsize is beneficial if entries in the Tree are accessed randomly and the Tree is in split mode.
363 /// \param[in] splitlevel If T is a class or struct and splitlevel > 0, the members of the object are serialised as separate branches.
364 /// \return Pointer to the TBranch that was created. The branch is owned by the tree.
365 template <class T> TBranch *Branch(const char* name, T* obj, Int_t bufsize = 32000, Int_t splitlevel = 99)
366 {
367 return BranchImpRef(name, TClass::GetClass<T>(), TDataType::GetType(typeid(T)), obj, bufsize, splitlevel);
368 }
369
370 /// Add a new branch, and infer the data type from the array `addobj` being passed.
371 ///
372 /// \note This and the previous overload should cover most cases for creating a branch. Try to use these two whenever
373 /// possible, unless e.g. type conversions are needed.
374 ///
375 /// \param[in] name Name of the branch to be created.
376 /// \param[in] addobj Array of the objects to be added. When calling Fill(), the current value of the type/object will be saved.
377 /// \param[in] bufsize he buffer size in bytes for this branch. When the buffer is full, it is compressed and written to disc.
378 /// The default value of 32000 bytes and should be ok for most simple types. Larger buffers (e.g. 256000) if your Tree is not split and each entry is large (Megabytes).
379 /// A small value for bufsize is beneficial if entries in the Tree are accessed randomly and the Tree is in split mode.
380 /// \param[in] splitlevel If T is a class or struct and splitlevel > 0, the members of the object are serialised as separate branches.
381 /// \return Pointer to the TBranch that was created. The branch is owned by the tree.
382 template <class T> TBranch *Branch(const char* name, T** addobj, Int_t bufsize = 32000, Int_t splitlevel = 99)
383 {
384 return BranchImp(name, TClass::GetClass<T>(), addobj, bufsize, splitlevel);
385 }
386
387 virtual Int_t Branch(TCollection* list, Int_t bufsize = 32000, Int_t splitlevel = 99, const char* name = "");
388 virtual Int_t Branch(TList* list, Int_t bufsize = 32000, Int_t splitlevel = 99);
389 virtual Int_t Branch(const char* folder, Int_t bufsize = 32000, Int_t splitlevel = 99);
390 virtual TBranch *Branch(const char* name, void* address, const char* leaflist, Int_t bufsize = 32000);
391 TBranch *Branch(const char* name, char* address, const char* leaflist, Int_t bufsize = 32000)
392 {
393 // Overload to avoid confusion between this signature and the template instance.
394 return Branch(name,(void*)address,leaflist,bufsize);
395 }
396 TBranch *Branch(const char* name, Longptr_t address, const char* leaflist, Int_t bufsize = 32000)
397 {
398 // Overload to avoid confusion between this signature and the template instance.
399 return Branch(name,(void*)address,leaflist,bufsize);
400 }
401 TBranch *Branch(const char* name, int address, const char* leaflist, Int_t bufsize = 32000)
402 {
403 // Overload to avoid confusion between this signature and the template instance.
404 return Branch(name,(void*)(Longptr_t)address,leaflist,bufsize);
405 }
406 virtual TBranch *Branch(const char* name, const char* classname, void* addobj, Int_t bufsize = 32000, Int_t splitlevel = 99);
407 template <class T> TBranch *Branch(const char* name, const char* classname, T* obj, Int_t bufsize = 32000, Int_t splitlevel = 99)
408 {
409 // See BranchImpRed for details. Here we __ignore
410 return BranchImpRef(name, classname, TClass::GetClass<T>(), obj, bufsize, splitlevel);
411 }
412 template <class T> TBranch *Branch(const char* name, const char* classname, T** addobj, Int_t bufsize = 32000, Int_t splitlevel = 99)
413 {
414 // See BranchImp for details
415 return BranchImp(name, classname, TClass::GetClass<T>(), addobj, bufsize, splitlevel);
416 }
417 template <typename T, std::size_t N> TBranch *Branch(const char* name, std::array<T, N> *obj, Int_t bufsize = 32000, Int_t splitlevel = 99)
418 {
419 TClass *cl = TClass::GetClass<T>();
420 if (cl) {
421 TClass *arrCl = TClass::GetClass<std::array<T, N>>();
422 Error("Branch","std::array of objects not yet supported as top level branch object (the class is %s)",
423 arrCl ? arrCl->GetName() : cl->GetName());
424 return nullptr;
425 }
426 return BranchImpArr(name, TDataType::GetType(typeid(T)), N, obj, bufsize, splitlevel);
427 }
428 virtual TBranch *Bronch(const char* name, const char* classname, void* addobj, Int_t bufsize = 32000, Int_t splitlevel = 99);
429 virtual TBranch *BranchOld(const char* name, const char* classname, void* addobj, Int_t bufsize = 32000, Int_t splitlevel = 1);
430 virtual TBranch *BranchRef();
431 void Browse(TBrowser*) override;
432 virtual Int_t BuildIndex(const char *majorname, const char *minorname = "0");
433 TStreamerInfo *BuildStreamerInfo(TClass* cl, void *pointer = nullptr, bool canOptimize = true);
434 virtual TFile *ChangeFile(TFile* file);
435 virtual TTree *CloneTree(Long64_t nentries = -1, Option_t* option = "");
436 virtual void CopyAddresses(TTree*,bool undo = false);
437 virtual Long64_t CopyEntries(TTree* tree, Long64_t nentries = -1, Option_t *option = "", bool needCopyAddresses = false);
439 virtual TBasket *CreateBasket(TBranch*);
440 virtual void DirectoryAutoAdd(TDirectory *);
441 Int_t Debug() const { return fDebug; }
442 void Delete(Option_t* option = "") override; // *MENU*
443 void Draw(Option_t* opt) override { Draw(opt, "", "", kMaxEntries, 0); }
444 virtual Long64_t Draw(const char* varexp, const TCut& selection, Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0);
445 virtual Long64_t Draw(const char* varexp, const char* selection, Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0); // *MENU*
446 virtual void DropBaskets();
447 virtual void DropBuffers(Int_t nbytes);
448 bool EnableCache();
449 virtual Int_t Fill();
450 virtual TBranch *FindBranch(const char* name);
451 virtual TLeaf *FindLeaf(const char* name);
452 virtual Int_t Fit(const char* funcname, const char* varexp, const char* selection = "", Option_t* option = "", Option_t* goption = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0); // *MENU*
453 virtual Int_t FlushBaskets(bool create_cluster = true) const;
454 virtual const char *GetAlias(const char* aliasName) const;
456#ifdef R__TRACK_BASKET_ALLOC_TIME
458#endif
459 virtual Long64_t GetAutoFlush() const {return fAutoFlush;}
460 virtual Long64_t GetAutoSave() const {return fAutoSave;}
461 virtual TBranch *GetBranch(const char* name);
462 virtual TBranchRef *GetBranchRef() const { return fBranchRef; };
463 virtual bool GetBranchStatus(const char* branchname) const;
464 static Int_t GetBranchStyle();
465 virtual Long64_t GetCacheSize() const { return fCacheSize; }
466 virtual TClusterIterator GetClusterIterator(Long64_t firstentry);
468 virtual Long64_t GetChainOffset() const { return fChainOffset; }
469 virtual bool GetClusterPrefetch() const { return fCacheDoClusterPrefetch; }
470 TFile *GetCurrentFile() const;
472 Long64_t GetDebugMax() const { return fDebugMax; }
473 Long64_t GetDebugMin() const { return fDebugMin; }
474 TDirectory *GetDirectory() const { return fDirectory; }
475 virtual Long64_t GetEntries() const { return fEntries; }
476 virtual Long64_t GetEntries(const char *selection);
477 /// Return a number greater or equal to the total number of entries in the
478 /// dataset.
479 ///
480 /// \note If you are interested in the total number of entries in a TChain,
481 /// this function will give that number once the last file of the chain
482 /// is opened. In general, using this instead of GetEntries will avoid
483 /// opening all files in the chain which could be very costly for very
484 /// large number of files stored at a remote location.
485 ///
486 /// The logic depends on whether the dataset is a TTree or a TChain. In the
487 /// first case, it simply returns the total number of entries in the tree. In
488 /// the latter case, it depends on which point of the processing of the chain
489 /// this function is called. During most of the chain processing, this
490 /// function will return TTree::kMaxEntries. When the chain arrives at the
491 /// last file, then the function will return the accumulated total number of
492 /// entries in the whole chain. A notable use case where this function
493 /// becomes quite useful is when writing the following for loop to traverse
494 /// the entries in the dataset:
495 ///
496 /// \code{.cpp}
497 /// for(Long64_t ievent = 0; ievent < dataset.GetEntriesFast(); ievent++) {
498 /// // Do something with the event in the dataset
499 /// }
500 /// \endcode
501 ///
502 /// In the example above, independently on whether the dataset is a TTree or
503 /// a TChain, the GetEntriesFast call will provide the correct stopping
504 /// condition for the loop (i.e. the total number of entries). In the TChain
505 /// case, calling GetEntries instead would open all the files in the chain
506 /// upfront which could be costly.
507 ///
508 /// The functionality offered by this method can also be seen when used in
509 /// conjunction with LoadTree. For a call like <tt> LoadTree(ievent) </tt>,
510 /// the condition <tt> ievent < dataset.GetEntriesFast() </tt> is only
511 /// satisfied if \p ievent is strictly smaller than the total number of
512 /// entries in the dataset. In fact, even when the dataset is a TChain, the
513 /// first time LoadTree is called with an entry number that belongs to the
514 /// last file of the chain, this will update the internal data member of the
515 /// class so that the next call to GetEntriesFast returns the total number
516 /// of entries in the dataset.
517 virtual Long64_t GetEntriesFast() const { return fEntries; }
518 virtual Long64_t GetEntriesFriend() const;
519 virtual Long64_t GetEstimate() const { return fEstimate; }
520 virtual Int_t GetEntry(Long64_t entry, Int_t getall = 0);
525 TEventList *GetEventList() const { return fEventList; }
526 virtual TEntryList *GetEntryList();
527 virtual Long64_t GetEntryNumber(Long64_t entry) const;
528 virtual Int_t GetFileNumber() const { return fFileNumber; }
529 virtual TTree *GetFriend(const char*) const;
530 virtual const char *GetFriendAlias(TTree*) const;
532 virtual bool GetImplicitMT() { return fIMTEnabled; }
533 virtual Int_t *GetIndex() { return &fIndex.fArray[0]; }
534 virtual Double_t *GetIndexValues() { return &fIndexValues.fArray[0]; }
536 virtual TIterator *GetIteratorOnAllLeaves(bool dir = kIterForward);
537 virtual TLeaf *GetLeaf(const char* branchname, const char* leafname);
538 virtual TLeaf *GetLeaf(const char* name);
539 virtual TList *GetListOfClones() { return fClones; }
540 virtual TObjArray *GetListOfBranches() { return &fBranches; }
541 virtual TObjArray *GetListOfLeaves() { return &fLeaves; }
542 virtual TList *GetListOfFriends() const { return fFriends; }
543 virtual TList *GetListOfAliases() const { return fAliases; }
544
545 // GetMakeClass is left non-virtual for efficiency reason.
546 // Making it virtual affects the performance of the I/O
547 Int_t GetMakeClass() const { return fMakeClass; }
548
549 virtual Long64_t GetMaxEntryLoop() const { return fMaxEntryLoop; }
550 virtual Double_t GetMaximum(const char* columname);
551 static Long64_t GetMaxTreeSize();
552 virtual Long64_t GetMaxVirtualSize() const { return fMaxVirtualSize; }
553 virtual Double_t GetMinimum(const char* columname);
555 TObject *GetNotify() const { return fNotify; }
557 virtual Int_t GetPacketSize() const { return fPacketSize; }
558 virtual TVirtualPerfStats *GetPerfStats() const { return fPerfStats; }
559 TTreeCache *GetReadCache(TFile *file) const;
560 TTreeCache *GetReadCache(TFile *file, bool create);
561 virtual Long64_t GetReadEntry() const { return fReadEntry; }
562 virtual Long64_t GetReadEvent() const { return fReadEntry; }
563 virtual Int_t GetScanField() const { return fScanField; }
566 virtual Int_t GetTimerInterval() const { return fTimerInterval; }
568 virtual Long64_t GetTotBytes() const { return fTotBytes; }
569 virtual TTree *GetTree() const { return const_cast<TTree*>(this); }
570 virtual TVirtualIndex *GetTreeIndex() const { return fTreeIndex; }
571 virtual Int_t GetTreeNumber() const { return 0; }
573 virtual Int_t GetUpdate() const { return fUpdate; }
574 virtual TList *GetUserInfo();
575 // See TSelectorDraw::GetVar
577 // See TSelectorDraw::GetVar
579 // See TSelectorDraw::GetVar
581 // See TSelectorDraw::GetVar
583 // See TSelectorDraw::GetVar
585 // See TSelectorDraw::GetVal
586 virtual Double_t *GetVal(Int_t i) { return GetPlayer()->GetVal(i); }
587 // See TSelectorDraw::GetVal
588 virtual Double_t *GetV1() { return GetPlayer()->GetV1(); }
589 // See TSelectorDraw::GetVal
590 virtual Double_t *GetV2() { return GetPlayer()->GetV2(); }
591 // See TSelectorDraw::GetVal
592 virtual Double_t *GetV3() { return GetPlayer()->GetV3(); }
593 // See TSelectorDraw::GetVal
594 virtual Double_t *GetV4() { return GetPlayer()->GetV4(); }
595 virtual Double_t *GetW() { return GetPlayer()->GetW(); }
596 virtual Double_t GetWeight() const { return fWeight; }
597 virtual Long64_t GetZipBytes() const { return fZipBytes; }
599 bool IsFolder() const override { return true; }
600 virtual bool InPlaceClone(TDirectory *newdirectory, const char *options = "");
601 virtual Int_t LoadBaskets(Long64_t maxmemory = 2000000000);
604 virtual Int_t MakeClass(const char *classname = nullptr, Option_t* option = "");
605 virtual Int_t MakeCode(const char *filename = nullptr);
606 virtual Int_t MakeProxy(const char* classname, const char* macrofilename = nullptr, const char* cutfilename = nullptr, const char* option = nullptr, Int_t maxUnrolling = 3);
607 virtual Int_t MakeSelector(const char *selector = nullptr, Option_t *option = "");
608 bool MemoryFull(Int_t nbytes);
609 virtual Long64_t Merge(TCollection* list, Option_t* option = "");
611 static TTree *MergeTrees(TList* list, Option_t* option = "");
612 bool Notify() override;
613 virtual void OptimizeBaskets(ULong64_t maxMemory=10000000, Float_t minComp=1.1, Option_t *option="");
614 TPrincipal *Principal(const char* varexp = "", const char* selection = "", Option_t* option = "np", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0);
615 void Print(Option_t* option = "") const override; // *MENU*
616 virtual void PrintCacheStats(Option_t* option = "") const;
617 virtual Long64_t Process(const char* filename, Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0); // *MENU*
619 virtual Long64_t Project(const char* hname, const char* varexp, const char* selection = "", Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0);
620 virtual TSQLResult *Query(const char* varexp = "", const char* selection = "", Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0);
621 virtual Long64_t ReadFile(const char* filename, const char* branchDescriptor = "", char delimiter = ' ');
622 virtual Long64_t ReadStream(std::istream& inputStream, const char* branchDescriptor = "", char delimiter = ' ');
623 virtual void Refresh();
625 virtual void RemoveExternalFriend(TFriendElement *);
626 virtual void RemoveFriend(TTree*);
627 void RecursiveRemove(TObject *obj) override;
628 virtual void Reset(Option_t* option = "");
629 virtual void ResetAfterMerge(TFileMergeInfo *);
630 virtual void ResetBranchAddress(TBranch *);
631 virtual void ResetBranchAddresses();
632 virtual Long64_t Scan(const char* varexp = "", const char* selection = "", Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0); // *MENU*
633 virtual bool SetAlias(const char* aliasName, const char* aliasFormula);
634 virtual void SetAutoSave(Long64_t autos = -300000000);
635 virtual void SetAutoFlush(Long64_t autof = -30000000);
636 virtual void SetBasketSize(const char* bname, Int_t buffsize = 16000);
637 virtual Int_t SetBranchAddress(const char *bname,void *add, TBranch **ptr = nullptr);
638 virtual Int_t SetBranchAddress(const char *bname,void *add, TClass *realClass, EDataType datatype, bool isptr);
639 virtual Int_t SetBranchAddress(const char *bname,void *add, TBranch **ptr, TClass *realClass, EDataType datatype, bool isptr);
640 template <class T> Int_t SetBranchAddress(const char *bname, T **add, TBranch **ptr = nullptr) {
641 TClass *cl = TClass::GetClass<T>();
643 if (!cl) type = TDataType::GetType(typeid(T));
644 return SetBranchAddress(bname,add,ptr,cl,type,true);
645 }
646#ifndef R__NO_CLASS_TEMPLATE_SPECIALIZATION
647 // This can only be used when the template overload resolution can distinguish between
648 // T* and T**
649 template <class T> Int_t SetBranchAddress(const char *bname, T *add, TBranch **ptr = nullptr) {
650 TClass *cl = TClass::GetClass<T>();
652 if (!cl) type = TDataType::GetType(typeid(T));
653 return SetBranchAddress(bname,add,ptr,cl,type,false);
654 }
655#endif
656 virtual void SetBranchStatus(const char* bname, bool status = true, UInt_t* found = nullptr);
657 static void SetBranchStyle(Int_t style = 1); //style=0 for old branch, =1 for new branch style
658 virtual Int_t SetCacheSize(Long64_t cachesize = -1);
659 virtual Int_t SetCacheEntryRange(Long64_t first, Long64_t last);
660 virtual void SetCacheLearnEntries(Int_t n=10);
662 virtual void SetCircular(Long64_t maxEntries);
664 virtual void SetDebug(Int_t level = 1, Long64_t min = 0, Long64_t max = 9999999); // *MENU*
665 virtual void SetDefaultEntryOffsetLen(Int_t newdefault, bool updateExisting = false);
666 virtual void SetDirectory(TDirectory* dir);
667 virtual Long64_t SetEntries(Long64_t n = -1);
668 virtual void SetEstimate(Long64_t nentries = 1000000);
670 virtual void SetFileNumber(Int_t number = 0);
671 virtual void SetEventList(TEventList* list);
672 virtual void SetEntryList(TEntryList* list, Option_t *opt="");
673 virtual void SetImplicitMT(bool enabled) { fIMTEnabled = enabled; }
674 virtual void SetMakeClass(Int_t make);
676 static void SetMaxTreeSize(Long64_t maxsize = 100000000000LL);
677 virtual void SetMaxVirtualSize(Long64_t size = 0) { fMaxVirtualSize = size; } // *MENU*
678 void SetName(const char* name) override; // *MENU*
679
680 /**
681 * @brief Sets the address of the object to be notified when the tree is loaded.
682 *
683 * The method TObject::Notify is called for the given object when the tree
684 * is loaded. Specifically this occurs in the TTree::LoadTree method. To
685 * remove the notification call this method with nullptr:
686 * @code tree->SetNotify(nullptr); @endcode
687 *
688 * If this is a TChain, `obj` is most often going to be a TNotifyLink.
689 *
690 * @param[in] obj Pointer to a TObject to be notified.
691 */
692 virtual void SetNotify(TObject* obj);
693
694 virtual void SetObject(const char* name, const char* title);
695 virtual void SetParallelUnzip(bool opt=true, Float_t RelSize=-1);
696 virtual void SetPerfStats(TVirtualPerfStats* perf);
697 /**
698 * \brief Sets the default maximum number of lines to be shown before `<CR>` when calling Scan().
699 * \param n the maximum number of lines. Default=50, if 0, all entries of the Tree are shown
700 * and there is no need to press `<CR>` or `q` to exit the function.
701 * \see TTreePlayer::Scan for more details on how to redirect the output to an ASCII file
702 */
703 virtual void SetScanField(Int_t n = 50) { fScanField = n; } // *MENU*
706 virtual void SetTreeIndex(TVirtualIndex* index);
707 virtual void SetWeight(Double_t w = 1, Option_t* option = "");
708 virtual void SetUpdate(Int_t freq = 0) { fUpdate = freq; }
709 virtual void Show(Long64_t entry = -1, Int_t lenmax = 20);
710 virtual void StartViewer(); // *MENU*
712 virtual Int_t UnbinnedFit(const char* funcname, const char* varexp, const char* selection = "", Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0);
713 void UseCurrentStyle() override;
714 Int_t Write(const char *name=nullptr, Int_t option=0, Int_t bufsize=0) override;
715 Int_t Write(const char *name=nullptr, Int_t option=0, Int_t bufsize=0) const override;
716
717 ClassDefOverride(TTree, 20) // Tree descriptor (the main ROOT I/O class)
718};
719
720//////////////////////////////////////////////////////////////////////////
721// //
722// TTreeFriendLeafIter //
723// //
724// Iterator on all the leaves in a TTree and its friend //
725// //
726//////////////////////////////////////////////////////////////////////////
727
729
730protected:
731 TTree *fTree; ///< tree being iterated
732 TIterator *fLeafIter; ///< current leaf sub-iterator.
733 TIterator *fTreeIter; ///< current tree sub-iterator.
734 bool fDirection; ///< iteration direction
735
736 TTreeFriendLeafIter() : fTree(nullptr), fLeafIter(nullptr), fTreeIter(nullptr),
737 fDirection(false) { }
738
739public:
740 TTreeFriendLeafIter(const TTree* t, bool dir = kIterForward);
743 TIterator &operator=(const TIterator &rhs) override;
745
746 const TCollection *GetCollection() const override { return nullptr; }
747 Option_t *GetOption() const override;
748 TObject *Next() override;
750 bool operator !=(const TIterator&) const override {
751 // TODO: Implement me
752 return false;
753 }
754 bool operator !=(const TTreeFriendLeafIter&) const {
755 // TODO: Implement me
756 return false;
757 }
758 TObject *operator*() const override {
759 // TODO: Implement me
760 return nullptr;
761 }
762 ClassDefOverride(TTreeFriendLeafIter,0) //Linked list iterator
763 };
764
765
766#endif
#define SafeDelete(p)
Definition RConfig.hxx:533
size_t size(const MatrixT &matrix)
retrieve the size of a square matrix
int Int_t
Definition RtypesCore.h:45
long Longptr_t
Definition RtypesCore.h:75
unsigned int UInt_t
Definition RtypesCore.h:46
float Float_t
Definition RtypesCore.h:57
double Double_t
Definition RtypesCore.h:59
long long Long64_t
Definition RtypesCore.h:69
unsigned long long ULong64_t
Definition RtypesCore.h:70
const char Option_t
Definition RtypesCore.h:66
#define BIT(n)
Definition Rtypes.h:90
#define ClassDefOverride(name, id)
Definition Rtypes.h:346
const Bool_t kIterForward
Definition TCollection.h:42
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
EDataType
Definition TDataType.h:28
@ kOther_t
Definition TDataType.h:32
#define gDirectory
Definition TDirectory.h:384
#define N
Option_t Option_t option
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char filename
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h offset
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t index
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t src
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t Atom_t Time_t type
Option_t Option_t style
char name[80]
Definition TGX11.cxx:110
int nentries
TIOFeatures provides the end-user with the ability to change the IO behavior of data written via a TT...
Array of doubles (64 bits per element).
Definition TArrayD.h:27
Double_t * fArray
Definition TArrayD.h:30
Array of integers (32 bits per element).
Definition TArrayI.h:27
Int_t * fArray
Definition TArrayI.h:30
Fill Area Attributes class.
Definition TAttFill.h:20
Line Attributes class.
Definition TAttLine.h:20
Marker Attributes class.
Definition TAttMarker.h:20
Manages buffers for branches of a Tree.
Definition TBasket.h:34
A branch containing and managing a TRefTable for TRef autoloading.
Definition TBranchRef.h:34
A TTree is a list of TBranches.
Definition TBranch.h:93
Using a TBrowser one can browse all ROOT objects.
Definition TBrowser.h:37
Buffer base class used for serializing objects.
Definition TBuffer.h:43
A Chain Index.
Definition TChainIndex.h:40
TClass instances represent classes, structs and namespaces in the ROOT type system.
Definition TClass.h:84
Collection abstract base class.
Definition TCollection.h:65
A specialized string object used for TTree selections.
Definition TCut.h:25
Int_t GetType() const
Definition TDataType.h:68
Describe directory structure in memory.
Definition TDirectory.h:45
A List of entry numbers in a TTree or TChain.
Definition TEntryList.h:26
<div class="legacybox"><h2>Legacy Code</h2> TEventList is a legacy interface: there will be no bug fi...
Definition TEventList.h:31
A ROOT file is an on-disk file, usually with extension .root, that stores objects in a file-system-li...
Definition TFile.h:131
A TFriendElement TF describes a TTree object TF in a file.
TH1 is the base class of all histogram classes in ROOT.
Definition TH1.h:59
Iterator abstract base class.
Definition TIterator.h:30
A TLeaf describes individual elements of a TBranch See TBranch structure in TTree.
Definition TLeaf.h:57
A doubly linked list.
Definition TList.h:38
The TNamed class is the base class for all named ROOT classes.
Definition TNamed.h:29
const char * GetName() const override
Returns name of object.
Definition TNamed.h:49
An array of TObjects.
Definition TObjArray.h:31
Int_t GetEntriesFast() const
Definition TObjArray.h:58
Mother of all ROOT objects.
Definition TObject.h:41
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
Definition TObject.cxx:1071
A PolyMarker is defined by an array on N points in a 2-D space.
Definition TPolyMarker.h:31
Principal Components Analysis (PCA)
Definition TPrincipal.h:21
A TSelector object is used by the TTree::Draw, TTree::Scan, TTree::Process to navigate in a TTree and...
Definition TSelector.h:31
Describes a persistent version of a class.
A cache to speed-up the reading of ROOT datasets.
Definition TTreeCache.h:32
Class implementing or helping the various TTree cloning method.
Definition TTreeCloner.h:31
Used to pass a selection expression to the Tree drawing routine.
Iterator on all the leaves in a TTree and its friend.
Definition TTree.h:728
bool operator!=(const TIterator &) const override
Compare two iterator objects.
Definition TTree.h:750
const TCollection * GetCollection() const override
Definition TTree.h:746
TTree * fTree
tree being iterated
Definition TTree.h:731
TObject * operator*() const override
Return current object or nullptr.
Definition TTree.h:758
void Reset() override
Definition TTree.h:749
TIterator & operator=(const TIterator &rhs) override
Overridden assignment operator. Does NOT copy the 'cursor' location!
Definition TTree.cxx:9916
~TTreeFriendLeafIter() override
Definition TTree.h:742
TObject * Next() override
Go the next friend element.
Definition TTree.cxx:9939
TIterator * fLeafIter
current leaf sub-iterator.
Definition TTree.h:732
Option_t * GetOption() const override
Returns the object option stored in the list.
Definition TTree.cxx:9978
TIterator * fTreeIter
current tree sub-iterator.
Definition TTree.h:733
bool fDirection
iteration direction
Definition TTree.h:734
A Tree Index with majorname and minorname.
Definition TTreeIndex.h:29
Helper class to iterate over cluster of baskets.
Definition TTree.h:282
Long64_t GetEstimatedClusterSize()
Estimate the cluster size.
Definition TTree.cxx:605
Long64_t Previous()
Move on to the previous cluster and return the starting entry of this previous cluster.
Definition TTree.cxx:688
Long64_t GetStartEntry()
Definition TTree.h:314
Long64_t operator()()
Definition TTree.h:323
Long64_t Next()
Move on to the next cluster and return the starting entry of this next cluster.
Definition TTree.cxx:644
Long64_t GetNextEntry()
Definition TTree.h:319
Long64_t fEstimatedSize
Definition TTree.h:288
TClusterIterator(TTree *tree, Long64_t firstEntry)
Regular constructor.
Definition TTree.cxx:554
Helper class to prevent infinite recursion in the usage of TTree Friends.
Definition TTree.h:199
TFriendLock & operator=(const TFriendLock &)
Assignment operator.
Definition TTree.cxx:520
UInt_t fMethodBit
Definition TTree.h:203
TTree * fTree
Definition TTree.h:202
~TFriendLock()
Restore the state of tree the same as before we set the lock.
Definition TTree.cxx:533
A TTree represents a columnar dataset.
Definition TTree.h:84
virtual Int_t Fill()
Fill all branches.
Definition TTree.cxx:4620
virtual TFriendElement * AddFriend(const char *treename, const char *filename="")
Add a TFriendElement to the list of friends.
Definition TTree.cxx:1326
TBranchRef * fBranchRef
Branch supporting the TRefTable (if any)
Definition TTree.h:141
TStreamerInfo * BuildStreamerInfo(TClass *cl, void *pointer=nullptr, bool canOptimize=true)
Build StreamerInfo for class cl.
Definition TTree.cxx:2649
virtual TBranch * FindBranch(const char *name)
Return the branch that correspond to the path 'branchname', which can include the name of the tree or...
Definition TTree.cxx:4856
virtual TVirtualPerfStats * GetPerfStats() const
Definition TTree.h:558
virtual void SetTimerInterval(Int_t msec=333)
Definition TTree.h:705
virtual void SetBranchStatus(const char *bname, bool status=true, UInt_t *found=nullptr)
Set branch status to Process or DoNotProcess.
Definition TTree.cxx:8645
TTreeFormula * GetSelect()
Definition TTree.h:564
bool EnableCache()
Enable the TTreeCache unless explicitly disabled for this TTree by a prior call to SetCacheSize(0).
Definition TTree.cxx:2682
virtual TBranch * GetBranch(const char *name)
Return pointer to the branch with the given name in this tree or its friends.
Definition TTree.cxx:5309
virtual Int_t GetScanField() const
Definition TTree.h:563
static Int_t GetBranchStyle()
Static function returning the current branch style.
Definition TTree.cxx:5413
TList * fFriends
pointer to list of friend elements
Definition TTree.h:135
bool fIMTEnabled
! true if implicit multi-threading is enabled for this tree
Definition TTree.h:147
virtual Long64_t GetChainEntryNumber(Long64_t entry) const
Definition TTree.h:467
virtual bool GetBranchStatus(const char *branchname) const
Return status of branch with name branchname.
Definition TTree.cxx:5398
UInt_t fFriendLockStatus
! Record which method is locking the friend recursion
Definition TTree.h:142
virtual TLeaf * GetLeafImpl(const char *branchname, const char *leafname)
Return pointer to the 1st Leaf named name in any Branch of this Tree or any branch in the list of fri...
Definition TTree.cxx:6118
Long64_t fTotBytes
Total number of bytes in all branches before compression.
Definition TTree.h:91
virtual Int_t FlushBaskets(bool create_cluster=true) const
Write to disk all the basket that have not yet been individually written and create an event cluster ...
Definition TTree.cxx:5144
Int_t GetDefaultEntryOffsetLen() const
Definition TTree.h:471
Int_t fMaxClusterRange
! Memory allocated for the cluster range.
Definition TTree.h:101
virtual void Show(Long64_t entry=-1, Int_t lenmax=20)
Print values of all active leaves for entry.
Definition TTree.cxx:9507
TEventList * fEventList
! Pointer to event selection list (if one)
Definition TTree.h:130
virtual Long64_t GetAutoSave() const
Definition TTree.h:460
virtual Int_t StopCacheLearningPhase()
Stop the cache learning phase.
Definition TTree.cxx:9596
virtual Int_t GetEntry(Long64_t entry, Int_t getall=0)
Read all branches of entry and return total number of bytes read.
Definition TTree.cxx:5658
std::vector< std::pair< Long64_t, TBranch * > > fSortedBranches
! Branches to be processed in parallel when IMT is on, sorted by average task time
Definition TTree.h:149
virtual void SetCircular(Long64_t maxEntries)
Enable/Disable circularity for this tree.
Definition TTree.cxx:9003
virtual Long64_t GetEstimate() const
Definition TTree.h:519
Long64_t GetDebugMax() const
Definition TTree.h:472
Long64_t fSavedBytes
Number of autosaved bytes.
Definition TTree.h:93
virtual Int_t AddBranchToCache(const char *bname, bool subbranches=false)
Add branch with name bname to the Tree cache.
Definition TTree.cxx:1053
Long64_t GetMedianClusterSize()
Estimate the median cluster size for the TTree.
Definition TTree.cxx:8408
virtual TClusterIterator GetClusterIterator(Long64_t firstentry)
Return an iterator over the cluster of baskets starting at firstentry.
Definition TTree.cxx:5485
virtual void ResetBranchAddress(TBranch *)
Tell a branch to set its address to zero.
Definition TTree.cxx:8162
bool fCacheUserSet
! true if the cache setting was explicitly given by user
Definition TTree.h:146
char GetNewlineValue(std::istream &inputStream)
Determine which newline this file is using.
Definition TTree.cxx:7685
TBranch * Branch(const char *name, T **addobj, Int_t bufsize=32000, Int_t splitlevel=99)
Add a new branch, and infer the data type from the array addobj being passed.
Definition TTree.h:382
TIOFeatures fIOFeatures
IO features to define for newly-written baskets and branches.
Definition TTree.h:119
virtual Long64_t GetSelectedRows()
Definition TTree.h:565
void AddAllocationCount(UInt_t count)
Definition TTree.h:349
virtual void SetMaxEntryLoop(Long64_t maxev=kMaxEntries)
Definition TTree.h:675
virtual Long64_t GetEntryNumberWithIndex(Long64_t major, Long64_t minor=0) const
Return entry number corresponding to major and minor number.
Definition TTree.cxx:5930
Long64_t fDebugMin
! First entry number to debug
Definition TTree.h:117
virtual Long64_t SetEntries(Long64_t n=-1)
Change number of entries in the tree.
Definition TTree.cxx:9122
virtual TObjArray * GetListOfLeaves()
Definition TTree.h:541
virtual TBranch * BranchOld(const char *name, const char *classname, void *addobj, Int_t bufsize=32000, Int_t splitlevel=1)
Create a new TTree BranchObject.
Definition TTree.cxx:2071
Long64_t GetCacheAutoSize(bool withDefault=false)
Used for automatic sizing of the cache.
Definition TTree.cxx:5425
virtual TBranch * BranchRef()
Build the optional branch supporting the TRefTable.
Definition TTree.cxx:2325
TFile * GetCurrentFile() const
Return pointer to the current file.
Definition TTree.cxx:5497
TObject * GetNotify() const
Definition TTree.h:555
TList * fAliases
List of aliases for expressions based on the tree branches.
Definition TTree.h:129
TBranch * Branch(const char *name, Longptr_t address, const char *leaflist, Int_t bufsize=32000)
Definition TTree.h:396
virtual TTree * CopyTree(const char *selection, Option_t *option="", Long64_t nentries=kMaxEntries, Long64_t firstentry=0)
Copy a tree with selection.
Definition TTree.cxx:3726
virtual Int_t DropBranchFromCache(const char *bname, bool subbranches=false)
Remove the branch with name 'bname' from the Tree cache.
Definition TTree.cxx:1136
virtual Int_t Fit(const char *funcname, const char *varexp, const char *selection="", Option_t *option="", Option_t *goption="", Long64_t nentries=kMaxEntries, Long64_t firstentry=0)
Fit a projected item(s) from a tree.
Definition TTree.cxx:5094
Long64_t * fClusterRangeEnd
[fNClusterRange] Last entry of a cluster range.
Definition TTree.h:108
std::atomic< Long64_t > fIMTZipBytes
! Zip bytes for the IMT flush baskets.
Definition TTree.h:166
void RecursiveRemove(TObject *obj) override
Make sure that obj (which is being deleted or will soon be) is no longer referenced by this TTree.
Definition TTree.cxx:7978
TVirtualTreePlayer * GetPlayer()
Load the TTreePlayer (if not already done).
Definition TTree.cxx:6325
virtual Int_t MakeProxy(const char *classname, const char *macrofilename=nullptr, const char *cutfilename=nullptr, const char *option=nullptr, Int_t maxUnrolling=3)
Generate a skeleton analysis class for this Tree using TBranchProxy.
Definition TTree.cxx:6788
Float_t fTargetMemoryRatio
! Ratio for memory usage in uncompressed buffers versus actual occupancy.
Definition TTree.h:151
virtual Double_t * GetIndexValues()
Definition TTree.h:534
virtual TList * GetListOfAliases() const
Definition TTree.h:543
virtual Long64_t ReadStream(std::istream &inputStream, const char *branchDescriptor="", char delimiter=' ')
Create or simply read branches from an input stream.
Definition TTree.cxx:7712
virtual void SetDebug(Int_t level=1, Long64_t min=0, Long64_t max=9999999)
Set the debug level and the debug range.
Definition TTree.cxx:9039
Int_t fScanField
Number of runs before prompting in Scan.
Definition TTree.h:97
virtual Double_t GetWeight() const
Definition TTree.h:596
void Draw(Option_t *opt) override
Default Draw method for all objects.
Definition TTree.h:443
virtual TTree * GetFriend(const char *) const
Return a pointer to the TTree friend whose name or alias is friendname.
Definition TTree.cxx:5995
TTreeFormula * GetVar(Int_t i)
Definition TTree.h:576
virtual void SetNotify(TObject *obj)
Sets the address of the object to be notified when the tree is loaded.
Definition TTree.cxx:9353
virtual Double_t GetMaximum(const char *columname)
Return maximum of column with name columname.
Definition TTree.cxx:6255
virtual Long64_t GetEntryNumberWithBestIndex(Long64_t major, Long64_t minor=0) const
Return entry number corresponding to major and minor number.
Definition TTree.cxx:5910
static void SetMaxTreeSize(Long64_t maxsize=100000000000LL)
Set the maximum size in bytes of a Tree file (static function).
Definition TTree.cxx:9319
void Print(Option_t *option="") const override
Print a summary of the tree contents.
Definition TTree.cxx:7315
virtual Int_t UnbinnedFit(const char *funcname, const char *varexp, const char *selection="", Option_t *option="", Long64_t nentries=kMaxEntries, Long64_t firstentry=0)
Unbinned fit of one or more variable(s) from a tree.
Definition TTree.cxx:9826
Int_t fNClusterRange
Number of Cluster range in addition to the one defined by 'AutoFlush'.
Definition TTree.h:100
virtual void PrintCacheStats(Option_t *option="") const
Print statistics about the TreeCache for this tree.
Definition TTree.cxx:7467
virtual Int_t BuildIndex(const char *majorname, const char *minorname="0")
Build a Tree Index (default is TTreeIndex).
Definition TTree.cxx:2634
TVirtualTreePlayer * fPlayer
! Pointer to current Tree player
Definition TTree.h:139
virtual TIterator * GetIteratorOnAllLeaves(bool dir=kIterForward)
Creates a new iterator that will go through all the leaves on the tree itself and its friend.
Definition TTree.cxx:6102
virtual void SetMakeClass(Int_t make)
Set all the branches in this TTree to be in decomposed object mode (also known as MakeClass mode).
Definition TTree.cxx:9299
virtual bool InPlaceClone(TDirectory *newdirectory, const char *options="")
Copy the content to a new new file, update this TTree with the new location information and attach th...
Definition TTree.cxx:7108
virtual void IncrementTotalBuffers(Int_t nbytes)
Definition TTree.h:598
TObjArray fBranches
List of Branches.
Definition TTree.h:127
TDirectory * GetDirectory() const
Definition TTree.h:474
bool fCacheDoAutoInit
! true if cache auto creation or resize check is needed
Definition TTree.h:144
TTreeCache * GetReadCache(TFile *file) const
Find and return the TTreeCache registered with the file and which may contain branches for us.
Definition TTree.cxx:6338
Long64_t fEntries
Number of entries.
Definition TTree.h:89
virtual TFile * ChangeFile(TFile *file)
Called by TTree::Fill() when file has reached its maximum fgMaxTreeSize.
Definition TTree.cxx:2746
virtual TEntryList * GetEntryList()
Returns the entry list assigned to this tree.
Definition TTree.cxx:5874
virtual void SetWeight(Double_t w=1, Option_t *option="")
Set tree weight.
Definition TTree.cxx:9496
void InitializeBranchLists(bool checkLeafCount)
Divides the top-level branches into two vectors: (i) branches to be processed sequentially and (ii) b...
Definition TTree.cxx:5801
virtual Int_t SetBranchAddress(const char *bname, void *add, TBranch **ptr=nullptr)
Change branch address, dealing with clone trees properly.
Definition TTree.cxx:8496
Long64_t * fClusterSize
[fNClusterRange] Number of entries in each cluster for a given range.
Definition TTree.h:109
Long64_t fFlushedBytes
Number of auto-flushed bytes.
Definition TTree.h:94
virtual void SetPerfStats(TVirtualPerfStats *perf)
Set perf stats.
Definition TTree.cxx:9451
TTreeFormula * GetVar2()
Definition TTree.h:580
std::atomic< Long64_t > fIMTTotBytes
! Total bytes for the IMT flush baskets
Definition TTree.h:165
virtual void SetCacheLearnEntries(Int_t n=10)
Interface to TTreeCache to set the number of entries for the learning phase.
Definition TTree.cxx:8976
Int_t SetBranchAddress(const char *bname, T *add, TBranch **ptr=nullptr)
Definition TTree.h:649
void SetTargetMemoryRatio(Float_t ratio)
Definition TTree.h:704
TEntryList * fEntryList
! Pointer to event selection list (if one)
Definition TTree.h:131
@ kSplitCollectionOfPointers
Definition TTree.h:278
virtual TVirtualIndex * GetTreeIndex() const
Definition TTree.h:570
Int_t Debug() const
Definition TTree.h:441
TList * fExternalFriends
! List of TFriendsElement pointing to us and need to be notified of LoadTree. Content not owned.
Definition TTree.h:136
virtual Long64_t Merge(TCollection *list, Option_t *option="")
Merge the trees in the TList into this tree.
Definition TTree.cxx:6922
virtual void SetMaxVirtualSize(Long64_t size=0)
Definition TTree.h:677
virtual void DropBaskets()
Remove some baskets from memory.
Definition TTree.cxx:4535
virtual void SetAutoSave(Long64_t autos=-300000000)
In case of a program crash, it will be possible to recover the data in the tree up to the last AutoSa...
Definition TTree.cxx:8453
virtual bool GetClusterPrefetch() const
Definition TTree.h:469
TBranch * Branch(const char *name, const char *classname, T **addobj, Int_t bufsize=32000, Int_t splitlevel=99)
Definition TTree.h:412
Long64_t fMaxEntryLoop
Maximum number of entries to process.
Definition TTree.h:103
friend TBranch * TTreeBranchImpRef(TTree *tree, const char *branchname, TClass *ptrClass, EDataType datatype, void *addobj, Int_t bufsize, Int_t splitlevel)
Float_t GetTargetMemoryRatio() const
Definition TTree.h:572
virtual void SetParallelUnzip(bool opt=true, Float_t RelSize=-1)
Enable or disable parallel unzipping of Tree buffers.
Definition TTree.cxx:9413
virtual void SetDirectory(TDirectory *dir)
Change the tree's directory.
Definition TTree.cxx:9077
void SortBranchesByTime()
Sorts top-level branches by the last average task time recorded per branch.
Definition TTree.cxx:5854
void Delete(Option_t *option="") override
Delete this tree from memory or/and disk.
Definition TTree.cxx:3754
virtual Int_t * GetIndex()
Definition TTree.h:533
virtual TBranchRef * GetBranchRef() const
Definition TTree.h:462
virtual Double_t * GetV3()
Definition TTree.h:592
virtual Long64_t Process(const char *filename, Option_t *option="", Long64_t nentries=kMaxEntries, Long64_t firstentry=0)
Process this tree executing the TSelector code in the specified filename.
Definition TTree.cxx:7547
virtual TBranch * BranchImpRef(const char *branchname, const char *classname, TClass *ptrClass, void *addobj, Int_t bufsize, Int_t splitlevel)
Same as TTree::Branch but automatic detection of the class name.
Definition TTree.cxx:1629
virtual void SetEventList(TEventList *list)
This function transfroms the given TEventList into a TEntryList The new TEntryList is owned by the TT...
Definition TTree.cxx:9180
TBranch * Branch(const char *name, int address, const char *leaflist, Int_t bufsize=32000)
Definition TTree.h:401
void MoveReadCache(TFile *src, TDirectory *dir)
Move a cache from a file to the current file in dir.
Definition TTree.cxx:7079
TTree & operator=(const TTree &tt)=delete
Long64_t fAutoFlush
Auto-flush tree when fAutoFlush entries written or -fAutoFlush (compressed) bytes produced.
Definition TTree.h:106
Int_t fUpdate
Update frequency for EntryLoop.
Definition TTree.h:98
virtual void ResetAfterMerge(TFileMergeInfo *)
Resets the state of this TTree after a merge (keep the customization but forget the data).
Definition TTree.cxx:8131
TBranch * Branch(const char *name, std::array< T, N > *obj, Int_t bufsize=32000, Int_t splitlevel=99)
Definition TTree.h:417
virtual Long64_t GetEntries() const
Definition TTree.h:475
virtual void SetEstimate(Long64_t nentries=1000000)
Set number of entries to estimate variable limits.
Definition TTree.cxx:9221
Int_t fTimerInterval
Timer interval in milliseconds.
Definition TTree.h:96
Int_t fDebug
! Debug level
Definition TTree.h:116
Int_t SetCacheSizeAux(bool autocache=true, Long64_t cacheSize=0)
Set the size of the file cache and create it if possible.
Definition TTree.cxx:8822
virtual Long64_t AutoSave(Option_t *option="")
AutoSave tree header every fAutoSave bytes.
Definition TTree.cxx:1494
virtual Long64_t GetEntryNumber(Long64_t entry) const
Return entry number corresponding to entry.
Definition TTree.cxx:5885
virtual TTree * CloneTree(Long64_t nentries=-1, Option_t *option="")
Create a clone of this tree and copy nentries.
Definition TTree.cxx:3140
virtual bool GetImplicitMT()
Definition TTree.h:532
Int_t fFileNumber
! current file number (if file extensions)
Definition TTree.h:121
virtual TLeaf * GetLeaf(const char *branchname, const char *leafname)
Return pointer to the 1st Leaf named name in any Branch of this Tree or any branch in the list of fri...
Definition TTree.cxx:6215
virtual Long64_t GetZipBytes() const
Definition TTree.h:597
TObjArray fLeaves
Direct pointers to individual branch leaves.
Definition TTree.h:128
virtual void Reset(Option_t *option="")
Reset baskets, buffers and entries count in all branches and leaves.
Definition TTree.cxx:8100
virtual void SetImplicitMT(bool enabled)
Definition TTree.h:673
virtual void KeepCircular()
Keep a maximum of fMaxEntries in memory.
Definition TTree.cxx:6435
virtual void SetDefaultEntryOffsetLen(Int_t newdefault, bool updateExisting=false)
Update the default value for the branch's fEntryOffsetLen.
Definition TTree.cxx:9051
virtual void DirectoryAutoAdd(TDirectory *)
Called by TKey and TObject::Clone to automatically add us to a directory when we are read from a file...
Definition TTree.cxx:3826
Long64_t fMaxVirtualSize
Maximum total size of buffers kept in memory.
Definition TTree.h:104
virtual Long64_t GetTotBytes() const
Definition TTree.h:568
virtual Int_t MakeSelector(const char *selector=nullptr, Option_t *option="")
Generate skeleton selector class for this tree.
Definition TTree.cxx:6842
virtual void SetObject(const char *name, const char *title)
Change the name and title of this tree.
Definition TTree.cxx:9382
TVirtualPerfStats * fPerfStats
! pointer to the current perf stats object
Definition TTree.h:137
Double_t fWeight
Tree weight (see TTree::SetWeight)
Definition TTree.h:95
virtual void SetUpdate(Int_t freq=0)
Definition TTree.h:708
std::vector< TBranch * > fSeqBranches
! Branches to be processed sequentially when IMT is on
Definition TTree.h:150
Long64_t fDebugMax
! Last entry number to debug
Definition TTree.h:118
Int_t fDefaultEntryOffsetLen
Initial Length of fEntryOffset table in the basket buffers.
Definition TTree.h:99
TTree()
Default constructor and I/O constructor.
Definition TTree.cxx:731
Long64_t fAutoSave
Autosave tree when fAutoSave entries written or -fAutoSave (compressed) bytes produced.
Definition TTree.h:105
TBranch * Branch(const char *name, T *obj, Int_t bufsize=32000, Int_t splitlevel=99)
Add a new branch, and infer the data type from the type of obj being passed.
Definition TTree.h:365
std::atomic< UInt_t > fAllocationCount
indicates basket should be resized to exact memory usage, but causes significant
Definition TTree.h:157
virtual Int_t GetEntryWithIndex(Int_t major, Int_t minor=0)
Read entry corresponding to major and minor number.
Definition TTree.cxx:5947
static TTree * MergeTrees(TList *list, Option_t *option="")
Static function merging the trees in the TList into a new tree.
Definition TTree.cxx:6873
bool MemoryFull(Int_t nbytes)
Check if adding nbytes to memory we are still below MaxVirtualsize.
Definition TTree.cxx:6857
TTreeFormula * GetVar4()
Definition TTree.h:584
virtual Long64_t GetReadEntry() const
Definition TTree.h:561
virtual TObjArray * GetListOfBranches()
Definition TTree.h:540
Long64_t fZipBytes
Total number of bytes in all branches after compression.
Definition TTree.h:92
virtual TTree * GetTree() const
Definition TTree.h:569
TBuffer * fTransientBuffer
! Pointer to the current transient buffer.
Definition TTree.h:143
virtual Double_t * GetVal(Int_t i)
Definition TTree.h:586
virtual void SetEntryList(TEntryList *list, Option_t *opt="")
Set an EntryList.
Definition TTree.cxx:9157
bool Notify() override
Function called when loading a new class library.
Definition TTree.cxx:7129
virtual void AddZipBytes(Int_t zip)
Definition TTree.h:344
virtual Long64_t LoadTree(Long64_t entry)
Set current entry.
Definition TTree.cxx:6493
virtual Long64_t ReadFile(const char *filename, const char *branchDescriptor="", char delimiter=' ')
Create or simply read branches from filename.
Definition TTree.cxx:7661
virtual const char * GetAlias(const char *aliasName) const
Returns the expanded value of the alias. Search in the friends if any.
Definition TTree.cxx:5241
ROOT::TIOFeatures SetIOFeatures(const ROOT::TIOFeatures &)
Provide the end-user with the ability to enable/disable various experimental IO features for this TTr...
Definition TTree.cxx:9241
friend class TFriendLock
Definition TTree.h:214
virtual TBasket * CreateBasket(TBranch *)
Create a basket for this tree and given branch.
Definition TTree.cxx:3738
TList * fUserInfo
pointer to a list of user objects associated to this Tree
Definition TTree.h:138
virtual Double_t GetMinimum(const char *columname)
Return minimum of column with name columname.
Definition TTree.cxx:6295
virtual void RemoveFriend(TTree *)
Remove a friend from the list of friends.
Definition TTree.cxx:8074
virtual Long64_t GetEntriesFast() const
Return a number greater or equal to the total number of entries in the dataset.
Definition TTree.h:517
void Browse(TBrowser *) override
Browse content of the TTree.
Definition TTree.cxx:2606
virtual Double_t * GetV1()
Definition TTree.h:588
virtual TList * GetUserInfo()
Return a pointer to the list containing user objects associated to this tree.
Definition TTree.cxx:6376
void RegisterBranchFullName(std::pair< std::string, TBranch * > &&kv)
Definition TTree.h:177
TEventList * GetEventList() const
Definition TTree.h:525
Long64_t fChainOffset
! Offset of 1st entry of this Tree in a TChain
Definition TTree.h:111
EStatusBits
Definition TTree.h:262
@ kOnlyFlushAtCluster
If set, the branch's buffers will grow until an event cluster boundary is hit, guaranteeing a basket ...
Definition TTree.h:268
@ kEntriesReshuffled
If set, signals that this TTree is the output of the processing of another TTree, and the entries are...
Definition TTree.h:273
@ kCircular
Definition TTree.h:264
@ kForceRead
Definition TTree.h:263
virtual Long64_t GetEntriesFriend() const
Return pointer to the 1st Leaf named name in any Branch of this Tree or any branch in the list of fri...
Definition TTree.cxx:5530
virtual TSQLResult * Query(const char *varexp="", const char *selection="", Option_t *option="", Long64_t nentries=kMaxEntries, Long64_t firstentry=0)
Loop over entries and return a TSQLResult object containing entries following selection.
Definition TTree.cxx:7610
virtual TBranch * Bronch(const char *name, const char *classname, void *addobj, Int_t bufsize=32000, Int_t splitlevel=99)
Create a new TTree BranchElement.
Definition TTree.cxx:2401
virtual void SetBasketSize(const char *bname, Int_t buffsize=16000)
Set a branch's basket size.
Definition TTree.cxx:8469
static void SetBranchStyle(Int_t style=1)
Set the current branch style.
Definition TTree.cxx:8776
virtual Long64_t GetReadEvent() const
Definition TTree.h:562
~TTree() override
Destructor.
Definition TTree.cxx:914
bool IsFolder() const override
Returns kTRUE in case object contains browsable objects (like containers or lists of other objects).
Definition TTree.h:599
void ImportClusterRanges(TTree *fromtree)
Appends the cluster range information stored in 'fromtree' to this tree, including the value of fAuto...
Definition TTree.cxx:6392
Long64_t fEstimate
Number of entries to estimate histogram limits.
Definition TTree.h:107
TH1 * GetHistogram()
Definition TTree.h:531
UInt_t GetAllocationCount() const
Definition TTree.h:455
Int_t FlushBasketsImpl() const
Internal implementation of the FlushBaskets algorithm.
Definition TTree.cxx:5161
Long64_t GetDebugMin() const
Definition TTree.h:473
virtual Long64_t LoadTreeFriend(Long64_t entry, TTree *T)
Load entry on behalf of our master tree, we may use an index.
Definition TTree.cxx:6577
Int_t Write(const char *name=nullptr, Int_t option=0, Int_t bufsize=0) override
Write this object to the current directory.
Definition TTree.cxx:9877
TVirtualIndex * fTreeIndex
Pointer to the tree Index (if any)
Definition TTree.h:134
void UseCurrentStyle() override
Replace current attributes by current style.
Definition TTree.cxx:9838
virtual Int_t GetTreeNumber() const
Definition TTree.h:571
Int_t GetEvent(Long64_t entry, Int_t getall=0)
Definition TTree.h:521
TObject * fNotify
Object to be notified when loading a Tree.
Definition TTree.h:125
virtual TBranch * BranchImp(const char *branchname, const char *classname, TClass *ptrClass, void *addobj, Int_t bufsize, Int_t splitlevel)
Same as TTree::Branch() with added check that addobj matches className.
Definition TTree.cxx:1548
virtual TList * GetListOfClones()
Definition TTree.h:539
Long64_t fCacheSize
! Maximum size of file buffers
Definition TTree.h:110
TList * fClones
! List of cloned trees which share our addresses
Definition TTree.h:140
std::atomic< Long64_t > fTotalBuffers
! Total number of bytes in branch buffers
Definition TTree.h:113
ELockStatusBits
Definition TTree.h:222
@ kFindBranch
Definition TTree.h:223
@ kResetBranchAddresses
Definition TTree.h:236
@ kFindLeaf
Definition TTree.h:224
@ kGetEntryWithIndex
Definition TTree.h:228
@ kPrint
Definition TTree.h:233
@ kGetFriend
Definition TTree.h:229
@ kGetBranch
Definition TTree.h:226
@ kSetBranchStatus
Definition TTree.h:235
@ kLoadTree
Definition TTree.h:232
@ kGetEntry
Definition TTree.h:227
@ kGetLeaf
Definition TTree.h:231
@ kRemoveFriend
Definition TTree.h:234
@ kGetFriendAlias
Definition TTree.h:230
@ kGetAlias
Definition TTree.h:225
virtual Double_t * GetV4()
Definition TTree.h:594
TBranch * Branch(const char *name, const char *classname, T *obj, Int_t bufsize=32000, Int_t splitlevel=99)
Definition TTree.h:407
TTreeFormula * GetVar3()
Definition TTree.h:582
virtual void SetTreeIndex(TVirtualIndex *index)
The current TreeIndex is replaced by the new index.
Definition TTree.cxx:9468
virtual void OptimizeBaskets(ULong64_t maxMemory=10000000, Float_t minComp=1.1, Option_t *option="")
This function may be called after having filled some entries in a Tree.
Definition TTree.cxx:7153
virtual Long64_t Project(const char *hname, const char *varexp, const char *selection="", Option_t *option="", Long64_t nentries=kMaxEntries, Long64_t firstentry=0)
Make a projection of a tree using selections.
Definition TTree.cxx:7595
virtual Int_t SetCacheEntryRange(Long64_t first, Long64_t last)
interface to TTreeCache to set the cache entry range
Definition TTree.cxx:8942
static Long64_t GetMaxTreeSize()
Static function which returns the tree file size limit in bytes.
Definition TTree.cxx:6285
bool fCacheDoClusterPrefetch
! true if cache is prefetching whole clusters
Definition TTree.h:145
Int_t SetBranchAddressImp(TBranch *branch, void *addr, TBranch **ptr)
Change branch address, dealing with clone trees properly.
Definition TTree.cxx:8556
virtual bool SetAlias(const char *aliasName, const char *aliasFormula)
Set a tree variable alias.
Definition TTree.cxx:8252
virtual Int_t GetTimerInterval() const
Definition TTree.h:566
virtual void CopyAddresses(TTree *, bool undo=false)
Set branch addresses of passed tree equal to ours.
Definition TTree.cxx:3306
virtual void SetScanField(Int_t n=50)
Sets the default maximum number of lines to be shown before <CR> when calling Scan().
Definition TTree.h:703
TTree(const TTree &tt)=delete
Long64_t fMaxEntries
Maximum number of entries in case of circular buffers.
Definition TTree.h:102
Int_t SetBranchAddress(const char *bname, T **add, TBranch **ptr=nullptr)
Definition TTree.h:640
TBranch * Branch(const char *name, char *address, const char *leaflist, Int_t bufsize=32000)
Definition TTree.h:391
virtual void DropBuffers(Int_t nbytes)
Drop branch buffers to accommodate nbytes below MaxVirtualsize.
Definition TTree.cxx:4548
virtual TList * GetListOfFriends() const
Definition TTree.h:542
virtual void Refresh()
Refresh contents of this tree and its branches from the current status on disk.
Definition TTree.cxx:8013
virtual void SetAutoFlush(Long64_t autof=-30000000)
This function may be called at the start of a program to change the default value for fAutoFlush.
Definition TTree.cxx:8307
static Long64_t fgMaxTreeSize
Maximum size of a file containing a Tree.
Definition TTree.h:160
Long64_t fReadEntry
! Number of the entry being processed
Definition TTree.h:112
TArrayD fIndexValues
Sorted index values.
Definition TTree.h:132
void MarkEventCluster()
Mark the previous event as being at the end of the event cluster.
Definition TTree.cxx:8369
virtual Int_t GetNbranches()
Definition TTree.h:554
UInt_t fNEntriesSinceSorting
! Number of entries processed since the last re-sorting of branches
Definition TTree.h:148
virtual void SetClusterPrefetch(bool enabled)
Definition TTree.h:663
virtual void SetFileNumber(Int_t number=0)
Set fFileNumber to number.
Definition TTree.cxx:9264
virtual TLeaf * FindLeaf(const char *name)
Find leaf..
Definition TTree.cxx:4931
virtual void StartViewer()
Start the TTreeViewer on this tree.
Definition TTree.cxx:9581
Int_t GetMakeClass() const
Definition TTree.h:547
virtual Int_t MakeCode(const char *filename=nullptr)
Generate a skeleton function for this tree.
Definition TTree.cxx:6660
bool fIMTFlush
! True if we are doing a multithreaded flush.
Definition TTree.h:164
TDirectory * fDirectory
! Pointer to directory holding this tree
Definition TTree.h:126
ESetBranchAddressStatus
Definition TTree.h:244
@ kNeedEnableDecomposedObj
Definition TTree.h:256
@ kClassMismatch
Definition TTree.h:249
@ kNeedDisableDecomposedObj
Definition TTree.h:257
@ kVoidPtr
Definition TTree.h:254
@ kNoCheck
Definition TTree.h:255
@ kMatchConversionCollection
Definition TTree.h:252
@ kMissingCompiledCollectionProxy
Definition TTree.h:247
@ kMismatch
Definition TTree.h:248
@ kMatchConversion
Definition TTree.h:251
@ kInternalError
Definition TTree.h:246
@ kDecomposedObjMask
Definition TTree.h:258
@ kMatch
Definition TTree.h:250
@ kMissingBranch
Definition TTree.h:245
@ kMakeClass
Definition TTree.h:253
static Int_t fgBranchStyle
Old/New branch style.
Definition TTree.h:159
virtual void ResetBranchAddresses()
Tell all of our branches to drop their current objects and allocate new ones.
Definition TTree.cxx:8172
Int_t fNfill
! Local for EntryLoop
Definition TTree.h:115
void SetName(const char *name) override
Change the name of this tree.
Definition TTree.cxx:9327
virtual Long64_t GetCacheSize() const
Definition TTree.h:465
virtual void RegisterExternalFriend(TFriendElement *)
Record a TFriendElement that we need to warn when the chain switches to a new file (typically this is...
Definition TTree.cxx:8054
TArrayI fIndex
Index of sorted values.
Definition TTree.h:133
virtual Int_t GetPacketSize() const
Definition TTree.h:557
virtual Int_t SetCacheSize(Long64_t cachesize=-1)
Set maximum size of the file cache .
Definition TTree.cxx:8794
void AddClone(TTree *)
Add a cloned tree to our list of trees to be notified whenever we change our branch addresses or when...
Definition TTree.cxx:1213
virtual Int_t CheckBranchAddressType(TBranch *branch, TClass *ptrClass, EDataType datatype, bool ptr)
Check whether or not the address described by the last 3 parameters matches the content of the branch...
Definition TTree.cxx:2868
TBuffer * GetTransientBuffer(Int_t size)
Returns the transient buffer currently used by this TTree for reading/writing baskets.
Definition TTree.cxx:1031
ROOT::TIOFeatures GetIOFeatures() const
Returns the current set of IO settings.
Definition TTree.cxx:6094
virtual Int_t MakeClass(const char *classname=nullptr, Option_t *option="")
Generate a skeleton analysis class for this tree.
Definition TTree.cxx:6627
virtual Int_t GetFileNumber() const
Definition TTree.h:528
virtual const char * GetFriendAlias(TTree *) const
If the 'tree' is a friend, this method returns its alias name.
Definition TTree.cxx:6052
virtual void SetChainOffset(Long64_t offset=0)
Definition TTree.h:661
virtual void RemoveExternalFriend(TFriendElement *)
Removes external friend.
Definition TTree.cxx:8065
virtual Double_t * GetW()
Definition TTree.h:595
TTreeFormula * GetVar1()
Definition TTree.h:578
virtual Double_t * GetV2()
Definition TTree.h:590
Int_t fPacketSize
! Number of entries in one packet for parallel root
Definition TTree.h:114
virtual Int_t GetUpdate() const
Definition TTree.h:573
virtual Long64_t GetChainOffset() const
Definition TTree.h:468
virtual TBranch * BranchImpArr(const char *branchname, EDataType datatype, std::size_t N, void *addobj, Int_t bufsize, Int_t splitlevel)
Definition TTree.cxx:1725
virtual Long64_t Scan(const char *varexp="", const char *selection="", Option_t *option="", Long64_t nentries=kMaxEntries, Long64_t firstentry=0)
Loop over tree entries and print entries passing selection.
Definition TTree.cxx:8210
virtual TBranch * BronchExec(const char *name, const char *classname, void *addobj, bool isptrptr, Int_t bufsize, Int_t splitlevel)
Helper function implementing TTree::Bronch and TTree::Branch(const char *name, T &obj);.
Definition TTree.cxx:2409
virtual Long64_t GetMaxEntryLoop() const
Definition TTree.h:549
virtual void AddTotBytes(Int_t tot)
Definition TTree.h:343
virtual Long64_t CopyEntries(TTree *tree, Long64_t nentries=-1, Option_t *option="", bool needCopyAddresses=false)
Copy nentries from given tree to this tree.
Definition TTree.cxx:3541
Int_t fMakeClass
! not zero when processing code generated by MakeClass
Definition TTree.h:120
virtual Int_t LoadBaskets(Long64_t maxmemory=2000000000)
Read in memory all baskets from all branches up to the limit of maxmemory bytes.
Definition TTree.cxx:6471
static constexpr Long64_t kMaxEntries
Definition TTree.h:241
TPrincipal * Principal(const char *varexp="", const char *selection="", Option_t *option="np", Long64_t nentries=kMaxEntries, Long64_t firstentry=0)
Interface to the Principal Components Analysis class.
Definition TTree.cxx:7296
std::unordered_map< std::string, TBranch * > fNamesToBranches
! maps names to their branches, useful when retrieving branches by name
Definition TTree.h:169
virtual Long64_t GetAutoFlush() const
Definition TTree.h:459
virtual Long64_t GetMaxVirtualSize() const
Definition TTree.h:552
Abstract interface for Tree Index.
Provides the interface for the PROOF internal performance measurement and event tracing.
Abstract base class defining the interface for the plugins that implement Draw, Scan,...
virtual TTreeFormula * GetVar1() const =0
virtual Double_t * GetV4() const =0
virtual Double_t * GetW() const =0
virtual TTreeFormula * GetVar4() const =0
virtual TTreeFormula * GetVar(Int_t) const =0
virtual Double_t * GetVal(Int_t) const =0
virtual TTreeFormula * GetVar2() const =0
virtual Double_t * GetV1() const =0
static constexpr Long64_t kMaxEntries
virtual TTreeFormula * GetVar3() const =0
virtual Double_t * GetV2() const =0
virtual TTreeFormula * GetSelect() const =0
virtual TH1 * GetHistogram() const =0
virtual Long64_t GetSelectedRows() const =0
virtual Double_t * GetV3() const =0
const Int_t n
Definition legend1.C:16
Namespace hosting functions and classes to retrieve tree information for internal use.
Definition RTTreeDS.hxx:49
void TBranch__SetTree(TTree *tree, TObjArray &branches)
Set the fTree member for all branches and sub branches.
Definition TTree.cxx:9630
th1 Draw()
auto * tt
Definition textangle.C:16