61      _nset.add(observables);
 
   64   double Density(
Int_t ndim, 
double *xvec)
 override 
   67      for (
int i = 0; i < ndim; i++) {
 
   68         x[i] = xvec[i] * (_binding->getMaxLimit(i) - _binding->getMinLimit(i)) + _binding->getMinLimit(i);
 
   70      double ret = (*_binding)(
x);
 
   78   std::unique_ptr<RooRealBinding> _binding;
 
  110  _tfoam = std::make_unique<TFoam>(
"TFOAM") ;
 
  131    _xmin[i] = var->getMin() ;
 
  132    _range[i] = var->getMax() - var->getMin() ;
 
 
  143  if(event->size() == 1) 
return event;
 
 
  159   static const std::string 
name = 
"RooFoamGenerator";
 
 
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
 
Storage_t::size_type size() const
 
Abstract base class for MC event generator implementations like RooAcceptReject and RooFoam.
 
RooArgSet _realVars
Set of real valued observabeles.
 
RooAbsReal * _funcClone
Pointer to top level node of cloned function.
 
std::unique_ptr< RooDataSet > _cache
Dataset holding generared values of observables.
 
Abstract base class for objects that represent a real value and implements functionality common to al...
 
RooArgSet is a container object that can hold multiple RooAbsArg objects.
 
Generic Monte Carlo toy generator that implement the TFOAM sampling technique on any positively value...
 
const RooArgSet * generateEvent(UInt_t remaining, double &resampleRatio) override
are we actually generating anything? (the cache always contains at least our function value)
 
std::vector< double > _xmin
Lower bound of observables to be generated ;.
 
RooFoamGenerator()=default
 
std::vector< double > _range
Range of observables to be generated ;.
 
std::unique_ptr< TFoam > _tfoam
Instance of TFOAM generator.
 
std::unique_ptr< TFoamIntegrand > _binding
Binding of RooAbsReal to TFoam function interface.
 
std::string const & generatorName() const override
Return unique name of generator implementation.
 
std::vector< double > _vec
Transfer array for FOAM output.
 
static void registerSampler(RooNumGenFactory &fact)
Register RooIntegrator1D, is parameters and capabilities with RooNumIntFactory.
 
Holds the configuration parameters of the various numeric integrators used by RooRealIntegral.
 
const RooArgSet & getConfigSection(const char *name) const
Retrieve configuration information specific to integrator with given name.
 
Factory to instantiate numeric integrators from a given function binding and a given configuration.
 
static TRandom * randomGenerator()
Return a pointer to a singleton random-number generator implementation.
 
Lightweight interface adaptor that binds a RooAbsReal object to a subset of its servers and present i...
 
Variable that can be changed from the outside.
 
void setVal(double value) override
Set value of variable to 'value'.
 
Abstract class representing n-dimensional real positive integrand function.