/*****************************************************************************
 * Project: RooFit                                                           *
 *                                                                           *
 * 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 ROONUMRUNNINGINT
#define ROONUMRUNNINGINT

#include "RooAbsCachedReal.h"
#include "RooRealProxy.h"
#include "RooAbsReal.h"


class RooNumRunningInt : public RooAbsCachedReal {
public:
  RooNumRunningInt(const char *name, const char *title, RooAbsReal& _func, RooRealVar& _x, const char* binningName="cache");
  RooNumRunningInt(const RooNumRunningInt& other, const char* name=0) ;
  virtual TObject* clone(const char* newname) const { return new RooNumRunningInt(*this,newname); }
  virtual ~RooNumRunningInt() ;

protected:

  class RICacheElem: public FuncCacheElem {
  public:
    RICacheElem(const RooNumRunningInt& ri, const RooArgSet* nset) ;
    ~RICacheElem() ;
    virtual RooArgList containedArgs(Action) ;
    void calculate(Bool_t cdfmode) ;
    void addRange(Int_t ixlo, Int_t ixhi, Int_t nbins) ;
    void addPoint(Int_t ix) ;

    RooNumRunningInt* _self ;
    Double_t* _ax ;
    Double_t* _ay ;    
    RooRealVar* _xx ; 

  } ;

  friend class RICacheElem ;
  virtual const char* binningName() const { return _binningName.c_str() ; }
  virtual FuncCacheElem* createCache(const RooArgSet* nset) const ;
  virtual const char* inputBaseName() const ; 
  virtual RooArgSet* actualObservables(const RooArgSet& nset) const ;
  virtual RooArgSet* actualParameters(const RooArgSet& nset) const ;
  virtual void fillCacheObject(FuncCacheElem& cacheFunc) const ;
  virtual Double_t evaluate() const ;

  virtual const char* payloadUniqueSuffix() const { return func.arg().aggregateCacheUniqueSuffix() ; }
  
  RooRealProxy func ; // Proxy to functions whose running integral is calculated
  RooRealProxy x   ; // Intergrated observable
  std::string _binningName ; // Name of binning to be used for cache histogram

private:

  ClassDef(RooNumRunningInt,1) // Numeric calculator for running integral of a given function

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