55 fComboBkgPdf(nullptr),
56 fComboSigBkgPdf(nullptr),
57 fComboDataset(nullptr),
58 fCombinationDone(false),
82 fComboBkgPdf(nullptr),
83 fComboSigBkgPdf(nullptr),
84 fComboDataset(nullptr),
85 fCombinationDone(false),
99 TNamed(
"hlfactory",
"hlfactory"),
101 fComboBkgPdf(nullptr),
102 fComboSigBkgPdf(nullptr),
103 fComboDataset(nullptr),
104 fCombinationDone(false),
142 const char* SigBkgPdfName,
143 const char* BkgPdfName,
144 const char* DatasetName){
146 std::cerr <<
"Cannot add anymore channels. "
147 <<
"Combination already carried out.\n";
151 if (SigBkgPdfName!=
nullptr){
152 if (
fWs->
pdf(SigBkgPdfName)==
nullptr){
153 std::cerr <<
"Pdf " << SigBkgPdfName <<
" not found in workspace!\n";
160 if (BkgPdfName!=
nullptr){
161 if (
fWs->
pdf(BkgPdfName)==
nullptr){
162 std::cerr <<
"Pdf " << BkgPdfName <<
" not found in workspace!\n";
169 if (DatasetName!=
nullptr){
170 if (
fWs->
data(DatasetName)==
nullptr){
171 std::cerr <<
"Dataset " << DatasetName <<
" not found in workspace!\n";
210 for(
auto * ostring : static_range_cast<TObjString*>(
fSigBkgPdfNames)) {
211 pdfs.
add( *(
fWs->
pdf(ostring->String().Data())) );
255 for(
auto * ostring : static_range_cast<TObjString*>(
fBkgPdfNames)) {
256 pdfs.
add( *
fWs->
pdf(ostring->String().Data()) );
315 if (!
data)
return nullptr;
387 const int maxDeepness=50;
389 TString warning(
"The inclusion stack is deeper than ");
390 warning+=maxDeepness;
391 warning+=
". Is this a recursive inclusion?";
397 std::ifstream ifile(fileName);
402 error+=
" could not be opened.";
413 TString ifileContentStripped(
"");
415 std::unique_ptr<TObjArray> lines_array{ifileContent.
Tokenize(
"\n")};
417 bool in_comment=
false;
420 for(
TObject * line_o : *lines_array) {
425 if (
line.EndsWith(
"*/")){
427 if (
fVerbose)
Info(
"fReadFile",
"Out of multiline comment ...");
434 if ((
line.BeginsWith(
"/*") &&
line.EndsWith(
"*/")) ||
435 line.BeginsWith(
"//")){
436 if (
fVerbose)
Info(
"fReadFile",
"In single line comment ...");
441 if (
line.BeginsWith(
"/*")){
443 if (
fVerbose)
Info(
"fReadFile",
"In multiline comment ...");
447 ifileContentStripped+=
line+
"\n";
452 lines_array.reset(ifileContentStripped.
Tokenize(
";"));
455 const int nNeutrals=2;
456 TString neutrals[nNeutrals]={
"\t",
" "};
458 for(
TObject * line_o : *lines_array) {
466 line.ReplaceAll(
"\n",
"");
469 if (
line.BeginsWith(
"echo")){
472 std::cout <<
"Echoing line " <<
line.Data() << std::endl;
473 std::cout <<
"[" <<
GetName() <<
"] echo: "
474 <<
line.Data() << std::endl;
479 for (
int i=0;i<nNeutrals;++i)
480 line.ReplaceAll(neutrals[i],
"");
487 if (
fVerbose)
Info(
"fReadFile",
"%s",
"Empty line: skipping ...");
493 if (
line.BeginsWith(
"#include")){
494 line.ReplaceAll(
"#include",
"");
495 if (
fVerbose)
Info(
"fReadFile",
"Reading included file...");
525 for (
auto * ostring : static_range_cast<TObjString*>(
fLabelsNames)) {
541 std::cerr <<
"The number of datasets and models added as channels "
542 <<
" is not the same!\n";
555 const int nequals =
line.CountChar(
'=');
559 if (
line.Contains(
"::") ||
561 (
line.Contains(
"[") &&
562 line.Contains(
"]") &&
564 !
line.Contains(
"(") &&
565 !
line.Contains(
")"))) {
572 (nequals > 1 &&
line.Contains(
"SIMUL"))){
576 const int equal_index=
line.First(
'=');
577 const int par_index=
line.First(
'(');
579 TString o_class(
line(equal_index+1,par_index-equal_index-1));
582 if (
fVerbose)
Info(
"fParseLine",
"o_name=%s o_class=%s o_descr=%s",
587 if (o_class ==
"import"){
593 const int n_descr_parts=descr_array->
GetEntries();
595 if (n_descr_parts<2 || n_descr_parts>3)
596 Error(
"fParseLine",
"Import wrong syntax: cannot process %s", o_descr.
Data());
602 std::unique_ptr<TFile> ifile{
TFile::Open(rootfile_name)};
606 if (n_descr_parts==3){
610 else if(n_descr_parts==2){
612 Info(
"fParseLine",
"Importing %s from %s under the name of %s",
614 TObject* the_obj=ifile->Get(obj_name);
620 new_line=o_class+
"::"+o_name+
"("+o_descr+
")";
623 std::cout <<
"DEBUG: line: " <<
line.Data() << std::endl;
624 std::cout <<
"DEBUG: new_line: " << new_line.
Data() << std::endl;
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
void Print(Option_t *options=nullptr) const override
Print the object to the defaultPrintStream().
virtual bool add(const RooAbsArg &var, bool silent=false)
Add the specified argument to list.
void Print(Option_t *options=nullptr) const override
This method must be overridden when a class wants to print itself.
Abstract interface for all probability density functions.
RooArgList is a container object that can hold multiple RooAbsArg objects.
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.
RooDataSet is a container class to hold unbinned data.
virtual RooAbsArg * addColumn(RooAbsArg &var, bool adjustRange=true)
Add a column with the values of the given (function) argument to this dataset.
void append(RooDataSet &data)
Add all data points of given data set to this data set.
Facilitates simultaneous fitting of multiple PDFs to subsets of a given dataset.
HLFactory is an High Level model Factory allows you to describe your models in a configuration file (...
TList fSigBkgPdfNames
List of channels names to combine for the signal plus background pdfs.
RooWorkspace * fWs
The RooWorkspace containing the models and variables.
TList fBkgPdfNames
List of channels names to combine for the background pdfs.
int fInclusionLevel
Keep trace of the inclusion deepness.
RooAbsPdf * fComboBkgPdf
The background model combination.
TList fLabelsNames
List of channels names to combine for the datasets.
RooDataSet * GetTotDataSet()
Get the combined dataset.
int fParseLine(TString &line)
Parse a single line an puts the content in the RooWorkSpace.
HLFactory()
Default Constructor.
RooCategory * fComboCat
The category of the combination.
RooDataSet * fComboDataset
The datasets combination.
TList fDatasetsNames
List of channels names to combine for the datasets.
RooAbsPdf * GetTotBkgPdf()
Get the combined background pdf.
RooAbsPdf * fComboSigBkgPdf
The signal plus background model combination.
bool fNamesListsConsistent()
Check the length of the lists.
bool fCombinationDone
Flag to keep trace of the status of the combination.
RooAbsPdf * GetTotSigBkgPdf()
Get the combined signal plus background pdf.
int AddChannel(const char *label, const char *SigBkgPdfName, const char *BkgPdfName=nullptr, const char *datasetName=nullptr)
Add channel for the combination.
int ProcessCard(const char *filename)
Process a configuration file.
RooCategory * GetTotCategory()
Get the combined dataset.
bool fOwnWs
Owns workspace.
~HLFactory() override
Default Destructor.
void fCreateCategory()
Create the category for the combinations.
bool fVerbose
The verbosity flag.
int fReadFile(const char *fileName, bool is_included=false)
Read the actual cfg file.
Persistable container for RooFit projects.
RooAbsPdf * pdf(RooStringView name) const
Retrieve p.d.f (RooAbsPdf) with given name. A null pointer is returned if not found.
bool import(const RooAbsArg &arg, 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 RooCmdArg &arg9={})
Import a RooAbsArg object, e.g.
RooFactoryWSTool & factory()
Return instance to factory tool.
RooAbsData * data(RooStringView name) const
Retrieve dataset (binned or unbinned) with given name. A null pointer is returned if not found.
virtual Int_t GetEntries() const
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
virtual Int_t GetSize() const
Return the capacity of the collection, i.e.
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 Add(TObject *obj) override
TObject * First() const override
Return the first object in the list. Returns 0 when list is empty.
TObject * At(Int_t idx) const override
Returns the object at position idx. Returns 0 if idx is out of range.
The TNamed class is the base class for all named ROOT classes.
const char * GetName() const override
Returns name of object.
Int_t GetEntries() const override
Return the number of objects in array (i.e.
TObject * At(Int_t idx) const override
Collectable string class.
const TString & GetString() const
Mother of all ROOT objects.
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
virtual void Info(const char *method, const char *msgfmt,...) const
Issue info message.
const char * Data() const
TString & ReplaceAll(const TString &s1, const TString &s2)
TObjArray * Tokenize(const TString &delim) const
This function is used to isolate sequential tokens in a TString.
std::istream & ReadFile(std::istream &str)
Replace string with the contents of strm, stopping at an EOF.
The namespace RooFit contains mostly switches that change the behaviour of functions of PDFs (or othe...
Namespace for the RooStats classes.