14#ifndef ROOT_Math_KDTree 
   15#define ROOT_Math_KDTree 
   34     template<
class _DataPo
int>
 
  248           const std::vector<tBoundary>&           
GetBoundaries() 
const override;
 
  263           typedef typename std::vector<const point_type* >::iterator         
data_it;
 
  264           typedef typename std::vector<const point_type* >::const_iterator   
const_data_it;
 
 
  340        const iterator  
First() 
const;
 
  354        const iterator  
Last() 
const;
 
 
Basic types used by ROOT and required by TInterpreter.
bool Bool_t
Boolean (0=false, 1=true) (bool)
unsigned int UInt_t
Unsigned integer 4 bytes (unsigned int)
double Double_t
Double 8 bytes.
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
BaseNode *& GetParentPointer()
BaseNode(const BaseNode &)
const BaseNode * LeftChild() const
virtual Bool_t Insert(const point_type &rPoint)=0
const BaseNode * Parent() const
virtual const BinNode * FindNode(const point_type &rPoint) const =0
const BaseNode * RightChild() const
virtual void GetPointsWithinDist(const point_type &rRef, value_type fDist, std::vector< const point_type * > &vFoundPoints) const =0
virtual void GetClosestPoints(const point_type &rRef, UInt_t nPoints, std::vector< std::pair< const _DataPoint *, Double_t > > &vFoundPoints) const =0
Bool_t IsLeftChild() const
BaseNode * fRightChild
pointer to left child
virtual Bool_t IsHeadNode() const
BaseNode & operator=(const BaseNode &)
BaseNode(BaseNode *pParent=0)
virtual void Print(int iRow=0) const =0
virtual BaseNode * Clone()=0
BaseNode * fLeftChild
pointer to parent node
virtual const std::vector< tBoundary > & GetBoundaries() const
std::vector< tBoundary > fBoundaries
bin boundaries
BinNode * Clone() override
BinNode(BaseNode *pParent=0)
point_type GetBinCenter() const
Double_t GetSumw2() const
void GetClosestPoints(const point_type &, UInt_t, std::vector< std::pair< const _DataPoint *, Double_t > > &) const override
std::pair< value_type, value_type > tBoundary
Bool_t IsInBin(const point_type &rPoint) const
BinNode & operator=(const BinNode &rhs)
Double_t fSumw2
sum of weights^2
const BinNode * FindNode(const point_type &rPoint) const override
UInt_t GetEntries() const
UInt_t fEntries
number of entries
Double_t GetDensity() const
Bool_t Insert(const point_type &rPoint) override
Double_t GetEffectiveEntries() const
Double_t fSumw
sum of weights
Double_t GetBinContent() const
void GetPointsWithinDist(const point_type &, value_type, std::vector< const point_type * > &) const override
Double_t GetVolume() const
Bool_t operator()(const point_type *pFirst, const point_type *pSecond) const
void SetAxis(UInt_t iAxis)
value_type GetCutValue() const
Cut(UInt_t iAxis, Double_t fNewCutValue)
Bool_t operator>(const point_type &rPoint) const
void SetAxis(UInt_t iAxis)
void SetCutValue(Double_t fNewCutValue)
Bool_t operator<(const point_type &rPoint) const
void GetPointsWithinDist(const point_type &rRef, value_type fDist, std::vector< const _DataPoint * > &vFoundPoints) const override
void GetClosestPoints(const point_type &rRef, UInt_t nPoints, std::vector< std::pair< const _DataPoint *, Double_t > > &vFoundPoints) const override
HeadNode & operator=(const HeadNode &)
bool IsHeadNode() const override
const BinNode * FindNode(const point_type &rPoint) const override
HeadNode(BaseNode &rNode)
void Print(Int_t) const override
HeadNode(const HeadNode &)
Bool_t Insert(const point_type &rPoint) override
HeadNode * Clone() override
Bool_t Insert(const point_type &rPoint) override
SplitNode(UInt_t iAxis, Double_t fCutValue, BaseNode &rLeft, BaseNode &rRight, BaseNode *pParent=0)
SplitNode * Clone() override
const BinNode * FindNode(const point_type &rPoint) const override
const Cut * GetCut() const
SplitNode & operator=(const SplitNode &)
void GetClosestPoints(const point_type &rRef, UInt_t nPoints, std::vector< std::pair< const _DataPoint *, Double_t > > &vFoundPoints) const override
void GetPointsWithinDist(const point_type &rRef, value_type fDist, std::vector< const _DataPoint * > &vFoundPoints) const override
SplitNode(const SplitNode &)
Bool_t Insert(const point_type &rPoint) override
const BinNode * FindNode(const point_type &) const override
data_it SplitBinContent()
std::vector< constpoint_type * >::iterator data_it
Double_t fBucketSize
target number of entries per bucket
void SetOwner(Bool_t bIsOwner=true)
void SetSplitOption(eSplitOption opt)
Bool_t fOwnData
terminal node owns the data objects (default = false)
std::pair< value_type, value_type > tBoundary
BinNode * Clone() override
BinNode * ConvertToBinNode()
TerminalNode(Double_t iBucketSize, BaseNode *pParent=0)
std::vector< constpoint_type * >::const_iterator const_data_it
const std::vector< tBoundary > & GetBoundaries() const override
UInt_t fSplitAxis
axis at which the next split will occur
TerminalNode & operator=(const TerminalNode &)
void GetPointsWithinDist(const point_type &rRef, value_type fDist, std::vector< const _DataPoint * > &vFoundPoints) const override
TerminalNode(const TerminalNode &)
data_it SplitEffectiveEntries()
void GetClosestPoints(const point_type &rRef, UInt_t nPoints, std::vector< std::pair< const _DataPoint *, Double_t > > &vFoundPoints) const override
std::vector< const _DataPoint * > fDataPoints
data points in this bucket
const std::vector< const point_type * > & GetPoints() const
eSplitOption fSplitOption
according to which figure of merit the node is split
bool operator==(const iterator &rIterator) const
const Bin & operator*() const
bool operator!=(const iterator &rIterator) const
iterator(const iterator ©)
iterator & operator=(const iterator &rhs)
const Bin * operator->() const
Double_t GetTotalSumw2() const
Bool_t Insert(const point_type &rData)
void SetOwner(Bool_t bIsOwner=true)
KDTree< _DataPoint > * GetFrozenCopy()
Double_t GetTotalSumw() const
_DataPoint::value_type value_type
const Bin * FindBin(const point_type &rPoint) const
UInt_t GetEntries() const
void GetPointsWithinDist(const point_type &rRef, value_type fDist, std::vector< const point_type * > &vFoundPoints) const
Double_t GetBucketSize() const
Double_t GetEffectiveEntries() const
KDTree< point_type > & operator=(const KDTree< point_type > &)
void SetSplitOption(eSplitOption opt)
void GetClosestPoints(const point_type &rRef, UInt_t nPoints, std::vector< std::pair< const _DataPoint *, Double_t > > &vFoundPoints) const
KDTree(const KDTree< point_type > &)
static UInt_t Dimension()
Namespace for new Math classes and functions.