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", bool long64major = false, bool long64minor = false);
433 /// Build index with only a major formula. Minor formula will be set to "0" ie skip.
434 /// \see TTree::BuildIndex(const char *, const char *, bool, bool)
435 Int_t BuildIndex(const char *majorname, bool long64major) { return BuildIndex(majorname, "0", long64major, false); }
436 TStreamerInfo *BuildStreamerInfo(TClass* cl, void *pointer = nullptr, bool canOptimize = true);
437 virtual TFile *ChangeFile(TFile* file);
438 virtual TTree *CloneTree(Long64_t nentries = -1, Option_t* option = "");
439 virtual void CopyAddresses(TTree*,bool undo = false);
440 virtual Long64_t CopyEntries(TTree* tree, Long64_t nentries = -1, Option_t *option = "", bool needCopyAddresses = false);
442 virtual TBasket *CreateBasket(TBranch*);
443 virtual void DirectoryAutoAdd(TDirectory *);
444 Int_t Debug() const { return fDebug; }
445 void Delete(Option_t* option = "") override; // *MENU*
446 void Draw(Option_t* opt) override { Draw(opt, "", "", kMaxEntries, 0); }
447 virtual Long64_t Draw(const char* varexp, const TCut& selection, Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0);
448 virtual Long64_t Draw(const char* varexp, const char* selection, Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0); // *MENU*
449 virtual void DropBaskets();
450 virtual void DropBuffers(Int_t nbytes);
451 bool EnableCache();
452 virtual Int_t Fill();
453 virtual TBranch *FindBranch(const char* name);
454 virtual TLeaf *FindLeaf(const char* name);
455 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*
456 virtual Int_t FlushBaskets(bool create_cluster = true) const;
457 virtual const char *GetAlias(const char* aliasName) const;
459#ifdef R__TRACK_BASKET_ALLOC_TIME
461#endif
462 virtual Long64_t GetAutoFlush() const {return fAutoFlush;}
463 virtual Long64_t GetAutoSave() const {return fAutoSave;}
464 virtual TBranch *GetBranch(const char* name);
465 virtual TBranchRef *GetBranchRef() const { return fBranchRef; };
466 virtual bool GetBranchStatus(const char* branchname) const;
467 static Int_t GetBranchStyle();
468 virtual Long64_t GetCacheSize() const { return fCacheSize; }
469 virtual TClusterIterator GetClusterIterator(Long64_t firstentry);
471 virtual Long64_t GetChainOffset() const { return fChainOffset; }
472 virtual bool GetClusterPrefetch() const { return fCacheDoClusterPrefetch; }
473 TFile *GetCurrentFile() const;
475 Long64_t GetDebugMax() const { return fDebugMax; }
476 Long64_t GetDebugMin() const { return fDebugMin; }
477 TDirectory *GetDirectory() const { return fDirectory; }
478 virtual Long64_t GetEntries() const { return fEntries; }
479 virtual Long64_t GetEntries(const char *selection);
480 /// Return a number greater or equal to the total number of entries in the
481 /// dataset.
482 ///
483 /// \note If you are interested in the total number of entries in a TChain,
484 /// this function will give that number once the last file of the chain
485 /// is opened. In general, using this instead of GetEntries will avoid
486 /// opening all files in the chain which could be very costly for very
487 /// large number of files stored at a remote location.
488 ///
489 /// The logic depends on whether the dataset is a TTree or a TChain. In the
490 /// first case, it simply returns the total number of entries in the tree. In
491 /// the latter case, it depends on which point of the processing of the chain
492 /// this function is called. During most of the chain processing, this
493 /// function will return TTree::kMaxEntries. When the chain arrives at the
494 /// last file, then the function will return the accumulated total number of
495 /// entries in the whole chain. A notable use case where this function
496 /// becomes quite useful is when writing the following for loop to traverse
497 /// the entries in the dataset:
498 ///
499 /// \code{.cpp}
500 /// for(Long64_t ievent = 0; ievent < dataset.GetEntriesFast(); ievent++) {
501 /// // Do something with the event in the dataset
502 /// }
503 /// \endcode
504 ///
505 /// In the example above, independently on whether the dataset is a TTree or
506 /// a TChain, the GetEntriesFast call will provide the correct stopping
507 /// condition for the loop (i.e. the total number of entries). In the TChain
508 /// case, calling GetEntries instead would open all the files in the chain
509 /// upfront which could be costly.
510 ///
511 /// The functionality offered by this method can also be seen when used in
512 /// conjunction with LoadTree. For a call like <tt> LoadTree(ievent) </tt>,
513 /// the condition <tt> ievent < dataset.GetEntriesFast() </tt> is only
514 /// satisfied if \p ievent is strictly smaller than the total number of
515 /// entries in the dataset. In fact, even when the dataset is a TChain, the
516 /// first time LoadTree is called with an entry number that belongs to the
517 /// last file of the chain, this will update the internal data member of the
518 /// class so that the next call to GetEntriesFast returns the total number
519 /// of entries in the dataset.
520 virtual Long64_t GetEntriesFast() const { return fEntries; }
521 virtual Long64_t GetEntriesFriend() const;
522 virtual Long64_t GetEstimate() const { return fEstimate; }
523 virtual Int_t GetEntry(Long64_t entry, Int_t getall = 0);
528 TEventList *GetEventList() const { return fEventList; }
529 virtual TEntryList *GetEntryList();
530 virtual Long64_t GetEntryNumber(Long64_t entry) const;
531 virtual Int_t GetFileNumber() const { return fFileNumber; }
532 virtual TTree *GetFriend(const char*) const;
533 virtual const char *GetFriendAlias(TTree*) const;
535 virtual bool GetImplicitMT() { return fIMTEnabled; }
536 virtual Int_t *GetIndex() { return &fIndex.fArray[0]; }
537 virtual Double_t *GetIndexValues() { return &fIndexValues.fArray[0]; }
539 virtual TIterator *GetIteratorOnAllLeaves(bool dir = kIterForward);
540 virtual TLeaf *GetLeaf(const char* branchname, const char* leafname);
541 virtual TLeaf *GetLeaf(const char* name);
542 virtual TList *GetListOfClones() { return fClones; }
543 virtual TObjArray *GetListOfBranches() { return &fBranches; }
544 virtual TObjArray *GetListOfLeaves() { return &fLeaves; }
545 virtual TList *GetListOfFriends() const { return fFriends; }
546 virtual TList *GetListOfAliases() const { return fAliases; }
547
548 // GetMakeClass is left non-virtual for efficiency reason.
549 // Making it virtual affects the performance of the I/O
550 Int_t GetMakeClass() const { return fMakeClass; }
551
552 virtual Long64_t GetMaxEntryLoop() const { return fMaxEntryLoop; }
553 virtual Double_t GetMaximum(const char* columname);
554 static Long64_t GetMaxTreeSize();
555 virtual Long64_t GetMaxVirtualSize() const { return fMaxVirtualSize; }
556 virtual Double_t GetMinimum(const char* columname);
558 TObject *GetNotify() const { return fNotify; }
560 virtual Int_t GetPacketSize() const { return fPacketSize; }
561 virtual TVirtualPerfStats *GetPerfStats() const { return fPerfStats; }
562 TTreeCache *GetReadCache(TFile *file) const;
563 TTreeCache *GetReadCache(TFile *file, bool create);
564 virtual Long64_t GetReadEntry() const { return fReadEntry; }
565 virtual Long64_t GetReadEvent() const { return fReadEntry; }
566 virtual Int_t GetScanField() const { return fScanField; }
569 virtual Int_t GetTimerInterval() const { return fTimerInterval; }
571 virtual Long64_t GetTotBytes() const { return fTotBytes; }
572 virtual TTree *GetTree() const { return const_cast<TTree*>(this); }
573 virtual TVirtualIndex *GetTreeIndex() const { return fTreeIndex; }
574 virtual Int_t GetTreeNumber() const { return 0; }
576 virtual Int_t GetUpdate() const { return fUpdate; }
577 virtual TList *GetUserInfo();
578 // See TSelectorDraw::GetVar
580 // See TSelectorDraw::GetVar
582 // See TSelectorDraw::GetVar
584 // See TSelectorDraw::GetVar
586 // See TSelectorDraw::GetVar
588 // See TSelectorDraw::GetVal
589 virtual Double_t *GetVal(Int_t i) { return GetPlayer()->GetVal(i); }
590 // See TSelectorDraw::GetVal
591 virtual Double_t *GetV1() { return GetPlayer()->GetV1(); }
592 // See TSelectorDraw::GetVal
593 virtual Double_t *GetV2() { return GetPlayer()->GetV2(); }
594 // See TSelectorDraw::GetVal
595 virtual Double_t *GetV3() { return GetPlayer()->GetV3(); }
596 // See TSelectorDraw::GetVal
597 virtual Double_t *GetV4() { return GetPlayer()->GetV4(); }
598 virtual Double_t *GetW() { return GetPlayer()->GetW(); }
599 virtual Double_t GetWeight() const { return fWeight; }
600 virtual Long64_t GetZipBytes() const { return fZipBytes; }
602 bool IsFolder() const override { return true; }
603 virtual bool InPlaceClone(TDirectory *newdirectory, const char *options = "");
604 virtual Int_t LoadBaskets(Long64_t maxmemory = 2000000000);
607 virtual Int_t MakeClass(const char *classname = nullptr, Option_t* option = "");
608 virtual Int_t MakeCode(const char *filename = nullptr);
609 virtual Int_t MakeProxy(const char* classname, const char* macrofilename = nullptr, const char* cutfilename = nullptr, const char* option = nullptr, Int_t maxUnrolling = 3);
610 virtual Int_t MakeSelector(const char *selector = nullptr, Option_t *option = "");
611 bool MemoryFull(Int_t nbytes);
612 virtual Long64_t Merge(TCollection* list, Option_t* option = "");
614 static TTree *MergeTrees(TList* list, Option_t* option = "");
615 bool Notify() override;
616 virtual void OptimizeBaskets(ULong64_t maxMemory=10000000, Float_t minComp=1.1, Option_t *option="");
617 TPrincipal *Principal(const char* varexp = "", const char* selection = "", Option_t* option = "np", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0);
618 void Print(Option_t* option = "") const override; // *MENU*
619 virtual void PrintCacheStats(Option_t* option = "") const;
620 virtual Long64_t Process(const char* filename, Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0); // *MENU*
622 virtual Long64_t Project(const char* hname, const char* varexp, const char* selection = "", Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0);
623 virtual TSQLResult *Query(const char* varexp = "", const char* selection = "", Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0);
624 virtual Long64_t ReadFile(const char* filename, const char* branchDescriptor = "", char delimiter = ' ');
625 virtual Long64_t ReadStream(std::istream& inputStream, const char* branchDescriptor = "", char delimiter = ' ');
626 virtual void Refresh();
628 virtual void RemoveExternalFriend(TFriendElement *);
629 virtual void RemoveFriend(TTree*);
630 void RecursiveRemove(TObject *obj) override;
631 virtual void Reset(Option_t* option = "");
632 virtual void ResetAfterMerge(TFileMergeInfo *);
633 virtual void ResetBranchAddress(TBranch *);
634 virtual void ResetBranchAddresses();
635 virtual Long64_t Scan(const char* varexp = "", const char* selection = "", Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0); // *MENU*
636 virtual bool SetAlias(const char* aliasName, const char* aliasFormula);
637 virtual void SetAutoSave(Long64_t autos = -300000000);
638 virtual void SetAutoFlush(Long64_t autof = -30000000);
639 virtual void SetBasketSize(const char* bname, Int_t buffsize = 16000);
640 virtual Int_t SetBranchAddress(const char *bname,void *add, TBranch **ptr = nullptr);
641 virtual Int_t SetBranchAddress(const char *bname,void *add, TClass *realClass, EDataType datatype, bool isptr);
642 virtual Int_t SetBranchAddress(const char *bname,void *add, TBranch **ptr, TClass *realClass, EDataType datatype, bool isptr);
643 template <class T> Int_t SetBranchAddress(const char *bname, T **add, TBranch **ptr = nullptr) {
644 TClass *cl = TClass::GetClass<T>();
646 if (!cl) type = TDataType::GetType(typeid(T));
647 return SetBranchAddress(bname,add,ptr,cl,type,true);
648 }
649#ifndef R__NO_CLASS_TEMPLATE_SPECIALIZATION
650 // This can only be used when the template overload resolution can distinguish between
651 // T* and T**
652 template <class T> Int_t SetBranchAddress(const char *bname, T *add, TBranch **ptr = nullptr) {
653 TClass *cl = TClass::GetClass<T>();
655 if (!cl) type = TDataType::GetType(typeid(T));
656 return SetBranchAddress(bname,add,ptr,cl,type,false);
657 }
658#endif
659 virtual void SetBranchStatus(const char* bname, bool status = true, UInt_t* found = nullptr);
660 static void SetBranchStyle(Int_t style = 1); //style=0 for old branch, =1 for new branch style
661 virtual Int_t SetCacheSize(Long64_t cachesize = -1);
662 virtual Int_t SetCacheEntryRange(Long64_t first, Long64_t last);
663 virtual void SetCacheLearnEntries(Int_t n=10);
665 virtual void SetCircular(Long64_t maxEntries);
667 virtual void SetDebug(Int_t level = 1, Long64_t min = 0, Long64_t max = 9999999); // *MENU*
668 virtual void SetDefaultEntryOffsetLen(Int_t newdefault, bool updateExisting = false);
669 virtual void SetDirectory(TDirectory* dir);
670 virtual Long64_t SetEntries(Long64_t n = -1);
671 virtual void SetEstimate(Long64_t nentries = 1000000);
673 virtual void SetFileNumber(Int_t number = 0);
674 virtual void SetEventList(TEventList* list);
675 virtual void SetEntryList(TEntryList* list, Option_t *opt="");
676 virtual void SetImplicitMT(bool enabled) { fIMTEnabled = enabled; }
677 virtual void SetMakeClass(Int_t make);
679 static void SetMaxTreeSize(Long64_t maxsize = 100000000000LL);
680 virtual void SetMaxVirtualSize(Long64_t size = 0) { fMaxVirtualSize = size; } // *MENU*
681 void SetName(const char* name) override; // *MENU*
682
683 /**
684 * @brief Sets the address of the object to be notified when the tree is loaded.
685 *
686 * The method TObject::Notify is called for the given object when the tree
687 * is loaded. Specifically this occurs in the TTree::LoadTree method. To
688 * remove the notification call this method with nullptr:
689 * @code tree->SetNotify(nullptr); @endcode
690 *
691 * If this is a TChain, `obj` is most often going to be a TNotifyLink.
692 *
693 * @param[in] obj Pointer to a TObject to be notified.
694 */
695 virtual void SetNotify(TObject* obj);
696
697 virtual void SetObject(const char* name, const char* title);
698 virtual void SetParallelUnzip(bool opt=true, Float_t RelSize=-1);
699 virtual void SetPerfStats(TVirtualPerfStats* perf);
700 /**
701 * \brief Sets the default maximum number of lines to be shown before `<CR>` when calling Scan().
702 * \param n the maximum number of lines. Default=50, if 0, all entries of the Tree are shown
703 * and there is no need to press `<CR>` or `q` to exit the function.
704 * \see TTreePlayer::Scan for more details on how to redirect the output to an ASCII file
705 */
706 virtual void SetScanField(Int_t n = 50) { fScanField = n; } // *MENU*
709 virtual void SetTreeIndex(TVirtualIndex* index);
710 virtual void SetWeight(Double_t w = 1, Option_t* option = "");
711 virtual void SetUpdate(Int_t freq = 0) { fUpdate = freq; }
712 virtual void Show(Long64_t entry = -1, Int_t lenmax = 20);
713 virtual void StartViewer(); // *MENU*
715 virtual Int_t UnbinnedFit(const char* funcname, const char* varexp, const char* selection = "", Option_t* option = "", Long64_t nentries = kMaxEntries, Long64_t firstentry = 0);
716 void UseCurrentStyle() override;
717 Int_t Write(const char *name=nullptr, Int_t option=0, Int_t bufsize=0) override;
718 Int_t Write(const char *name=nullptr, Int_t option=0, Int_t bufsize=0) const override;
719
720 ClassDefOverride(TTree, 20) // Tree descriptor (the main ROOT I/O class)
721};
722
723//////////////////////////////////////////////////////////////////////////
724// //
725// TTreeFriendLeafIter //
726// //
727// Iterator on all the leaves in a TTree and its friend //
728// //
729//////////////////////////////////////////////////////////////////////////
730
732
733protected:
734 TTree *fTree; ///< tree being iterated
735 TIterator *fLeafIter; ///< current leaf sub-iterator.
736 TIterator *fTreeIter; ///< current tree sub-iterator.
737 bool fDirection; ///< iteration direction
738
739 TTreeFriendLeafIter() : fTree(nullptr), fLeafIter(nullptr), fTreeIter(nullptr),
740 fDirection(false) { }
741
742public:
743 TTreeFriendLeafIter(const TTree* t, bool dir = kIterForward);
746 TIterator &operator=(const TIterator &rhs) override;
748
749 const TCollection *GetCollection() const override { return nullptr; }
750 Option_t *GetOption() const override;
751 TObject *Next() override;
753 bool operator !=(const TIterator&) const override {
754 // TODO: Implement me
755 return false;
756 }
757 bool operator !=(const TTreeFriendLeafIter&) const {
758 // TODO: Implement me
759 return false;
760 }
761 TObject *operator*() const override {
762 // TODO: Implement me
763 return nullptr;
764 }
765 ClassDefOverride(TTreeFriendLeafIter,0) //Linked list iterator
766 };
767
768
769#endif
#define SafeDelete(p)
Definition RConfig.hxx:538
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:108
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:731
bool operator!=(const TIterator &) const override
Compare two iterator objects.
Definition TTree.h:753
const TCollection * GetCollection() const override
Definition TTree.h:749
TTree * fTree
tree being iterated
Definition TTree.h:734
TObject * operator*() const override
Return current object or nullptr.
Definition TTree.h:761
void Reset() override
Definition TTree.h:752
TIterator & operator=(const TIterator &rhs) override
Overridden assignment operator. Does NOT copy the 'cursor' location!
Definition TTree.cxx:9906
~TTreeFriendLeafIter() override
Definition TTree.h:745
TObject * Next() override
Go the next friend element.
Definition TTree.cxx:9929
TIterator * fLeafIter
current leaf sub-iterator.
Definition TTree.h:735
Option_t * GetOption() const override
Returns the object option stored in the list.
Definition TTree.cxx:9968
TIterator * fTreeIter
current tree sub-iterator.
Definition TTree.h:736
bool fDirection
iteration direction
Definition TTree.h:737
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:4610
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:4846
virtual TVirtualPerfStats * GetPerfStats() const
Definition TTree.h:561
virtual void SetTimerInterval(Int_t msec=333)
Definition TTree.h:708
virtual void SetBranchStatus(const char *bname, bool status=true, UInt_t *found=nullptr)
Set branch status to Process or DoNotProcess.
Definition TTree.cxx:8635
TTreeFormula * GetSelect()
Definition TTree.h:567
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:5299
virtual Int_t GetScanField() const
Definition TTree.h:566
static Int_t GetBranchStyle()
Static function returning the current branch style.
Definition TTree.cxx:5403
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:470
virtual bool GetBranchStatus(const char *branchname) const
Return status of branch with name branchname.
Definition TTree.cxx:5388
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:6108
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:5134
Int_t GetDefaultEntryOffsetLen() const
Definition TTree.h:474
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:9497
TEventList * fEventList
! Pointer to event selection list (if one)
Definition TTree.h:130
virtual Long64_t GetAutoSave() const
Definition TTree.h:463
virtual Int_t StopCacheLearningPhase()
Stop the cache learning phase.
Definition TTree.cxx:9586
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:5648
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:8993
virtual Long64_t GetEstimate() const
Definition TTree.h:522
Long64_t GetDebugMax() const
Definition TTree.h:475
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:8398
virtual TClusterIterator GetClusterIterator(Long64_t firstentry)
Return an iterator over the cluster of baskets starting at firstentry.
Definition TTree.cxx:5475
virtual void ResetBranchAddress(TBranch *)
Tell a branch to set its address to zero.
Definition TTree.cxx:8152
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:7675
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:568
void AddAllocationCount(UInt_t count)
Definition TTree.h:349
virtual void SetMaxEntryLoop(Long64_t maxev=kMaxEntries)
Definition TTree.h:678
virtual Long64_t GetEntryNumberWithIndex(Long64_t major, Long64_t minor=0) const
Return entry number corresponding to major and minor number.
Definition TTree.cxx:5920
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:9112
virtual TObjArray * GetListOfLeaves()
Definition TTree.h:544
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:5415
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:5487
TObject * GetNotify() const
Definition TTree.h:558
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:5084
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:7968
TVirtualTreePlayer * GetPlayer()
Load the TTreePlayer (if not already done).
Definition TTree.cxx:6315
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:6778
Float_t fTargetMemoryRatio
! Ratio for memory usage in uncompressed buffers versus actual occupancy.
Definition TTree.h:151
virtual Double_t * GetIndexValues()
Definition TTree.h:537
virtual TList * GetListOfAliases() const
Definition TTree.h:546
virtual Long64_t ReadStream(std::istream &inputStream, const char *branchDescriptor="", char delimiter=' ')
Create or simply read branches from an input stream.
Definition TTree.cxx:7702
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:9029
Int_t fScanField
Number of runs before prompting in Scan.
Definition TTree.h:97
virtual Double_t GetWeight() const
Definition TTree.h:599
void Draw(Option_t *opt) override
Default Draw method for all objects.
Definition TTree.h:446
virtual TTree * GetFriend(const char *) const
Return a pointer to the TTree friend whose name or alias is friendname.
Definition TTree.cxx:5985
TTreeFormula * GetVar(Int_t i)
Definition TTree.h:579
virtual void SetNotify(TObject *obj)
Sets the address of the object to be notified when the tree is loaded.
Definition TTree.cxx:9343
virtual Double_t GetMaximum(const char *columname)
Return maximum of column with name columname.
Definition TTree.cxx:6245
virtual Long64_t GetEntryNumberWithBestIndex(Long64_t major, Long64_t minor=0) const
Return entry number corresponding to major and minor number.
Definition TTree.cxx:5900
static void SetMaxTreeSize(Long64_t maxsize=100000000000LL)
Set the maximum size in bytes of a Tree file (static function).
Definition TTree.cxx:9309
void Print(Option_t *option="") const override
Print a summary of the tree contents.
Definition TTree.cxx:7305
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:9816
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:7457
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:6092
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:9289
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:7098
virtual void IncrementTotalBuffers(Int_t nbytes)
Definition TTree.h:601
TObjArray fBranches
List of Branches.
Definition TTree.h:127
TDirectory * GetDirectory() const
Definition TTree.h:477
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:6328
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:5864
virtual void SetWeight(Double_t w=1, Option_t *option="")
Set tree weight.
Definition TTree.cxx:9486
void InitializeBranchLists(bool checkLeafCount)
Divides the top-level branches into two vectors: (i) branches to be processed sequentially and (ii) b...
Definition TTree.cxx:5791
virtual Int_t SetBranchAddress(const char *bname, void *add, TBranch **ptr=nullptr)
Change branch address, dealing with clone trees properly.
Definition TTree.cxx:8486
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:9441
TTreeFormula * GetVar2()
Definition TTree.h:583
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:8966
Int_t SetBranchAddress(const char *bname, T *add, TBranch **ptr=nullptr)
Definition TTree.h:652
void SetTargetMemoryRatio(Float_t ratio)
Definition TTree.h:707
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:573
Int_t Debug() const
Definition TTree.h:444
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:6912
virtual void SetMaxVirtualSize(Long64_t size=0)
Definition TTree.h:680
virtual void DropBaskets()
Remove some baskets from memory.
Definition TTree.cxx:4525
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:8443
virtual bool GetClusterPrefetch() const
Definition TTree.h:472
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
Int_t BuildIndex(const char *majorname, bool long64major)
Build index with only a major formula.
Definition TTree.h:435
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:575
virtual void SetParallelUnzip(bool opt=true, Float_t RelSize=-1)
Enable or disable parallel unzipping of Tree buffers.
Definition TTree.cxx:9403
virtual void SetDirectory(TDirectory *dir)
Change the tree's directory.
Definition TTree.cxx:9067
void SortBranchesByTime()
Sorts top-level branches by the last average task time recorded per branch.
Definition TTree.cxx:5844
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:536
virtual TBranchRef * GetBranchRef() const
Definition TTree.h:465
virtual Double_t * GetV3()
Definition TTree.h:595
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:7537
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:9170
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:7069
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:8121
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:478
virtual void SetEstimate(Long64_t nentries=1000000)
Set number of entries to estimate variable limits.
Definition TTree.cxx:9211
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:8812
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:5875
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:535
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:6205
virtual Long64_t GetZipBytes() const
Definition TTree.h:600
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:8090
virtual void SetImplicitMT(bool enabled)
Definition TTree.h:676
virtual void KeepCircular()
Keep a maximum of fMaxEntries in memory.
Definition TTree.cxx:6425
virtual void SetDefaultEntryOffsetLen(Int_t newdefault, bool updateExisting=false)
Update the default value for the branch's fEntryOffsetLen.
Definition TTree.cxx:9041
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:571
virtual Int_t MakeSelector(const char *selector=nullptr, Option_t *option="")
Generate skeleton selector class for this tree.
Definition TTree.cxx:6832
virtual void SetObject(const char *name, const char *title)
Change the name and title of this tree.
Definition TTree.cxx:9372
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:711
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:5937
static TTree * MergeTrees(TList *list, Option_t *option="")
Static function merging the trees in the TList into a new tree.
Definition TTree.cxx:6863
bool MemoryFull(Int_t nbytes)
Check if adding nbytes to memory we are still below MaxVirtualsize.
Definition TTree.cxx:6847
TTreeFormula * GetVar4()
Definition TTree.h:587
virtual Long64_t GetReadEntry() const
Definition TTree.h:564
virtual TObjArray * GetListOfBranches()
Definition TTree.h:543
Long64_t fZipBytes
Total number of bytes in all branches after compression.
Definition TTree.h:92
virtual TTree * GetTree() const
Definition TTree.h:572
TBuffer * fTransientBuffer
! Pointer to the current transient buffer.
Definition TTree.h:143
virtual Double_t * GetVal(Int_t i)
Definition TTree.h:589
virtual void SetEntryList(TEntryList *list, Option_t *opt="")
Set an EntryList.
Definition TTree.cxx:9147
bool Notify() override
Function called when loading a new class library.
Definition TTree.cxx:7119
virtual void AddZipBytes(Int_t zip)
Definition TTree.h:344
virtual Long64_t LoadTree(Long64_t entry)
Set current entry.
Definition TTree.cxx:6483
virtual Long64_t ReadFile(const char *filename, const char *branchDescriptor="", char delimiter=' ')
Create or simply read branches from filename.
Definition TTree.cxx:7651
virtual const char * GetAlias(const char *aliasName) const
Returns the expanded value of the alias. Search in the friends if any.
Definition TTree.cxx:5231
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:9231
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:6285
virtual void RemoveFriend(TTree *)
Remove a friend from the list of friends.
Definition TTree.cxx:8064
virtual Long64_t GetEntriesFast() const
Return a number greater or equal to the total number of entries in the dataset.
Definition TTree.h:520
void Browse(TBrowser *) override
Browse content of the TTree.
Definition TTree.cxx:2606
virtual Double_t * GetV1()
Definition TTree.h:591
virtual TList * GetUserInfo()
Return a pointer to the list containing user objects associated to this tree.
Definition TTree.cxx:6366
void RegisterBranchFullName(std::pair< std::string, TBranch * > &&kv)
Definition TTree.h:177
TEventList * GetEventList() const
Definition TTree.h:528
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:5520
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:7600
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:8459
static void SetBranchStyle(Int_t style=1)
Set the current branch style.
Definition TTree.cxx:8766
virtual Long64_t GetReadEvent() const
Definition TTree.h:565
~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:602
void ImportClusterRanges(TTree *fromtree)
Appends the cluster range information stored in 'fromtree' to this tree, including the value of fAuto...
Definition TTree.cxx:6382
Long64_t fEstimate
Number of entries to estimate histogram limits.
Definition TTree.h:107
TH1 * GetHistogram()
Definition TTree.h:534
UInt_t GetAllocationCount() const
Definition TTree.h:458
Int_t FlushBasketsImpl() const
Internal implementation of the FlushBaskets algorithm.
Definition TTree.cxx:5151
Long64_t GetDebugMin() const
Definition TTree.h:476
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:6567
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:9867
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:9828
virtual Int_t GetTreeNumber() const
Definition TTree.h:574
Int_t GetEvent(Long64_t entry, Int_t getall=0)
Definition TTree.h:524
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:542
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:597
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:585
virtual void SetTreeIndex(TVirtualIndex *index)
The current TreeIndex is replaced by the new index.
Definition TTree.cxx:9458
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:7143
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:7585
virtual Int_t SetCacheEntryRange(Long64_t first, Long64_t last)
interface to TTreeCache to set the cache entry range
Definition TTree.cxx:8932
static Long64_t GetMaxTreeSize()
Static function which returns the tree file size limit in bytes.
Definition TTree.cxx:6275
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:8546
virtual bool SetAlias(const char *aliasName, const char *aliasFormula)
Set a tree variable alias.
Definition TTree.cxx:8242
virtual Int_t GetTimerInterval() const
Definition TTree.h:569
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:706
virtual Int_t BuildIndex(const char *majorname, const char *minorname="0", bool long64major=false, bool long64minor=false)
Build a Tree Index (default is TTreeIndex).
Definition TTree.cxx:2634
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:643
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:4538
virtual TList * GetListOfFriends() const
Definition TTree.h:545
virtual void Refresh()
Refresh contents of this tree and its branches from the current status on disk.
Definition TTree.cxx:8003
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:8297
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:8359
virtual Int_t GetNbranches()
Definition TTree.h:557
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:666
virtual void SetFileNumber(Int_t number=0)
Set fFileNumber to number.
Definition TTree.cxx:9254
virtual TLeaf * FindLeaf(const char *name)
Find leaf..
Definition TTree.cxx:4921
virtual void StartViewer()
Start the TTreeViewer on this tree.
Definition TTree.cxx:9571
Int_t GetMakeClass() const
Definition TTree.h:550
virtual Int_t MakeCode(const char *filename=nullptr)
Generate a skeleton function for this tree.
Definition TTree.cxx:6650
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:8162
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:9317
virtual Long64_t GetCacheSize() const
Definition TTree.h:468
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:8044
TArrayI fIndex
Index of sorted values.
Definition TTree.h:133
virtual Int_t GetPacketSize() const
Definition TTree.h:560
virtual Int_t SetCacheSize(Long64_t cachesize=-1)
Set maximum size of the file cache .
Definition TTree.cxx:8784
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:6084
virtual Int_t MakeClass(const char *classname=nullptr, Option_t *option="")
Generate a skeleton analysis class for this tree.
Definition TTree.cxx:6617
virtual Int_t GetFileNumber() const
Definition TTree.h:531
virtual const char * GetFriendAlias(TTree *) const
If the 'tree' is a friend, this method returns its alias name.
Definition TTree.cxx:6042
virtual void SetChainOffset(Long64_t offset=0)
Definition TTree.h:664
virtual void RemoveExternalFriend(TFriendElement *)
Removes external friend.
Definition TTree.cxx:8055
virtual Double_t * GetW()
Definition TTree.h:598
TTreeFormula * GetVar1()
Definition TTree.h:581
virtual Double_t * GetV2()
Definition TTree.h:593
Int_t fPacketSize
! Number of entries in one packet for parallel root
Definition TTree.h:114
virtual Int_t GetUpdate() const
Definition TTree.h:576
virtual Long64_t GetChainOffset() const
Definition TTree.h:471
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:8200
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:552
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:6461
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:7286
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:462
virtual Long64_t GetMaxVirtualSize() const
Definition TTree.h:555
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.
void TBranch__SetTree(TTree *tree, TObjArray &branches)
Set the fTree member for all branches and sub branches.
Definition TTree.cxx:9620
th1 Draw()
auto * tt
Definition textangle.C:16