118using std::endl, std::string, std::map, std::list, std::ifstream, std::ofstream, std::ostream;
133struct FinalizeVarsOutput {
135 std::unique_ptr<RooRealVar> weight;
136 std::string weightVarName;
147 FinalizeVarsOutput out;
148 out.finalVars.add(vars);
155 if(
data->isWeighted()) {
170 out.finalVars.add(*indexCat,
true);
175 if(out.weightVarName.empty()) {
195 if (!out.weightVarName.empty() && !
wgtVar) {
196 const char*
name = out.weightVarName.c_str();
198 wgtVar = out.weight.get();
207 if(errorSet) out.errorSet.add(*errorSet,
true);
281 RooCmdConfig pc(
"RooDataSet::ctor(" + std::string(GetName()) +
")");
282 pc.defineInt(
"ownLinked",
"OwnLinked",0) ;
283 pc.defineObject(
"impTree",
"ImportTree",0) ;
284 pc.defineObject(
"impData",
"ImportData",0) ;
285 pc.defineObject(
"indexCat",
"IndexCat",0) ;
286 pc.defineObject(
"impSliceData",
"ImportDataSlice",0,
nullptr,
true) ;
287 pc.defineString(
"impSliceState",
"ImportDataSlice",0,
"",
true) ;
288 pc.defineObject(
"lnkSliceData",
"LinkDataSlice",0,
nullptr,
true) ;
289 pc.defineString(
"lnkSliceState",
"LinkDataSlice",0,
"",
true) ;
290 pc.defineString(
"cutSpec",
"CutSpec",0,
"") ;
291 pc.defineObject(
"cutVar",
"CutVar",0) ;
292 pc.defineString(
"cutRange",
"CutRange",0,
"") ;
293 pc.defineString(
"wgtVarName",
"WeightVarName",0,
"") ;
294 pc.defineInt(
"newWeight1",
"WeightVarName",0,0) ;
295 pc.defineString(
"fname",
"ImportFromFile",0,
"") ;
296 pc.defineString(
"tname",
"ImportFromFile",1,
"") ;
297 pc.defineObject(
"wgtVar",
"WeightVar",0) ;
298 pc.defineInt(
"newWeight2",
"WeightVar",0,0) ;
299 pc.defineObject(
"dummy1",
"ImportDataSliceMany",0) ;
300 pc.defineObject(
"dummy2",
"LinkDataSliceMany",0) ;
301 pc.defineSet(
"errorSet",
"StoreError",0) ;
302 pc.defineSet(
"asymErrSet",
"StoreAsymError",0) ;
303 pc.defineSet(
"glObs",
"GlobalObservables",0,
nullptr) ;
304 pc.defineMutex(
"ImportTree",
"ImportData",
"ImportDataSlice",
"LinkDataSlice",
"ImportFromFile") ;
305 pc.defineMutex(
"CutSpec",
"CutVar") ;
306 pc.defineMutex(
"WeightVarName",
"WeightVar") ;
307 pc.defineDependency(
"ImportDataSlice",
"IndexCat") ;
308 pc.defineDependency(
"LinkDataSlice",
"IndexCat") ;
309 pc.defineDependency(
"OwnLinked",
"LinkDataSlice") ;
321 const std::string
errMsg =
"Error in RooDataSet constructor: command argument list could not be processed";
323 throw std::invalid_argument(
errMsg);
326 if(pc.getSet(
"glObs")) setGlobalObservables(*pc.getSet(
"glObs"));
332 const char*
cutSpec = pc.getString(
"cutSpec",
"",
true) ;
333 const char* cutRange = pc.getString(
"cutRange",
"",
true) ;
334 const char*
wgtVarName = pc.getString(
"wgtVarName",
"",
true) ;
336 const char*
impSliceNames = pc.getString(
"impSliceState",
"",
true) ;
338 const char*
lnkSliceNames = pc.getString(
"lnkSliceState",
"",
true) ;
342 const char*
fname = pc.getString(
"fname") ;
343 const char*
tname = pc.getString(
"tname") ;
345 Int_t newWeight = pc.getInt(
"newWeight1") + pc.getInt(
"newWeight2") ;
368 char *token =
strtok(tmp,
",");
372 token =
strtok(
nullptr,
",");
383 throw std::string(
"RooDataSet::RooDataSet() ERROR in constructor, cannot find index category") ;
389 coutI(InputArguments) <<
"RooDataSet::ctor(" << GetName() <<
") defining state \"" <<
hiter->first <<
"\" in index category " << indexCat->
GetName() << std::endl ;
399 addOwnedComponent(
hiter->first.c_str(),*
hiter->second) ;
404 _dstore = std::make_unique<RooCompositeDataStore>(
name,title,_vars,*
icat,
storeMap) ;
411 if (defaultStorageType==Tree) {
412 _dstore = std::make_unique<RooTreeDataStore>(
name,title,_vars,
wgtVarName) ;
414 }
else if (defaultStorageType==Vector) {
418 wgttmp->setAttribute(
"NewWeight") ;
421 _dstore = std::make_unique<RooVectorDataStore>(
name,title,_vars,
wgtVarName) ;
426 std::map<string,RooAbsData*>
hmap ;
437 std::unique_ptr<RooArgSet>
intErrorSet{_vars.selectCommon(*errorSet)};
440 arg->attachToStore(*_dstore) ;
447 arg->attachToStore(*_dstore) ;
455 std::unique_ptr<RooFormulaVar>
cutVarTmp;
477 std::unique_ptr<TFile> file;
482 std::stringstream
ss;
483 ss <<
"RooDataSet::ctor(" << GetName() <<
") ERROR file '" <<
fname
484 <<
"' cannot be opened or does not exist";
485 const std::string
errMsg =
ss.str();
487 throw std::invalid_argument(
errMsg);
492 std::stringstream
ss;
493 ss <<
"RooDataSet::ctor(" << GetName() <<
") ERROR file '" <<
fname
494 <<
"' does not contain a TTree named '" <<
tname <<
"'";
495 const std::string
errMsg =
ss.str();
497 throw std::invalid_argument(
errMsg);
539 if(vars ==
nullptr) {
558 if(var->getAttribute(
"StoreError")) errorSet.
add(*var);
559 if(var->getAttribute(
"StoreAsymError"))
asymErrorSet.add(*var);
563 return RooFit::makeOwningPtr<RooAbsData>(std::make_unique<RooDataSet>(
581 coutE(DataHandling) <<
"RooDataSet::RooDataSet(" <<
GetName() <<
"): designated weight variable "
582 <<
wgtVarName <<
" not found in set of variables, no weighting will be assigned" << std::endl ;
583 throw std::invalid_argument(
"RooDataSet::initialize() weight variable could not be initialised.");
585 coutE(DataHandling) <<
"RooDataSet::RooDataSet(" <<
GetName() <<
"): designated weight variable "
586 <<
wgtVarName <<
" is not of type RooRealVar, no weighting will be assigned" << std::endl ;
587 throw std::invalid_argument(
"RooDataSet::initialize() weight variable could not be initialised.");
601 const char *cutRange, std::size_t
nStart, std::size_t
nStop)
const
613 if (!cutRange ||
strchr(cutRange,
',') ==
nullptr) {
616 ds._cachedVars.add(
_dstore->cachedVars());
622 errMsg <<
"Error in RooAbsData::reduce! The ranges " << cutRange <<
" are overlapping!";
623 throw std::runtime_error(
errMsg.str());
625 for (
const auto &token :
tokens) {
629 ds._cachedVars.add(
_dstore->cachedVars());
664 title = std::string(
GetTitle()) +
"_binned" ;
693 return e > 0.0 ?
e *
e :
w *
w;
704 throw std::runtime_error(
"RooDataSet::getWeightBatch(): requested range not valid for dataset.");
720 for (std::size_t i = 0; i <
nEntries; ++i) {
726 return std::span<const double>(&*(
_sumW2Buffer->begin() + first),
len);
773 std::unique_ptr<RooFormula> select = nullptr ;
775 select = std::make_unique<RooFormula>(
"select",
cutSpec,*
get()) ;
787 if (select && select->eval()==0.)
continue ;
865 ccoutE(DataHandling) <<
"An event weight/error was passed but no weight variable was defined"
866 <<
" in the dataset '" <<
GetName() <<
"'. The weight will be ignored." << std::endl;
874 coutE(DataHandling) <<
"An event weight error was passed to the RooDataSet '" <<
GetName()
876 <<
"' does not store errors. Check `StoreError` in the RooDataSet constructor." << std::endl;
914 ccoutE(DataHandling) <<
"An event weight was given but no weight variable was defined"
915 <<
" in the dataset '" <<
GetName() <<
"'. The weight will be ignored." << std::endl;
921 coutE(DataHandling) <<
"An event weight error was passed to the RooDataSet '" <<
GetName()
923 <<
"' does not store errors. Check `StoreAsymError` in the RooDataSet constructor." << std::endl;
966 ccoutE(DataHandling) <<
"An event weight was given but no weight variable was defined"
967 <<
" in the dataset '" <<
GetName() <<
"'. The weight will be ignored." << std::endl;
976 coutE(DataHandling) <<
"An event weight error was passed to the RooDataSet '" <<
GetName()
978 <<
"' does not store errors. Check `StoreError` in the RooDataSet constructor." << std::endl;
1024 coutE(InputArguments) <<
"RooDataSet::merge(" <<
GetName() <<
") ERROR: datasets have different size" << std::endl ;
1121 pc.
defineInt(
"lineColor",
"LineColor",0,-999) ;
1122 pc.
defineInt(
"lineStyle",
"LineStyle",0,-999) ;
1123 pc.
defineInt(
"lineWidth",
"LineWidth",0,-999) ;
1124 pc.
defineInt(
"markerColor",
"MarkerColor",0,-999) ;
1125 pc.
defineInt(
"markerStyle",
"MarkerStyle",0,8) ;
1127 pc.
defineInt(
"fillColor",
"FillColor",0,-999) ;
1128 pc.
defineInt(
"fillStyle",
"FillStyle",0,-999) ;
1129 pc.
defineInt(
"histInvisible",
"Invisible",0,0) ;
1142 const char* drawOptions = pc.
getString(
"drawOption") ;
1143 Int_t histInvisible = pc.
getInt(
"histInvisible") ;
1144 const char* histName = pc.
getString(
"histName",
nullptr,
true) ;
1145 double scaleFactor = pc.
getDouble(
"scaleFactor") ;
1154 coutE(InputArguments) <<
"RooDataSet::plotOnXY(" <<
GetName() <<
") ERROR: no YVar() argument specified and dataset is not weighted" << std::endl ;
1160 coutE(InputArguments) <<
"RooDataSet::plotOnXY(" <<
GetName() <<
") ERROR on YVar() argument, dataset does not contain a variable named " <<
yvar->GetName() << std::endl ;
1175 double x =
xvar->getVal() ;
1212 frame->
addPlotable(graph,drawOptions,histInvisible) ;
1283 oocoutE(
nullptr,DataHandling) <<
"RooDataSet::read: ERROR: variable list already contains"
1284 <<
"a non-RooCategory blindState member" << std::endl ;
1287 oocoutW(
nullptr,DataHandling) <<
"RooDataSet::read: WARNING: recycling existing "
1288 <<
"blindState category in variable list" << std::endl ;
1293 blindCat->setAttribute(
"Dynamic") ;
1300 bool verbose= !
opts.Contains(
"q");
1303 auto data = std::make_unique<RooDataSet>(
"dataset",
fileList, variables);
1306 oocoutE(
nullptr,DataHandling) <<
"RooDataSet::read: unable to create a new dataset"
1321 oocoutE(
data.get(),DataHandling) <<
"RooDataSet::read: no index category named "
1322 <<
indexCatName <<
" in supplied variable list" << std::endl ;
1327 <<
" is not a RooCategory" << std::endl ;
1365 oocoutE(
data.get(), DataHandling) <<
"RooDataSet::read: Error, cannot register automatic type name " <<
newLabel
1366 <<
" in index category " << indexCat->
GetName() << std::endl ;
1374 oocoutI(
data.get(), DataHandling) <<
"RooDataSet::read: reading file " <<
filename << std::endl ;
1382 oocoutE(
data.get(), DataHandling) <<
"RooDataSet::read: unable to open '"
1383 <<
filename <<
"'. Returning nullptr now." << std::endl;
1391 while(file.good() && !file.eof()) {
1396 if (file.peek() ==
'#') {
1400 bool readError = variables.readFromStream(file,
true,verbose) ;
1401 data->_vars.assign(variables) ;
1405 oocoutE(
data.get(), DataHandling) <<
"RooDataSet::read(static): read error at line " <<
line << std::endl ;
1418 while (
isspace(file.peek())) {
1420 file >> std::noskipws >> dummy >> std::skipws;
1434 for (
const auto&
nameIdx : *indexCat) {
1438 oocoutI(
data.get(),DataHandling) <<
"RooDataSet::read: read " <<
data->numEntries()
1439 <<
" events (ignored " <<
outOfRange <<
" out of range events)" << std::endl;
1441 return data.release();
1458 coutE(DataHandling) <<
"RooDataSet::write(" <<
GetName() <<
") cannot create file " <<
filename << std::endl ;
1463 coutI(DataHandling) <<
"RooDataSet::write(" <<
GetName() <<
") writing ASCII file " <<
filename << std::endl ;
1477 get(i)->writeToStream(
ofs,
true);
1481 coutW(DataHandling) <<
"RooDataSet::write(" <<
GetName() <<
"): WARNING error(s) have occurred in writing" << std::endl ;
1499 os <<
indent <<
" Dataset variable \"" <<
_wgtVar->
GetName() <<
"\" is interpreted as the event weight" << std::endl ;
1530 os << arg->GetName() ;
1567 if (
R__b.IsReading()) {
1638 const char *
cstr =
"cstr";
1653 throw std::invalid_argument(
"Only one of cutVar or cutSpec should be not a nullptr!");
1671 coutI(InputArguments) <<
"RooDataSet::ctor(" <<
GetName() <<
") defining state \"" <<
item.first
1672 <<
"\" in index category " << indexCat.
GetName() << std::endl;
1678 std::unique_ptr<RooFormulaVar>
cutVarTmp;
1699 os <<
"Contents of RooDataSet \"" <<
GetName() <<
"\"" << std::endl;
1702 os <<
"(dataset is empty)" << std::endl;
1706 if (
get() ==
nullptr ||
get()->empty()) {
1707 os <<
"(dataset has no observables)" << std::endl;
1713 os <<
" Entry " << i <<
": ";
1716 for (
const auto* var : *row) {
1717 if (!first) os <<
", ";
1720 os << var->GetName() <<
"=";
1724 os <<
catVar->getLabel();
1726 os <<
"(unsupported type)";
1730 os <<
", weight=" <<
weight();
1734 if (lo != 0.0 ||
hi != 0.0) {
1735 os <<
" ±[" << lo <<
"," <<
hi <<
"]";
ROOT::RRangeCast< T, false, Range_t > static_range_cast(Range_t &&coll)
int Int_t
Signed integer 4 bytes (int)
float Size_t
Attribute size (float)
short Version_t
Class version identifier (short)
static void indent(ostringstream &buf, int indent_level)
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void data
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char filename
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t index
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t Atom_t Time_t UChar_t len
The Kahan summation is a compensated summation algorithm, which significantly reduces numerical error...
const_iterator begin() const
const_iterator end() const
Common abstract base class for objects that represent a value and a "shape" in RooFit.
void setAttribute(const Text_t *name, bool value=true)
Set (default) or clear a named boolean attribute of this object.
bool hasLabel(const std::string &label) const
Check if a state with name label exists.
virtual void removeAll()
Remove all arguments from our set, deleting them if we own them.
virtual bool remove(const RooAbsArg &var, bool silent=false, bool matchByNameOnly=false)
Remove the specified argument from our list.
bool allInRange(const char *rangeSpec) const
Return true if all contained object report to have their value inside the specified range.
void assignFast(const RooAbsCollection &other, bool setValDirty=true) const
Functional equivalent of assign() but assumes this and other collection have same layout.
virtual bool add(const RooAbsArg &var, bool silent=false)
Add the specified argument to list.
void assign(const RooAbsCollection &other) const
Sets the value, cache and constant attribute of any argument in our set that also appears in the othe...
virtual bool addOwned(RooAbsArg &var, bool silent=false)
Add an argument and transfer the ownership to the collection.
virtual RooAbsArg * addClone(const RooAbsArg &var, bool silent=false)
Add a clone of the specified argument to list.
RooAbsArg * find(const char *name) const
Find object with given name in list.
Abstract base class for a data collection.
virtual bool isWeighted() const =0
virtual double sumEntries() const
virtual double weightError(RooAbsData::ErrorType etype=RooAbsData::Poisson) const =0
virtual double weight() const =0
Abstract base class for binned and unbinned datasets.
virtual const RooArgSet * get() const
void printMultiline(std::ostream &os, Int_t contents, bool verbose=false, TString indent="") const override
Interface for detailed printing of object.
void SetName(const char *name) override
Set the name of the TNamed.
RooAbsDataStore * store()
std::unique_ptr< RooAbsDataStore > _dstore
Data storage implementation.
RooArgSet _vars
Dimensions of this data set.
virtual Int_t numEntries() const
Return number of entries in dataset, i.e., count unweighted entries.
void Streamer(TBuffer &) override
Stream an object of class RooAbsData.
double getVal(const RooArgSet *normalisationSet=nullptr) const
Evaluate object.
RooArgList is a container object that can hold multiple RooAbsArg objects.
RooArgSet is a container object that can hold multiple RooAbsArg objects.
void Streamer(TBuffer &) override
Stream an object of class TObject.
Object to represent discrete states.
bool setIndex(Int_t index, bool printError=true) override
Set value by specifying the index code of the desired state.
bool defineType(const std::string &label)
Define a state with given name.
bool setLabel(const char *label, bool printError=true) override
Set value by specifying the name of the desired state.
Named container for two doubles, two integers two object points and three string pointers that can be...
const char * getString(Int_t idx) const
Return string stored in slot idx.
Configurable parser for RooCmdArg named arguments.
bool process(const RooCmdArg &arg)
Process given RooCmdArg.
double getDouble(const char *name, double defaultValue=0.0) const
Return double property registered with name 'name'.
bool defineDouble(const char *name, const char *argName, int doubleNum, double defValue=0.0)
Define double property name 'name' mapped to double in slot 'doubleNum' in RooCmdArg with name argNam...
bool ok(bool verbose) const
Return true of parsing was successful.
bool defineObject(const char *name, const char *argName, int setNum, const TObject *obj=nullptr, bool isArray=false)
Define TObject property name 'name' mapped to object in slot 'setNum' in RooCmdArg with name argName ...
const char * getString(const char *name, const char *defaultValue="", bool convEmptyToNull=false) const
Return string property registered with name 'name'.
bool defineString(const char *name, const char *argName, int stringNum, const char *defValue="", bool appendMode=false)
Define double property name 'name' mapped to double in slot 'stringNum' in RooCmdArg with name argNam...
bool defineInt(const char *name, const char *argName, int intNum, int defValue=0)
Define integer property name 'name' mapped to integer in slot 'intNum' in RooCmdArg with name argName...
int getInt(const char *name, int defaultValue=0) const
Return integer property registered with name 'name'.
TObject * getObject(const char *name, TObject *obj=nullptr) const
Return TObject property registered with name 'name'.
Container class to hold N-dimensional binned data.
double weight(std::size_t i) const
Return weight of i-th bin.
double weightSquared(std::size_t i) const
Return squared weight sum of i-th bin.
const RooArgSet * get() const override
Get bin centre of current bin.
Container class to hold unbinned data.
RooFit::OwningPtr< RooAbsData > emptyClone(const char *newName=nullptr, const char *newTitle=nullptr, const RooArgSet *vars=nullptr, const char *wgtVarName=nullptr) const override
Return an empty clone of this dataset.
RooRealVar * _wgtVar
Pointer to weight variable (if set)
bool _doWeightErrorCheck
! When adding events with weights, check that weights can actually be stored.
RooArgSet _varsNoWgt
Vars without weight variable.
void loadValuesFromSlices(RooCategory &indexCat, std::map< std::string, RooAbsData * > const &slices, const char *rangeName, RooFormulaVar const *cutVar, const char *cutSpec)
RooFit::OwningPtr< RooDataHist > binnedClone(const char *newName=nullptr, const char *newTitle=nullptr) const
Return binned clone of this dataset.
void weightError(double &lo, double &hi, ErrorType etype=SumW2) const override
Return the asymmetric errors on the current weight.
const RooArgSet * get() const override
Return a RooArgSet with the coordinates of the current event.
void printContents(std::ostream &os=std::cout) const override
Print the contents of the dataset to the specified output stream.
virtual RooPlot * plotOnXY(RooPlot *frame, const RooCmdArg &arg1={}, const RooCmdArg &arg2={}, const RooCmdArg &arg3={}, const RooCmdArg &arg4={}, const RooCmdArg &arg5={}, const RooCmdArg &arg6={}, const RooCmdArg &arg7={}, const RooCmdArg &arg8={}) const
Special plot method for 'X-Y' datasets used in fitting.
void initialize(const char *wgtVarName)
Initialize the dataset.
void printArgs(std::ostream &os) const override
Print argument of dataset, i.e. the observable names.
void SetName(const char *name) override
Change the name of this dataset into the given name.
virtual void addFast(const RooArgSet &row, double weight=1.0, double weightError=0.0)
Add a data point, with its coordinates specified in the 'data' argset, to the data set.
bool merge(RooDataSet *data1, RooDataSet *data2=nullptr, RooDataSet *data3=nullptr, RooDataSet *data4=nullptr, RooDataSet *data5=nullptr, RooDataSet *data6=nullptr)
TClass * IsA() const override
virtual RooAbsArg * addColumn(RooAbsArg &var, bool adjustRange=true)
Add a column with the values of the given (function) argument to this dataset.
bool write(const char *filename) const
Write the contents of this dataset to an ASCII file with the specified name.
double sumEntries() const override
Return effective number of entries in dataset, i.e., sum all weights.
std::span< const double > getWeightBatch(std::size_t first, std::size_t len, bool sumW2) const override
~RooDataSet() override
Destructor.
bool isNonPoissonWeighted() const override
Returns true if histogram contains bins with entries with a non-integer weight.
void SetNameTitle(const char *name, const char *title) override
Change the title of this dataset into the given name.
void printValue(std::ostream &os) const override
Print value of the dataset, i.e. the sum of weights contained in the dataset.
void append(RooDataSet &data)
Add all data points of given data set to this data set.
RooDataSet()
Default constructor for persistence.
std::unique_ptr< std::vector< double > > _sumW2Buffer
! Buffer for sumW2 in case a batch of values is requested.
void Streamer(TBuffer &) override
Stream an object of class RooDataSet.
void add(const RooArgSet &row, double weight, double weightError)
Add one ore more rows of data.
unsigned short _errorMsgCount
! Counter to silence error messages when filling dataset.
std::unique_ptr< RooAbsData > reduceEng(const RooArgSet &varSubset, const RooFormulaVar *cutVar, const char *cutRange=nullptr, std::size_t nStart=0, std::size_t nStop=std::numeric_limits< std::size_t >::max()) const override
Implementation of RooAbsData virtual method that drives the RooAbsData::reduce() methods.
void convertToTreeStore() override
Convert vector-based storage to tree-based storage.
void printMultiline(std::ostream &os, Int_t contents, bool verbose=false, TString indent="") const override
Print info about this dataset to the specified output stream.
double weightSquared() const override
Return squared event weight of the current event.
double weight() const override
Return event weight of current event.
static RooDataSet * read(const char *filename, const RooArgList &variables, const char *opts="", const char *commonPath="", const char *indexCatName=nullptr)
Read data from a text file and create a dataset from it.
bool isWeighted() const override
Return true if dataset contains weighted events.
Utility base class for RooFit objects that are to be attached to ROOT directories.
virtual void Streamer(TBuffer &)
void removeFromDir(TObject *obj)
Remove object from directory it was added to.
TDirectory * _dir
! Associated directory
Graphical representation of binned data based on the TGraphAsymmErrors class.
void addBinWithXYError(Axis_t binCenter, double n, double exlow, double exhigh, double eylow, double eyhigh, double scaleFactor=1.0)
Add a bin to this histogram with the specified bin contents and error.
Collection class for internal use, storing a collection of RooAbsArg pointers in a doubly linked list...
virtual void Add(TObject *arg)
Plot frame and a container for graphics objects within that frame.
RooAbsRealLValue * getPlotVar() const
void addPlotable(RooPlotable *plotable, Option_t *drawOptions="", bool invisible=false, bool refreshNorm=false)
Add the specified plotable object to our plot.
Variable that can be changed from the outside.
void setVal(double value) override
Set value of variable to 'value'.
void setError(double value)
void setAsymError(double lo, double hi)
The RooStringView is a wrapper around a C-style string that can also be constructed from a std::strin...
TTree-backed data storage.
virtual void SetFillColor(Color_t fcolor)
Set the fill area color.
virtual void SetFillStyle(Style_t fstyle)
Set the fill area style.
virtual void SetLineStyle(Style_t lstyle)
Set the line style.
virtual void SetLineWidth(Width_t lwidth)
Set the line width.
virtual void SetLineColor(Color_t lcolor)
Set the line color.
virtual void SetMarkerColor(Color_t mcolor=1)
Set the marker color.
virtual void SetMarkerStyle(Style_t mstyle=1)
Set the marker style.
virtual void SetMarkerSize(Size_t msize=1)
Set the marker size.
Buffer base class used for serializing objects.
static TClass * GetClass(const char *name, Bool_t load=kTRUE, Bool_t silent=kFALSE)
Static method returning pointer to TClass of the specified class name.
virtual TList * GetList() const
static TFile * Open(const char *name, Option_t *option="", const char *ftitle="", Int_t compress=ROOT::RCompressionSetting::EDefaults::kUseCompiledDefault, Int_t netopt=0)
Create / open a file.
void SetName(const char *name="") override
Set graph name.
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
const char * GetName() const override
Returns name of object.
const char * GetTitle() const override
Returns title of object.
Mother of all ROOT objects.
A TTree represents a columnar dataset.
RooCmdArg StoreError(const RooArgSet &aset)
RooCmdArg WeightVar(const char *name="weight", bool reinterpretAsWeight=false)
std::vector< std::string > Split(std::string_view str, std::string_view delims, bool skipEmpty=false)
Splits a string at each character in delims.
The namespace RooFit contains mostly switches that change the behaviour of functions of PDFs (or othe...
T * OwningPtr
An alias for raw pointers for indicating that the return type of a RooFit function is an owning point...
OwningPtr< T > makeOwningPtr(std::unique_ptr< T > &&ptr)
Internal helper to turn a std::unique_ptr<T> into an OwningPtr.
bool checkIfRangesOverlap(RooArgSet const &observables, std::vector< std::string > const &rangeNames)
void initialize(typename Architecture_t::Matrix_t &A, EInitialization m)