204 Error(
"Add",
"object must be sortable");
286 Error(
"FindObject",
"object must be sortable");
305 Error(
"IdxAdd",
"object must be sortable");
347 Warning(
"Init",
"order must be at least 3");
396 Error(
"Rank",
"object must be sortable");
411 Error(
"Remove",
"object must be sortable");
471 TSeqCollection::Streamer(b);
481 TSeqCollection::Streamer(b);
510 fNofKeysInTree = n->
NofKeys()+1;
522 fNofKeysInTree = n->
NofKeys()+1;
578 : fTree(t), fCurCursor(0), fCursor(0), fDirection(dir)
643 if (fCursor < fTree->GetSize())
658 const TBtreeIter &iter(dynamic_cast<const TBtreeIter &>(aIter));
677 return (((
fCurCursor >= 0) && (fCurCursor < fTree->GetSize())) ?
693 ::Fatal(
"TBtInnerNode::TBtInnerNode",
"no more memory");
705 ::Fatal(
"TBtInnerNode::TBtInnerNode",
"no more memory");
729 ln->
Add(obj, ln->fLast+1);
782 R__ASSERT(0 <= stop && stop <= src->fLast );
784 for (
Int_t i = start; i <= stop; i++)
818 PushLeft(noFromThis, leftsib, pidx);
894 for (
Int_t i = 0; i <
l; i++)
987 Int_t hasLeftSib = (leafidx > 0) &&
995 }
else if (hasLeftSib) {
1002 }
else if (hasRightSib) {
1005 }
else if (leftSibFull) {
1008 }
else if (hasLeftSib) {
1023 Int_t hasLeftSib = (inneridx > 0) &&
1030 }
else if (hasLeftSib) {
1036 }
else if (hasRightSib) {
1038 }
else if (leftSibFull) {
1040 }
else if (hasLeftSib) {
1066 Int_t hasLeftSib = (leafidx > 0) &&
1076 }
else if (hasLeftSib) {
1079 }
else if (hasRightSib) {
1092 Int_t hasLeftSib = (inneridx > 0) &&
1100 }
else if (hasLeftSib) {
1102 }
else if (hasRightSib) {
1124 if (rightsib->
Psize() > 0)
1141 return sum +
Psize();
1155 ::Error(
"TBtInnerNode::operator[]",
"should not happen, 0 returned");
1162 ::Error(
"TBtInnerNode::operator[]",
"should not happen, 0 returned");
1200 tgt = rightsib->
fLast + noFromThis;
1201 src = rightsib->
fLast;
1202 rightsib->
fLast = tgt;
1223 fLast -= noFromThis;
1322 Int_t newSizeThis = nofKeys / 3;
1323 Int_t newSizeNew = (nofKeys - newSizeThis) / 2;
1324 Int_t newSizeSib = (nofKeys - newSizeThis - newSizeNew);
1326 Int_t noFromSib = rightsib->
Vsize() - newSizeSib;
1335 if (noFromThis > 0) {
1339 this->
PushRight(noFromThis-1, newNode, keyidx);
1340 rightsib->
PushLeft(noFromSib, newNode, keyidx+1);
1347 rightsib->
PushLeft(noFromSib-1, newNode, keyidx+1);
1431 R__ASSERT(0 <= stop && stop <= src->fLast);
1433 for (
Int_t i = start; i <= stop; i++)
1457 PushLeft(noFromThis, leftsib, pidx);
1536 if (
fItem[i] == that)
1628 tgt = rightsib->
fLast + noFromThis;
1629 src = rightsib->
fLast;
1630 rightsib->
fLast = tgt;
1632 rightsib->
fItem[tgt--] = rightsib->
fItem[src--];
1646 fLast -= noFromThis;
1711 Int_t newSizeThis = nofKeys / 3;
1712 Int_t newSizeNew = (nofKeys - newSizeThis) / 2;
1713 Int_t newSizeSib = (nofKeys - newSizeThis - newSizeNew);
1715 Int_t noFromSib = rightsib->
Vsize() - newSizeSib;
1723 this->
PushRight(noFromThis-1, newNode, keyidx);
1724 rightsib->
PushLeft(noFromSib, newNode, keyidx+1);
TBtLeafNode(TBtInnerNode *p, const TObject *obj=0, TBtree *t=0)
Constructor.
void SetItem(Int_t i, TBtItem &itm)
Int_t NofKeys(Int_t i) const
Return the number of keys.
friend class TBtInnerNode
TObject * Before(const TObject *obj) const
May not use this method since B-tree decides order.
void BalanceWithLeft(TBtLeafNode *l, Int_t idx)
THIS has more than LEFTSIB; move some items from THIS to LEFTSIB.
void InformParent()
Tell the parent that we are full.
static long int sum(long int i)
void ShiftLeft(Int_t cnt)
Shift.
Int_t GetNofKeys(Int_t i) const
TObject * GetKey(Int_t i) const
Int_t DecNofKeys(Int_t i, Int_t n=1)
void AppendFrom(TBtInnerNode *src, Int_t start, Int_t stop)
This should never create a full node that is, it is not used anywhere where THIS could possibly be ne...
void Fatal(const char *location, const char *msgfmt,...)
~TBtItem()
Delete a tree item.
void SetNofKeys(Int_t i, Int_t r)
virtual TBtree * GetParentTree() const
TBtInnerNode(TBtInnerNode *parent, TBtree *t=0)
Create a B-tree innernode.
Int_t Rank(const TObject *obj) const
Returns the rank of the object in the tree.
TObject * FindObject(const char *name) const
Find object using its name (see object's GetName()).
Int_t NofKeys() const
Return the number of keys.
Bool_t IsArgNull(const char *where, const TObject *obj) const
Returns true if object is a null pointer.
void RemoveItem(Int_t idx)
void Add(TObject *obj)
Add object to B-tree.
virtual ~TBtree()
Delete B-tree.
Abstract base class (ABC) of a TBtree node.
Buffer base class used for serializing objects.
TBtLeafNode * FirstLeafNode()
Return the first node.
void RootIsEmpty()
If root is empty clean up its space.
Int_t NofKeys() const
Number of key.
virtual Int_t CheckByteCount(UInt_t startpos, UInt_t bcnt, const TClass *clss)=0
void Clear(Option_t *option="")
Remove all objects from B-tree.
virtual TObject * Found(const TObject *obj, TBtNode **which, Int_t *where)=0
virtual UInt_t WriteVersion(const TClass *cl, Bool_t useBcnt=kFALSE)=0
virtual ~TBtNode()
Delete a B-tree node.
void BalanceWithRight(TBtInnerNode *r, Int_t idx)
THIS has more than RIGHTSIB.
Int_t IdxAdd(const TObject &obj)
Add object and return its index in the tree.
TObject * operator[](Int_t i) const
return an element.
TObject * operator*() const
Return current object or nullptr.
Int_t FindRankUp(const TBtNode *n) const
FindRankUp is FindRank in reverse.
Iterator abstract base class.
void AddElt(TBtItem &itm, Int_t at)
Add one element.
virtual void Add(const TObject *obj, Int_t index)=0
void PushLeft(Int_t cnt, TBtInnerNode *leftsib, Int_t parentIdx)
noFromThis==1 => moves the parent item into the leftsib, and the first item in this's array into the ...
TObject * Next()
Get next object from B-tree. Returns 0 when no more objects in tree.
void SetTree(Int_t i, TBtNode *node)
void Remove(Int_t idx)
Remove an element.
void MergeWithRight(TBtLeafNode *r, Int_t idx)
Merge.
void Reset()
Reset the B-tree iterator.
TObject * Found(const TObject *obj, TBtNode **which, Int_t *where)
Recursively look for WHAT starting in the current node.
Item stored in inner nodes of a TBtree.
TBtLeafNode * LastLeafNode()
Return the last leaf node.
TIterator & operator=(const TIterator &rhs)
Overridden assignment operator.
const Bool_t kIterForward
void MayNotUse(const char *method) const
Use this method to signal that a method (defined in a base class) may not be called in a derived clas...
TBtNode(Int_t isleaf, TBtInnerNode *p, TBtree *t=0)
Create a B-tree node.
void BalanceWith(TBtLeafNode *n, Int_t idx)
PITEM is the parent item whose key will change when keys are shifted from one LeafNode to the other...
Int_t FindRank(const TObject *obj) const
WHAT was not in any inner node; it is either here, or it's not in the tree.
TBtItem & GetItem(Int_t i) const
void Error(const char *location, const char *msgfmt,...)
TBtLeafNode * LastLeafNode()
return the last node.
void MergeWithRight(TBtInnerNode *r, Int_t idx)
Merge the 2 part of the tree.
TIterator * MakeIterator(Bool_t dir=kIterForward) const
Returns a B-tree iterator.
virtual TBtLeafNode * LastLeafNode()=0
void Split()
This function is called only when THIS is the only descendent of the root node, and THIS needs to be ...
virtual Bool_t IsSortable() const
void PushRight(Int_t cnt, TBtLeafNode *r, Int_t parentIndex)
noFromThis==1 => moves the parent item into the rightsib, and the last item in this's array into the ...
void PushLeft(Int_t cnt, TBtLeafNode *l, Int_t parentIndex)
noFromThis==1 => moves the parent item into the leftsib, and the first item in this's array into the ...
void Append(TObject *obj, TBtNode *n)
Never called from anywhere where it might fill up THIS.
void AppendFrom(TBtLeafNode *src, Int_t start, Int_t stop)
A convenience function, does not worry about the element in the parent, simply moves elements from SR...
void BalanceWithRight(TBtLeafNode *r, Int_t idx)
THIS has more than RIGHTSIB; move some items from THIS to RIGHTSIB.
R__ALWAYS_INLINE Bool_t IsOnHeap() const
void DecrNofKeys(TBtNode *np)
THAT is a child of THIS that has just shrunk by 1.
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
void RootIsFull()
The root of the tree is full.
void Append(TObject *obj)
Never called from anywhere where it might fill up THIS does NOT handle nofKeys.
void IncrNofKeys(TBtNode *np)
THAT is a child of THIS that has just grown by 1.
virtual void SetByteCount(UInt_t cntpos, Bool_t packInVersion=kFALSE)=0
virtual Int_t Compare(const TObject *obj) const
Compare abstract method.
TObject * At(Int_t idx) const
TObject * After(const TObject *obj) const
Cannot use this method since B-tree decides order.
void Init(Int_t i)
Initialize a B-tree.
TBtree(Int_t ordern=3)
Create a B-tree of certain order (by default 3).
void Remove(Int_t idx)
Remove an element.
virtual void Remove(Int_t index)=0
virtual Int_t FindRank(const TObject *obj) const =0
Int_t IsAlmostFull() const
~TBtLeafNode()
Destructor.
~TBtInnerNode()
Constructor.
static void GarbageCollect(TObject *obj)
Add to the list of things to be cleaned up.
Int_t IndexOf(const TBtNode *n) const
Returns a number in the range 0 to this->fLast 0 is returned if THAT == fTree[0]. ...
Int_t IndexOf(const TObject *obj) const
Returns a number in the range 0 to MaxIndex().
void SplitWith(TBtLeafNode *r, Int_t idx)
Split.
TObject * Remove(TObject *obj)
Remove an object from the tree.
Int_t IncNofKeys(Int_t i, Int_t n=1)
Int_t IsAlmostFull() const
void SetKey(Int_t i, TObject *obj)
void Delete(Option_t *option="")
Remove all objects from B-tree AND delete all heap based objects.
void BalanceWithLeft(TBtInnerNode *l, Int_t idx)
THIS has more than LEFTSIB.
Int_t FindRank(const TObject *obj) const
Recursively look for WHAT starting in the current node.
void PushRight(Int_t cnt, TBtInnerNode *rightsib, Int_t parentIdx)
The operation is three steps:
Mother of all ROOT objects.
void RemoveItem(Int_t idx)
Remove an item.
TObject * Found(const TObject *obj, TBtNode **which, Int_t *where)
WHAT was not in any inner node; it is either here, or it's not in the tree.
TBtLeafNode * FirstLeafNode()
Return the first leaf node.
void ShiftLeft(Int_t cnt)
Shift to the left.
Int_t Compare(const void *item1, const void *item2)
Bool_t operator!=(const TIterator &aIter) const
This operator compares two TIterator objects.
you should not use this method at all Int_t Int_t Double_t Double_t Double_t Int_t Double_t Double_t Double_t Double_t b
virtual TObject * FindObject(const char *name) const
Find an object in this collection using its name.
Int_t NofKeys(Int_t idx) const
void SplitWith(TBtInnerNode *r, Int_t idx)
THIS and SIB are too full; create a NEWNODE, and balance the number of keys between the three of them...
virtual Int_t GetSize() const
Return the capacity of the collection, i.e.
virtual TBtLeafNode * FirstLeafNode()=0
void Split()
This function is called only when THIS is the only descendent of the root node, and THIS needs to be ...
virtual Int_t NofKeys() const =0
TBtNode * GetTree(Int_t i) const
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
virtual Version_t ReadVersion(UInt_t *start=0, UInt_t *bcnt=0, const TClass *cl=0)=0
void Add(const TObject *obj, Int_t idx)
This is called only from TBtree::Add().
void Add(const TObject *obj, Int_t idx)
Add the object OBJ to the leaf node, inserting it at location INDEX in the fItem array.
void BalanceWith(TBtInnerNode *n, int idx)
PINDX is the index of the parent item whose key will change when keys are shifted from one InnerNode ...