/*****************************************************************************
 * 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_HIST_FUNC
#define ROO_HIST_FUNC

#include "RooAbsReal.h"
#include "RooRealProxy.h"
#include "RooSetProxy.h"
#include "RooAICRegistry.h"
#include "RooTrace.h"

class RooRealVar;
class RooAbsReal;
class RooDataHist ;

class RooHistFunc : public RooAbsReal {
public:
  RooHistFunc() ; 
  RooHistFunc(const char *name, const char *title, const RooArgSet& vars, const RooDataHist& dhist, Int_t intOrder=0);
  RooHistFunc(const char *name, const char *title, const RooArgList& funcObs, const RooArgList& histObs, const RooDataHist& dhist, Int_t intOrder=0);
  RooHistFunc(const RooHistFunc& other, const char* name=0);
  virtual TObject* clone(const char* newname) const { return new RooHistFunc(*this,newname); }
  virtual ~RooHistFunc() ;

  RooDataHist& dataHist()  { 
    // Return RooDataHist that is represented
    return *_dataHist ; 
  }
  const RooDataHist& dataHist() const { 
    // Return RooDataHist that is represented
    return *_dataHist ; 
  }
  
  void setInterpolationOrder(Int_t order) { 
    // Set histogram interpolation order 
    _intOrder = order ; 
  }

  Int_t getInterpolationOrder() const { 
    // Return histogram interpolation order
    return _intOrder ; 
  }

  Int_t getAnalyticalIntegral(RooArgSet& allVars, RooArgSet& analVars, const char* rangeName=0) const ;
  Double_t analyticalIntegral(Int_t code, const char* rangeName=0) const ;

  void setCdfBoundaries(Bool_t flag) { 
    // Set use of special boundary conditions for c.d.f.s
    _cdfBoundaries = flag ; 
  }

  Bool_t getCdfBoundaries() const { 
    // If true, special boundary conditions for c.d.f.s are used
    return _cdfBoundaries ; 
  }

  virtual Int_t getMaxVal(const RooArgSet& vars) const;
  virtual Double_t maxVal(Int_t code) const;

  virtual std::list<Double_t>* binBoundaries(RooAbsRealLValue& /*obs*/, Double_t /*xlo*/, Double_t /*xhi*/) const ;
  virtual std::list<Double_t>* plotSamplingHint(RooAbsRealLValue& obs, Double_t xlo, Double_t xhi) const ; 
  virtual Bool_t isBinnedDistribution(const RooArgSet&) const { return _intOrder==0 ; }

protected:

  Bool_t importWorkspaceHook(RooWorkspace& ws) ;
  Bool_t areIdentical(const RooDataHist& dh1, const RooDataHist& dh2) ;

  Double_t evaluate() const;
  Double_t totalVolume() const ;
  friend class RooAbsCachedReal ;
  Double_t totVolume() const ;

  virtual void ioStreamerPass2() ;

  RooArgSet         _histObsList ; // List of observables defining dimensions of histogram
  RooSetProxy       _depList ;  // List of observables mapped onto histogram observables
  TIterator*         _histObsIter ; //! 
  TIterator*         _pdfObsIter ; //! 
  RooDataHist*      _dataHist ;  // Unowned pointer to underlying histogram
  mutable RooAICRegistry _codeReg ; //! Auxiliary class keeping tracking of analytical integration code
  Int_t             _intOrder ; // Interpolation order
  Bool_t            _cdfBoundaries ; // Use boundary conditions for CDFs.
  mutable Double_t  _totVolume ; //! Total volume of space (product of ranges of observables)
  Bool_t            _unitNorm  ; //! Assume contents is unit normalized (for use as pdf cache)

  ClassDef(RooHistFunc,2) // Histogram based function
};

#endif
 RooHistFunc.h:1
 RooHistFunc.h:2
 RooHistFunc.h:3
 RooHistFunc.h:4
 RooHistFunc.h:5
 RooHistFunc.h:6
 RooHistFunc.h:7
 RooHistFunc.h:8
 RooHistFunc.h:9
 RooHistFunc.h:10
 RooHistFunc.h:11
 RooHistFunc.h:12
 RooHistFunc.h:13
 RooHistFunc.h:14
 RooHistFunc.h:15
 RooHistFunc.h:16
 RooHistFunc.h:17
 RooHistFunc.h:18
 RooHistFunc.h:19
 RooHistFunc.h:20
 RooHistFunc.h:21
 RooHistFunc.h:22
 RooHistFunc.h:23
 RooHistFunc.h:24
 RooHistFunc.h:25
 RooHistFunc.h:26
 RooHistFunc.h:27
 RooHistFunc.h:28
 RooHistFunc.h:29
 RooHistFunc.h:30
 RooHistFunc.h:31
 RooHistFunc.h:32
 RooHistFunc.h:33
 RooHistFunc.h:34
 RooHistFunc.h:35
 RooHistFunc.h:36
 RooHistFunc.h:37
 RooHistFunc.h:38
 RooHistFunc.h:39
 RooHistFunc.h:40
 RooHistFunc.h:41
 RooHistFunc.h:42
 RooHistFunc.h:43
 RooHistFunc.h:44
 RooHistFunc.h:45
 RooHistFunc.h:46
 RooHistFunc.h:47
 RooHistFunc.h:48
 RooHistFunc.h:49
 RooHistFunc.h:50
 RooHistFunc.h:51
 RooHistFunc.h:52
 RooHistFunc.h:53
 RooHistFunc.h:54
 RooHistFunc.h:55
 RooHistFunc.h:56
 RooHistFunc.h:57
 RooHistFunc.h:58
 RooHistFunc.h:59
 RooHistFunc.h:60
 RooHistFunc.h:61
 RooHistFunc.h:62
 RooHistFunc.h:63
 RooHistFunc.h:64
 RooHistFunc.h:65
 RooHistFunc.h:66
 RooHistFunc.h:67
 RooHistFunc.h:68
 RooHistFunc.h:69
 RooHistFunc.h:70
 RooHistFunc.h:71
 RooHistFunc.h:72
 RooHistFunc.h:73
 RooHistFunc.h:74
 RooHistFunc.h:75
 RooHistFunc.h:76
 RooHistFunc.h:77
 RooHistFunc.h:78
 RooHistFunc.h:79
 RooHistFunc.h:80
 RooHistFunc.h:81
 RooHistFunc.h:82
 RooHistFunc.h:83
 RooHistFunc.h:84
 RooHistFunc.h:85
 RooHistFunc.h:86
 RooHistFunc.h:87
 RooHistFunc.h:88
 RooHistFunc.h:89
 RooHistFunc.h:90
 RooHistFunc.h:91
 RooHistFunc.h:92
 RooHistFunc.h:93
 RooHistFunc.h:94
 RooHistFunc.h:95
 RooHistFunc.h:96
 RooHistFunc.h:97
 RooHistFunc.h:98
 RooHistFunc.h:99
 RooHistFunc.h:100
 RooHistFunc.h:101
 RooHistFunc.h:102
 RooHistFunc.h:103