/*****************************************************************************
 * Project: RooFit                                                           *
 * Package: RooFitCore                                                       *
 *    File: $Id$
 * Authors:                                                                  *
 *   WV, Wouter Verkerke, UC Santa Barbara, verkerke@slac.stanford.edu       *
 *   DK, David Kirkby,    UC Irvine,         dkirkby@uci.edu                 *
 *                                                                           *
 * Copyright (c) 2000-2005, Regents of the University of California          *
 *                          and Stanford University. All rights reserved.    *
 *                                                                           *
 * Redistribution and use in source and binary forms,                        *
 * with or without modification, are permitted according to the terms        *
 * listed in LICENSE (http://roofit.sourceforge.net/license.txt)             *
 *****************************************************************************/
#ifndef ROO_FOAM_GENERATOR
#define ROO_FOAM_GENERATOR

#include "RooAbsNumGenerator.h"
#include "RooPrintable.h"
#include "RooArgSet.h"

class RooAbsReal;
class RooRealVar;
class RooDataSet;

class TFoam ;
class RooTFoamBinding ;
class RooNumGenFactory ;

class RooFoamGenerator : public RooAbsNumGenerator {
public:
  RooFoamGenerator() : _binding(0), _tfoam(0), _xmin(0), _range(0), _vec(0), _rvIter(0) {} ; 
  RooFoamGenerator(const RooAbsReal &func, const RooArgSet &genVars, const RooNumGenConfig& config, Bool_t verbose=kFALSE, const RooAbsReal* maxFuncVal=0);
  RooAbsNumGenerator* clone(const RooAbsReal& func, const RooArgSet& genVars, const RooArgSet& /*condVars*/, 
			    const RooNumGenConfig& config, Bool_t verbose=kFALSE, const RooAbsReal* maxFuncVal=0) const {
    return new RooFoamGenerator(func,genVars,config,verbose,maxFuncVal) ;
  }
  virtual ~RooFoamGenerator();

  const RooArgSet *generateEvent(UInt_t remaining, Double_t& resampleRatio);
  
  TFoam& engine() { return *_tfoam; }

  virtual Bool_t canSampleConditional() const { return kFALSE ; }
  virtual Bool_t canSampleCategories() const { return kFALSE ; }
 
protected:

  friend class RooNumGenFactory ;
  static void registerSampler(RooNumGenFactory& fact) ;	

  RooTFoamBinding* _binding ; // Binding of RooAbsReal to TFoam function interface
  TFoam*           _tfoam ;   // Instance of TFOAM generator
  Double_t*        _xmin ;    // Lower bound of observables to be generated ;
  Double_t*        _range ;   // Range of observables to be generated ;
  Double_t*        _vec ;     // Transfer array for FOAM output
  TIterator*       _rvIter ;  // Iteratator over _realVars ;


  ClassDef(RooFoamGenerator,0) // Context for generating a dataset from a PDF using the TFoam class
};

#endif
 RooFoamGenerator.h:1
 RooFoamGenerator.h:2
 RooFoamGenerator.h:3
 RooFoamGenerator.h:4
 RooFoamGenerator.h:5
 RooFoamGenerator.h:6
 RooFoamGenerator.h:7
 RooFoamGenerator.h:8
 RooFoamGenerator.h:9
 RooFoamGenerator.h:10
 RooFoamGenerator.h:11
 RooFoamGenerator.h:12
 RooFoamGenerator.h:13
 RooFoamGenerator.h:14
 RooFoamGenerator.h:15
 RooFoamGenerator.h:16
 RooFoamGenerator.h:17
 RooFoamGenerator.h:18
 RooFoamGenerator.h:19
 RooFoamGenerator.h:20
 RooFoamGenerator.h:21
 RooFoamGenerator.h:22
 RooFoamGenerator.h:23
 RooFoamGenerator.h:24
 RooFoamGenerator.h:25
 RooFoamGenerator.h:26
 RooFoamGenerator.h:27
 RooFoamGenerator.h:28
 RooFoamGenerator.h:29
 RooFoamGenerator.h:30
 RooFoamGenerator.h:31
 RooFoamGenerator.h:32
 RooFoamGenerator.h:33
 RooFoamGenerator.h:34
 RooFoamGenerator.h:35
 RooFoamGenerator.h:36
 RooFoamGenerator.h:37
 RooFoamGenerator.h:38
 RooFoamGenerator.h:39
 RooFoamGenerator.h:40
 RooFoamGenerator.h:41
 RooFoamGenerator.h:42
 RooFoamGenerator.h:43
 RooFoamGenerator.h:44
 RooFoamGenerator.h:45
 RooFoamGenerator.h:46
 RooFoamGenerator.h:47
 RooFoamGenerator.h:48
 RooFoamGenerator.h:49
 RooFoamGenerator.h:50
 RooFoamGenerator.h:51
 RooFoamGenerator.h:52
 RooFoamGenerator.h:53
 RooFoamGenerator.h:54
 RooFoamGenerator.h:55
 RooFoamGenerator.h:56
 RooFoamGenerator.h:57
 RooFoamGenerator.h:58
 RooFoamGenerator.h:59
 RooFoamGenerator.h:60
 RooFoamGenerator.h:61
 RooFoamGenerator.h:62
 RooFoamGenerator.h:63
 RooFoamGenerator.h:64