/*****************************************************************************
 * 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)             *
 *****************************************************************************/

//////////////////////////////////////////////////////////////////////////////
//
// BEGIN_HTML
// RooIntegrator2D implements a numeric two-dimensiona integrator
// in terms of a recursive application of RooIntegrator1D
// END_HTML
//


#include "RooFit.h"

#include "TClass.h"
#include "RooIntegrator2D.h"
#include "RooArgSet.h"
#include "RooIntegratorBinding.h"
#include "RooRealVar.h"
#include "RooNumber.h"
#include "RooNumIntFactory.h"

#include <assert.h>

using namespace std;

ClassImp(RooIntegrator2D)
;


//_____________________________________________________________________________
void RooIntegrator2D::registerIntegrator(RooNumIntFactory& fact)
{
  // Register RooIntegrator2D, is parameters and capabilities with RooNumIntFactory

  RooIntegrator2D* proto = new RooIntegrator2D() ;
  fact.storeProtoIntegrator(proto,RooArgSet(),RooIntegrator1D::Class()->GetName()) ;
  RooNumIntConfig::defaultConfig().method2D().setLabel(proto->IsA()->GetName()) ;
}


//_____________________________________________________________________________
RooIntegrator2D::RooIntegrator2D() :
  _xIntegrator(0), _xint(0)
{
  // Default constructor

}


//_____________________________________________________________________________
RooIntegrator2D::RooIntegrator2D(const RooAbsFunc& function, RooIntegrator1D::SummationRule rule,
				 Int_t maxSteps, Double_t eps) : 
  RooIntegrator1D(*(_xint=new RooIntegratorBinding(*(_xIntegrator=new RooIntegrator1D(function,rule,maxSteps,eps)))),rule,maxSteps,eps)
{
  // Constructor with a given function binding, summation rule,
  // maximum number of steps and conversion tolerance. The integration
  // limits are taken from the definition in the function binding.
} 


//_____________________________________________________________________________
RooIntegrator2D::RooIntegrator2D(const RooAbsFunc& function, Double_t xmin, Double_t xmax,
				 Double_t ymin, Double_t ymax,
				 SummationRule rule, Int_t maxSteps, Double_t eps) : 
  RooIntegrator1D(*(_xint=new RooIntegratorBinding(*(_xIntegrator=new RooIntegrator1D(function,ymin,ymax,rule,maxSteps,eps)))),xmin,xmax,rule,maxSteps,eps)
{
  // Constructor with a given function binding, summation rule,
  // maximum number of steps, conversion tolerance and an explicit
  // choice of integration limits on both dimensions.
} 


//_____________________________________________________________________________
RooIntegrator2D::RooIntegrator2D(const RooAbsFunc& function, const RooNumIntConfig& config) :
  RooIntegrator1D(*(_xint=new RooIntegratorBinding(*(_xIntegrator=new RooIntegrator1D(function,config)))),config)
{
  // Constructor with a function binding and a configuration object.
  // The integration limits are taken from the definition in the function
  // binding
} 



//_____________________________________________________________________________
RooIntegrator2D::RooIntegrator2D(const RooAbsFunc& function, Double_t xmin, Double_t xmax,
				 Double_t ymin, Double_t ymax,
				 const RooNumIntConfig& config) :
  RooIntegrator1D(*(_xint=new RooIntegratorBinding(*(_xIntegrator=new RooIntegrator1D(function,ymin,ymax,config)))),xmin,xmax,config)
{
  // Constructor with a function binding, a configuration object and
  // an explicit definition of the integration limits.
} 


//_____________________________________________________________________________
RooAbsIntegrator* RooIntegrator2D::clone(const RooAbsFunc& function, const RooNumIntConfig& config) const
{
  // Clone integrator with new function and configuration. Needed to support RooNumIntFactory
  return new RooIntegrator2D(function,config) ;
}



//_____________________________________________________________________________
RooIntegrator2D::~RooIntegrator2D() 
{
  // Destructor

  delete _xint ;
  delete _xIntegrator ;
}


//_____________________________________________________________________________
Bool_t RooIntegrator2D::checkLimits() const 
{
  // Verify that the limits are OK for this integrator (i.e. no open-ended ranges)

  Bool_t ret = RooIntegrator1D::checkLimits() ;
  ret &= _xIntegrator->checkLimits() ;
  return ret ;
}
 RooIntegrator2D.cxx:1
 RooIntegrator2D.cxx:2
 RooIntegrator2D.cxx:3
 RooIntegrator2D.cxx:4
 RooIntegrator2D.cxx:5
 RooIntegrator2D.cxx:6
 RooIntegrator2D.cxx:7
 RooIntegrator2D.cxx:8
 RooIntegrator2D.cxx:9
 RooIntegrator2D.cxx:10
 RooIntegrator2D.cxx:11
 RooIntegrator2D.cxx:12
 RooIntegrator2D.cxx:13
 RooIntegrator2D.cxx:14
 RooIntegrator2D.cxx:15
 RooIntegrator2D.cxx:16
 RooIntegrator2D.cxx:17
 RooIntegrator2D.cxx:18
 RooIntegrator2D.cxx:19
 RooIntegrator2D.cxx:20
 RooIntegrator2D.cxx:21
 RooIntegrator2D.cxx:22
 RooIntegrator2D.cxx:23
 RooIntegrator2D.cxx:24
 RooIntegrator2D.cxx:25
 RooIntegrator2D.cxx:26
 RooIntegrator2D.cxx:27
 RooIntegrator2D.cxx:28
 RooIntegrator2D.cxx:29
 RooIntegrator2D.cxx:30
 RooIntegrator2D.cxx:31
 RooIntegrator2D.cxx:32
 RooIntegrator2D.cxx:33
 RooIntegrator2D.cxx:34
 RooIntegrator2D.cxx:35
 RooIntegrator2D.cxx:36
 RooIntegrator2D.cxx:37
 RooIntegrator2D.cxx:38
 RooIntegrator2D.cxx:39
 RooIntegrator2D.cxx:40
 RooIntegrator2D.cxx:41
 RooIntegrator2D.cxx:42
 RooIntegrator2D.cxx:43
 RooIntegrator2D.cxx:44
 RooIntegrator2D.cxx:45
 RooIntegrator2D.cxx:46
 RooIntegrator2D.cxx:47
 RooIntegrator2D.cxx:48
 RooIntegrator2D.cxx:49
 RooIntegrator2D.cxx:50
 RooIntegrator2D.cxx:51
 RooIntegrator2D.cxx:52
 RooIntegrator2D.cxx:53
 RooIntegrator2D.cxx:54
 RooIntegrator2D.cxx:55
 RooIntegrator2D.cxx:56
 RooIntegrator2D.cxx:57
 RooIntegrator2D.cxx:58
 RooIntegrator2D.cxx:59
 RooIntegrator2D.cxx:60
 RooIntegrator2D.cxx:61
 RooIntegrator2D.cxx:62
 RooIntegrator2D.cxx:63
 RooIntegrator2D.cxx:64
 RooIntegrator2D.cxx:65
 RooIntegrator2D.cxx:66
 RooIntegrator2D.cxx:67
 RooIntegrator2D.cxx:68
 RooIntegrator2D.cxx:69
 RooIntegrator2D.cxx:70
 RooIntegrator2D.cxx:71
 RooIntegrator2D.cxx:72
 RooIntegrator2D.cxx:73
 RooIntegrator2D.cxx:74
 RooIntegrator2D.cxx:75
 RooIntegrator2D.cxx:76
 RooIntegrator2D.cxx:77
 RooIntegrator2D.cxx:78
 RooIntegrator2D.cxx:79
 RooIntegrator2D.cxx:80
 RooIntegrator2D.cxx:81
 RooIntegrator2D.cxx:82
 RooIntegrator2D.cxx:83
 RooIntegrator2D.cxx:84
 RooIntegrator2D.cxx:85
 RooIntegrator2D.cxx:86
 RooIntegrator2D.cxx:87
 RooIntegrator2D.cxx:88
 RooIntegrator2D.cxx:89
 RooIntegrator2D.cxx:90
 RooIntegrator2D.cxx:91
 RooIntegrator2D.cxx:92
 RooIntegrator2D.cxx:93
 RooIntegrator2D.cxx:94
 RooIntegrator2D.cxx:95
 RooIntegrator2D.cxx:96
 RooIntegrator2D.cxx:97
 RooIntegrator2D.cxx:98
 RooIntegrator2D.cxx:99
 RooIntegrator2D.cxx:100
 RooIntegrator2D.cxx:101
 RooIntegrator2D.cxx:102
 RooIntegrator2D.cxx:103
 RooIntegrator2D.cxx:104
 RooIntegrator2D.cxx:105
 RooIntegrator2D.cxx:106
 RooIntegrator2D.cxx:107
 RooIntegrator2D.cxx:108
 RooIntegrator2D.cxx:109
 RooIntegrator2D.cxx:110
 RooIntegrator2D.cxx:111
 RooIntegrator2D.cxx:112
 RooIntegrator2D.cxx:113
 RooIntegrator2D.cxx:114
 RooIntegrator2D.cxx:115
 RooIntegrator2D.cxx:116
 RooIntegrator2D.cxx:117
 RooIntegrator2D.cxx:118
 RooIntegrator2D.cxx:119
 RooIntegrator2D.cxx:120
 RooIntegrator2D.cxx:121
 RooIntegrator2D.cxx:122
 RooIntegrator2D.cxx:123
 RooIntegrator2D.cxx:124
 RooIntegrator2D.cxx:125
 RooIntegrator2D.cxx:126
 RooIntegrator2D.cxx:127
 RooIntegrator2D.cxx:128
 RooIntegrator2D.cxx:129
 RooIntegrator2D.cxx:130
 RooIntegrator2D.cxx:131
 RooIntegrator2D.cxx:132
 RooIntegrator2D.cxx:133
 RooIntegrator2D.cxx:134
 RooIntegrator2D.cxx:135
 RooIntegrator2D.cxx:136