ROOT  6.06/09
Reference Guide
RooCFunction2Binding.cxx
Go to the documentation of this file.
1 /*****************************************************************************
2  * Project: RooFit *
3  * Package: RooFitCore *
4  * File: $Id$
5  * Authors: *
6  * WV, Wouter Verkerke, NIKHEF, verkerke@nikhef.nl *
7  * *
8  * Copyright (c) 2000-2008, NIKHEF, Regents of the University of California *
9  * and Stanford University. All rights reserved. *
10  * *
11  *****************************************************************************/
12 
13 //////////////////////////////////////////////////////////////////////////////
14 //
15 // BEGIN_HTML
16 // RooCFunction2Binding is a templated implementation of class RooAbsReal that binds
17 // generic C(++) functions to a RooAbsReal argument thus allowing generic C++
18 // functions to be used as RooFit functions. Instances of function binding
19 // classes are fully functional RooFit function objects with one exception:
20 // if the bound function is _not_ a standard TMath or MathMore function the
21 // class cannot be persisted in a RooWorkspace without registering the function
22 // pointer first using RooCFunction2Binding<T1,T2,T3>::register().
23 // END_HTML
24 //
25 
26 #include "Riostream.h"
27 #include "RooCFunction2Binding.h"
28 #include "RooCintUtils.h"
29 
30 using namespace std ;
31 
32 #ifndef ROOFIT_R__NO_CLASS_TEMPLATE_SPECIALIZATION
33 #define ROOFIT_R__NO_CLASS_TEMPLATE_SPECIALIZATION
36 #endif
37 
38 
39 template<> RooCFunction2Map<double,double,double>* RooCFunction2Ref<double,double,double>::_fmap = 0 ;
40 template<> RooCFunction2Map<double,int,double> *RooCFunction2Ref<double,int,double>::_fmap = 0 ;
41 template<> RooCFunction2Map<double,unsigned int,double> *RooCFunction2Ref<double,unsigned int,double>::_fmap = 0 ;
42 template<> RooCFunction2Map<double,double,int> *RooCFunction2Ref<double,double,int>::_fmap = 0 ;
43 template<> RooCFunction2Map<double,int,int> *RooCFunction2Ref<double,int,int>::_fmap = 0 ;
44 
45 
46 namespace RooFit {
47 
50  }
51 
54  }
55 
58  }
59 
62  }
63 
66  }
67 
70  }
71 
74  }
75 
78  }
79 
82  }
83 
86  }
87 
88 }
RooAbsPdf * bindPdf(const char *name, CFUNCD1D func, RooAbsReal &x)
STL namespace.
RooAbsReal * bindFunction(const char *name, CFUNCD1D func, RooAbsReal &x)
Double_t x[n]
Definition: legend1.C:17
Double_t(* CFUNCD2II)(Int_t, Int_t)
templateClassImp(RooCFunction2Binding) templateClassImp(RooCFunction2Ref) template<> RooCFunction2Map< double
Double_t(* CFUNCD2UD)(UInt_t, Double_t)
Double_t(* CFUNCD2DD)(Double_t, Double_t)
RooAbsReal is the common abstract base class for objects that represent a real value and implements f...
Definition: RooAbsReal.h:53
Double_t(* CFUNCD2DI)(Double_t, Int_t)
Double_t(* CFUNCD2ID)(Int_t, Double_t)
Double_t y[n]
Definition: legend1.C:17
double func(double *x, double *p)
Definition: stressTF1.cxx:213
#define name(a, b)
Definition: linkTestLib0.cpp:5
RooAbsPdf is the abstract interface for all probability density functions The class provides hybrid a...
Definition: RooAbsPdf.h:41