/*****************************************************************************
 * Project: RooFit                                                           *
 * Package: RooFitCore                                                       *
 * @(#)root/roofitcore:$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_MULTI_GEN_FUNCTION
#define ROO_MULTI_GEN_FUNCTION

#include "RooFunctor.h"
#include "Math/IFunction.h"

class RooAbsReal ;
class RooArgList ;
class RooArgSet ;
class RooAbsFunc ;

class RooMultiGenFunction : public ROOT::Math::IMultiGenFunction {

public:
  RooMultiGenFunction(const RooAbsFunc& func) ;
  RooMultiGenFunction(const RooAbsReal& func, const RooArgList& observables, const RooArgList& parameters) ;
  RooMultiGenFunction(const RooAbsReal& func, const RooArgList& observables, const RooArgList& parameters, const RooArgSet& nset) ;
  RooMultiGenFunction(const RooMultiGenFunction& other) ;
  virtual ~RooMultiGenFunction() ;

  virtual ROOT::Math::IBaseFunctionMultiDim* Clone() const {
    return new RooMultiGenFunction(*this) ;
  }

/*   Int_t numCall() const { return _ftor.numCall() ; } */
/*   void resetNumCall() const { _ftor.resetNumCall() ; } */

  unsigned int NDim() const { return _ftor.nObs() ; }

protected:

  double DoEval(const double*) const ;

  RooFunctor _ftor ;
  
  ClassDef(RooMultiGenFunction,0) // Export RooAbsReal as functor
};

#endif

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