15 #ifndef ROO_NDKEYS_PDF
16 #define ROO_NDKEYS_PDF
35 class VecVecDouble :
public std::vector<std::vector<Double_t> > { } ;
37 typedef std::pair<Int_t, VecVecDouble::iterator >
iiPair;
38 typedef std::vector< iiPair >
iiVec;
39 typedef std::pair<Int_t, VecTVecDouble::iterator >
itPair;
40 typedef std::vector< itPair >
itVec;
115 Double_t gauss(std::vector<Double_t>&
x, std::vector<std::vector<Double_t> >& weights)
const;
116 void loopRange(std::vector<Double_t>&
x, std::map<Int_t,Bool_t>& ibMap)
const;
139 mutable std::vector<std::vector<Double_t> >
_dataPts;
143 mutable std::vector<std::vector<Double_t> >*
_weights;
151 mutable std::vector<Double_t>
_rho;
153 mutable std::vector<Double_t>
_x;
172 mutable std::vector<Int_t>
_idx;
175 mutable std::map<Int_t,Double_t>
_wMap;
194 return (aVec[
idx]<bVec[
idx]);
std::vector< itPair > itVec
std::vector< iiPair > iiVec
std::vector< Double_t > xVarHi
std::vector< Double_t > _xVarLo
std::vector< std::string > _varName
std::vector< Int_t > bIdcs
void boxInfoInit(BoxInfo *bi, const char *rangeName, Int_t code) const
virtual TObject * clone(const char *newname) const
std::vector< Int_t > _bIdcs
std::vector< Double_t > _xDatLo
Double_t evaluate() const
do not persist
std::vector< Double_t > _x1
Iterator abstract base class.
Int_t getAnalyticalIntegral(RooArgSet &allVars, RooArgSet &analVars, const char *rangeName=0) const
Interface function getAnalyticalIntergral advertises the analytical integrals that are supported...
std::vector< Double_t > _xDatHi
std::vector< Double_t > _xVarLoM3s
std::vector< std::vector< Double_t > > _weights1
std::vector< Double_t > _xVarHiM3s
std::pair< Int_t, VecVecDouble::iterator > iiPair
#define ClassDef(name, id)
void loopRange(std::vector< Double_t > &x, std::map< Int_t, Bool_t > &ibMap) const
determine closest points to x, to loop over in evaluate()
std::map< Int_t, Double_t > _wMap
void calculateBandWidth() const
std::map< std::pair< std::string, int >, BoxInfo * > _rangeBoxInfo
void fixShape(Bool_t fix)
std::vector< Double_t > _xDatLo3s
std::vector< std::vector< Double_t > > * _weights
RooRealVar represents a fundamental (non-derived) real valued object.
void sortDataIndices(BoxInfo *bi=0) const
sort entries, as needed for loopRange()
std::vector< Double_t > xVarHiP3s
void calculatePreNorm(BoxInfo *bi) const
bi->nEventsBMSW=0.
std::vector< Double_t > _x
TPaveLabel title(3, 27.1, 15, 28.7,"ROOT Environment and Tools")
std::vector< itVec > _sortTVIdcs
void setOptions() const
set the configuration
void createPdf(Bool_t firstCall=kTRUE) const
evaluation order of constructor.
std::vector< Double_t > xVarHiM3s
RooNDKeysPdf(const char *name, const char *title, const RooArgList &varList, RooDataSet &data, TString options="a", Double_t rho=1, Double_t nSigma=3, Bool_t rotate=kTRUE)
RooDataSet is a container class to hold unbinned data.
std::vector< Double_t > _x0
Generic N-dimensional implementation of a kernel estimation p.d.f.
RooListProxy is the concrete proxy for RooArgList objects.
std::vector< Double_t > _mean
std::vector< Double_t > _xVarHiP3s
RooAbsReal is the common abstract base class for objects that represent a real value and implements f...
std::map< Int_t, Bool_t > _bpsIdcs
std::vector< Int_t > sIdcs
void mirrorDataSet() const
determine mirror dataset.
std::vector< Double_t > xVarLoP3s
std::vector< Double_t > _xVarHi
std::vector< Int_t > _idx
std::pair< Int_t, VecTVecDouble::iterator > itPair
bool operator()(const itPair &a, const itPair &b)
std::vector< Double_t > _xDatHi3s
std::vector< Int_t > _sIdcs
Mother of all ROOT objects.
std::map< Int_t, Bool_t > bpsIdcs
std::vector< Int_t > bmsIdcs
std::vector< Double_t > _rho
void initialize() const
initialization
RooAbsPdf is the abstract interface for all probability density functions The class provides hybrid a...
Double_t analyticalIntegral(Int_t code, const char *rangeName=0) const
Implements the actual analytical integral(s) advertised by getAnalyticalIntegral. ...
void calculateShell(BoxInfo *bi) const
determine points in +/- nSigma shell around the box determined by the variable ranges.
std::vector< TVectorD > _dataPtsR
std::vector< std::vector< Double_t > > _dataPts
std::vector< std::vector< Double_t > > _weights0
void loadWeightSet() const
void loadDataSet(Bool_t firstCall) const
copy the dataset and calculate some useful variables
SorterTV_L2H(Int_t index)
std::vector< Double_t > _xVarLoP3s
std::vector< Double_t > _sigma
std::vector< Double_t > xVarLo
std::vector< Int_t > _bmsIdcs
Double_t gauss(std::vector< Double_t > &x, std::vector< std::vector< Double_t > > &weights) const
loop over all closest point to x, as determined by loopRange()
std::vector< Double_t > xVarLoM3s
std::vector< iiVec > _sortIdcs
std::vector< Double_t > _x2