84   , fTarget(distr.fTarget)
 
  107      Log() << kFATAL << 
"<PDEFoamTargetDensity::Density()> Binary tree not found!" << 
Endl;
 
  110   std::vector<Double_t> lb(GetBox().size());
 
  111   std::vector<Double_t> ub(GetBox().size());
 
  114   const Double_t probevolume_inv = 1.0 / GetBoxVolume();
 
  117   for (
UInt_t idim = 0; idim < GetBox().size(); ++idim) {
 
  118      lb[idim] = xev[idim] - GetBox().at(idim) / 2.0;
 
  119      ub[idim] = xev[idim] + GetBox().at(idim) / 2.0;
 
  123   std::vector<const TMVA::BinarySearchTreeNode*> nodes; 
 
  126   const Double_t sumOfWeights = fBst->SearchVolume(&volume, &nodes);
 
  129   event_density = nodes.size() * probevolume_inv;
 
  133   for (std::vector<const TMVA::BinarySearchTreeNode*>::const_iterator it = nodes.begin();
 
  134        it != nodes.end(); ++it) {
 
  135      n_tar += ((*it)->GetTargets()).at(fTarget) * ((*it)->GetWeight());
 
  139   return (n_tar / (sumOfWeights + 0.1)) * probevolume_inv;
 
This is an abstract class, which provides an interface for a PDEFoam density estimator.
 
This is a concrete implementation of PDEFoam.
 
virtual Double_t Density(std::vector< Double_t > &Xarg, Double_t &event_density)
This function is needed during the foam buildup.
 
Volume for BinarySearchTree.
 
void box(Int_t pat, Double_t x1, Double_t y1, Double_t x2, Double_t y2)
 
MsgLogger & Endl(MsgLogger &ml)