ROOT logo
/*****************************************************************************
 * Project: RooFit                                                           *
 * Package: RooFitCore                                                       *
 * @(#)root/roofitcore:$Id: RooTFoamBinding.cxx 28259 2009-04-16 16:21:16Z wouter $
 * 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
// Lightweight interface adaptor that binds a RooAbsPdf to TFOAM
// END_HTML
//


#include "RooFit.h"
#include "Riostream.h"

#include "RooTFoamBinding.h"
#include "RooRealBinding.h"
#include "RooAbsReal.h"
#include "RooAbsPdf.h"
#include "RooArgSet.h"

#include <assert.h>



ClassImp(RooTFoamBinding)
;


//_____________________________________________________________________________
RooTFoamBinding::RooTFoamBinding(const RooAbsReal& pdf, const RooArgSet& observables)
{
  _nset.add(observables) ;
  _binding = new RooRealBinding(pdf,observables,&_nset,kFALSE,0) ;
}


//_____________________________________________________________________________
RooTFoamBinding::~RooTFoamBinding() 
{
  // Destructor
  delete _binding ;
}



//_____________________________________________________________________________
Double_t RooTFoamBinding::Density(Int_t ndim, Double_t *xvec) 
{
  Double_t x[10] ;
  for (int i=0 ; i<ndim ; i++) {    
    x[i] = xvec[i]*(_binding->getMaxLimit(i)-_binding->getMinLimit(i)) + _binding->getMinLimit(i) ;
    //cout << "RTFB::Density xvec[" << i << "] = " << xvec[i] << " x[i] = " << x[i] << endl ;
  }
  Double_t ret = (*_binding)(x) ;  
  return ret<0?0:ret ;
}
 RooTFoamBinding.cxx:1
 RooTFoamBinding.cxx:2
 RooTFoamBinding.cxx:3
 RooTFoamBinding.cxx:4
 RooTFoamBinding.cxx:5
 RooTFoamBinding.cxx:6
 RooTFoamBinding.cxx:7
 RooTFoamBinding.cxx:8
 RooTFoamBinding.cxx:9
 RooTFoamBinding.cxx:10
 RooTFoamBinding.cxx:11
 RooTFoamBinding.cxx:12
 RooTFoamBinding.cxx:13
 RooTFoamBinding.cxx:14
 RooTFoamBinding.cxx:15
 RooTFoamBinding.cxx:16
 RooTFoamBinding.cxx:17
 RooTFoamBinding.cxx:18
 RooTFoamBinding.cxx:19
 RooTFoamBinding.cxx:20
 RooTFoamBinding.cxx:21
 RooTFoamBinding.cxx:22
 RooTFoamBinding.cxx:23
 RooTFoamBinding.cxx:24
 RooTFoamBinding.cxx:25
 RooTFoamBinding.cxx:26
 RooTFoamBinding.cxx:27
 RooTFoamBinding.cxx:28
 RooTFoamBinding.cxx:29
 RooTFoamBinding.cxx:30
 RooTFoamBinding.cxx:31
 RooTFoamBinding.cxx:32
 RooTFoamBinding.cxx:33
 RooTFoamBinding.cxx:34
 RooTFoamBinding.cxx:35
 RooTFoamBinding.cxx:36
 RooTFoamBinding.cxx:37
 RooTFoamBinding.cxx:38
 RooTFoamBinding.cxx:39
 RooTFoamBinding.cxx:40
 RooTFoamBinding.cxx:41
 RooTFoamBinding.cxx:42
 RooTFoamBinding.cxx:43
 RooTFoamBinding.cxx:44
 RooTFoamBinding.cxx:45
 RooTFoamBinding.cxx:46
 RooTFoamBinding.cxx:47
 RooTFoamBinding.cxx:48
 RooTFoamBinding.cxx:49
 RooTFoamBinding.cxx:50
 RooTFoamBinding.cxx:51
 RooTFoamBinding.cxx:52
 RooTFoamBinding.cxx:53
 RooTFoamBinding.cxx:54
 RooTFoamBinding.cxx:55
 RooTFoamBinding.cxx:56
 RooTFoamBinding.cxx:57
 RooTFoamBinding.cxx:58
 RooTFoamBinding.cxx:59
 RooTFoamBinding.cxx:60
 RooTFoamBinding.cxx:61
 RooTFoamBinding.cxx:62
 RooTFoamBinding.cxx:63
 RooTFoamBinding.cxx:64
 RooTFoamBinding.cxx:65
 RooTFoamBinding.cxx:66
 RooTFoamBinding.cxx:67
 RooTFoamBinding.cxx:68
 RooTFoamBinding.cxx:69