/usr/include/root/RooRealSumPdf.h is in libroot-roofit-dev 5.34.19+dfsg-1.2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 | /*****************************************************************************
* Project: RooFit *
* Package: RooFitCore *
* File: $Id: RooRealSumPdf.h,v 1.10 2007/05/11 09:11:30 verkerke Exp $
* 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_REAL_SUM_PDF
#define ROO_REAL_SUM_PDF
#include "RooAbsPdf.h"
#include "RooListProxy.h"
#include "RooAICRegistry.h"
#include "RooObjCacheManager.h"
class RooRealSumPdf : public RooAbsPdf {
public:
RooRealSumPdf() ;
RooRealSumPdf(const char *name, const char *title);
RooRealSumPdf(const char *name, const char *title, const RooArgList& funcList, const RooArgList& coefList, Bool_t extended=kFALSE) ;
RooRealSumPdf(const char *name, const char *title,
RooAbsReal& func1, RooAbsReal& func2, RooAbsReal& coef1) ;
RooRealSumPdf(const RooRealSumPdf& other, const char* name=0) ;
virtual TObject* clone(const char* newname) const { return new RooRealSumPdf(*this,newname) ; }
virtual ~RooRealSumPdf() ;
Double_t evaluate() const ;
virtual Bool_t checkObservables(const RooArgSet* nset) const ;
virtual Bool_t forceAnalyticalInt(const RooAbsArg& arg) const { return arg.isFundamental() ; }
Int_t getAnalyticalIntegralWN(RooArgSet& allVars, RooArgSet& numVars, const RooArgSet* normSet, const char* rangeName=0) const ;
Double_t analyticalIntegralWN(Int_t code, const RooArgSet* normSet, const char* rangeName=0) const ;
const RooArgList& funcList() const { return _funcList ; }
const RooArgList& coefList() const { return _coefList ; }
virtual ExtendMode extendMode() const ;
virtual Double_t expectedEvents(const RooArgSet* nset) const ;
virtual Double_t expectedEvents(const RooArgSet& nset) const {
// Return expected number of events for extended likelihood calculation
// which is the sum of all coefficients
return expectedEvents(&nset) ;
}
virtual Bool_t selfNormalized() const { return getAttribute("BinnedLikelihoodActive") ; }
void printMetaArgs(std::ostream& os) 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 ;
Bool_t isBinnedDistribution(const RooArgSet& obs) const ;
void setFloor(Bool_t flag) { _doFloor = flag ; }
Bool_t getFloor() const { return _doFloor ; }
static void setFloorGlobal(Bool_t flag) { _doFloorGlobal = flag ; }
static Bool_t getFloorGlobal() { return _doFloorGlobal ; }
virtual CacheMode canNodeBeCached() const { return RooAbsArg::NotAdvised ; } ;
virtual void setCacheAndTrackHints(RooArgSet&) ;
protected:
class CacheElem : public RooAbsCacheElement {
public:
CacheElem() {} ;
virtual ~CacheElem() {} ;
virtual RooArgList containedArgs(Action) { RooArgList ret(_funcIntList) ; ret.add(_funcNormList) ; return ret ; }
RooArgList _funcIntList ;
RooArgList _funcNormList ;
} ;
mutable RooObjCacheManager _normIntMgr ; // The integration cache manager
Bool_t _haveLastCoef ;
RooListProxy _funcList ; // List of component FUNCs
RooListProxy _coefList ; // List of coefficients
TIterator* _funcIter ; //! Iterator over FUNC list
TIterator* _coefIter ; //! Iterator over coefficient list
Bool_t _extended ; // Allow use as extended p.d.f.
Bool_t _doFloor ; // Introduce floor at zero in pdf
static Bool_t _doFloorGlobal ; // Global flag for introducing floor at zero in pdf
private:
ClassDef(RooRealSumPdf,3) // PDF constructed from a sum of (non-pdf) functions
};
#endif
|