Logo ROOT   6.16/01
Reference Guide
RooPoisson.h
Go to the documentation of this file.
1 /*****************************************************************************
2 * Project: RooFit *
3 * *
4 * Simple Poisson PDF
5 * author: Kyle Cranmer <cranmer@cern.ch>
6 * *
7 *****************************************************************************/
8
9#ifndef ROOPOISSON
10#define ROOPOISSON
11
12#include "RooAbsPdf.h"
13#include "RooRealProxy.h"
14#include "RooCategoryProxy.h"
15#include "RooAbsReal.h"
16#include "RooAbsCategory.h"
17#include "RooTrace.h"
18
19class RooPoisson : public RooAbsPdf {
20public:
22 RooPoisson(const char *name, const char *title, RooAbsReal& _x, RooAbsReal& _mean, Bool_t noRounding=kFALSE);
23 RooPoisson(const RooPoisson& other, const char* name=0) ;
24 virtual TObject* clone(const char* newname) const { return new RooPoisson(*this,newname); }
25 inline virtual ~RooPoisson() { }
26
27 Int_t getAnalyticalIntegral(RooArgSet& allVars, RooArgSet& analVars, const char* rangeName=0) const ;
28 Double_t analyticalIntegral(Int_t code, const char* rangeName=0) const ;
29
30 Int_t getGenerator(const RooArgSet& directVars, RooArgSet &generateVars, Bool_t staticInitOK=kTRUE) const;
31 void generateEvent(Int_t code);
32
33 void setNoRounding(bool flag = kTRUE){_noRounding = flag;}
34 void protectNegativeMean(bool flag = kTRUE){_protectNegative = flag;}
35
36 Double_t getLogVal(const RooArgSet* set=0) const ;
37
38protected:
39
44
45 Double_t evaluate() const ;
47
48
49private:
50
51 ClassDef(RooPoisson,3) // A Poisson PDF
52};
53
54#endif
int Int_t
Definition: RtypesCore.h:41
const Bool_t kFALSE
Definition: RtypesCore.h:88
bool Bool_t
Definition: RtypesCore.h:59
double Double_t
Definition: RtypesCore.h:55
const Bool_t kTRUE
Definition: RtypesCore.h:87
#define ClassDef(name, id)
Definition: Rtypes.h:324
RooAbsPdf is the abstract interface for all probability density functions The class provides hybrid a...
Definition: RooAbsPdf.h:41
RooAbsReal is the common abstract base class for objects that represent a real value and implements f...
Definition: RooAbsReal.h:53
RooArgSet is a container object that can hold multiple RooAbsArg objects.
Definition: RooArgSet.h:28
Poisson pdf.
Definition: RooPoisson.h:19
RooRealProxy x
Definition: RooPoisson.h:40
void generateEvent(Int_t code)
Implement internal generator using TRandom::Poisson.
Definition: RooPoisson.cxx:200
virtual TObject * clone(const char *newname) const
Definition: RooPoisson.h:24
virtual ~RooPoisson()
Definition: RooPoisson.h:25
void protectNegativeMean(bool flag=kTRUE)
Definition: RooPoisson.h:34
Bool_t _protectNegative
Definition: RooPoisson.h:43
Double_t getLogVal(const RooArgSet *set=0) const
calculate and return the negative log-likelihood of the Poisson
Definition: RooPoisson.cxx:74
Double_t analyticalIntegral(Int_t code, const char *rangeName=0) const
Implements the actual analytical integral(s) advertised by getAnalyticalIntegral.
Definition: RooPoisson.cxx:129
Int_t getGenerator(const RooArgSet &directVars, RooArgSet &generateVars, Bool_t staticInitOK=kTRUE) const
Advertise internal generator in x.
Definition: RooPoisson.cxx:191
Int_t getAnalyticalIntegral(RooArgSet &allVars, RooArgSet &analVars, const char *rangeName=0) const
Interface function getAnalyticalIntergral advertises the analytical integrals that are supported.
Definition: RooPoisson.cxx:120
Double_t evaluate() const
Implementation in terms of the TMath Poisson function.
Definition: RooPoisson.cxx:63
Bool_t _noRounding
Definition: RooPoisson.h:42
Double_t evaluate(Double_t k) const
RooRealProxy mean
Definition: RooPoisson.h:41
void setNoRounding(bool flag=kTRUE)
Definition: RooPoisson.h:33
RooRealProxy is the concrete proxy for RooAbsReal objects A RooRealProxy is the general mechanism to ...
Definition: RooRealProxy.h:23
Mother of all ROOT objects.
Definition: TObject.h:37