75using std::map, std::vector, std::cout, std::endl;
 
  115   void CloseWindow() 
override;
 
  116   void DoText(
const char *
text);
 
  118   void DoSlider(
const char *);
 
  121   void HandleButtons();
 
  136   if (
strcmp(
fMC->GetPdf()->ClassName(), 
"RooSimultaneous") == 0) {
 
  137      cout << 
"Is a simultaneous PDF" << endl;
 
  140      cout << 
" with " << 
channelCat->numTypes() << 
" categories" << endl;
 
  143      cout << 
"Is not a simultaneous PDF" << endl;
 
  153   AddFrame(fCanvas, 
fLcan);
 
  156      fCanvas->GetCanvas()->Divide(
numCats);
 
  157      for (
int i = 0; i < 
numCats; ++i) {
 
  158         fCanvas->GetCanvas()->cd(i + 1)->SetBorderMode(0);
 
  159         fCanvas->GetCanvas()->cd(i + 1)->SetGrid();
 
  169   fCheck1->SetToolTipText(
"Pointer position constrained to slider sides");
 
  170   fCheck2->SetToolTipText(
"Pointer position relative to slider position");
 
  177   fFitButton->Connect(
"Clicked()", 
"ModelInspectorGUI", 
this, 
"DoFit()");
 
  179   fExitButton->Connect(
"Clicked()", 
"ModelInspectorGUI", 
this, 
"DoExit()");
 
  181   fCheck1->Connect(
"Clicked()", 
"ModelInspectorGUI", 
this, 
"HandleButtons()");
 
  182   fCheck2->Connect(
"Clicked()", 
"ModelInspectorGUI", 
this, 
"HandleButtons()");
 
  203   parameters.
add(*
fMC->GetParametersOfInterest());
 
  204   parameters.
add(*
fMC->GetNuisanceParameters());
 
  215      cout << 
"Adding Slider for " << param->GetName() << endl;
 
  219         new TGLabel(
hframek, 
Form(
"%s = %.3f +%.3f", param->GetName(), param->getVal(), param->getError()));
 
  222      hsliderk->Connect(
"PointerPositionChanged()", 
"ModelInspectorGUI", 
this, 
"DoSlider()");
 
  223      hsliderk->Connect(
"PositionChanged()", 
"ModelInspectorGUI", 
this, 
"DoSlider()");
 
  224      hsliderk->SetRange(param->getMin(), param->getMax());
 
  230      hsliderk->SetPosition(param->getVal() - param->getError(), param->getVal() + param->getError());
 
  231      hsliderk->SetPointerPosition(param->getVal());
 
  242   SetWindowName(
"RooFit/RooStats Model Inspector");
 
  244   Resize(GetDefaultSize());
 
  251ModelInspectorGUI::~ModelInspectorGUI()
 
  259void ModelInspectorGUI::CloseWindow()
 
  267void ModelInspectorGUI::DoText(
const char * )
 
  284void ModelInspectorGUI::DoFit()
 
  287   map<TGTripleHSlider *, const char *>::iterator it;
 
  294      it->first->SetPointerPosition(param->
getVal());
 
  300void ModelInspectorGUI::DoSlider(
const char *
text)
 
  302   cout << 
"." << 
text << endl;
 
  306void ModelInspectorGUI::DoSlider()
 
  314   if (
strcmp(
fMC->GetPdf()->ClassName(), 
"RooSimultaneous") == 0) {
 
  328      map<TGTripleHSlider *, const char *>::iterator it;
 
  331      fPlot = ((
RooRealVar *)
fMC->GetObservables()->first())->frame();
 
  332      fData->plotOn(fPlot);
 
  338         const char *
name = it->second;
 
  339         fWS->var(
name)->setVal(it->first->GetMaxPosition());
 
  341         fLabelMap[it->first]->SetText(
Form(
"%s = %.3f [%.3f,%.3f]", param->
GetName(), it->first->GetPointerPosition(),
 
  342                                            it->first->GetMinPosition(), it->first->GetMaxPosition()));
 
  350         const char *
name = it->second;
 
  351         fWS->var(
name)->setVal(it->first->GetMinPosition());
 
  359         const char *
name = it->second;
 
  360         fWS->var(
name)->setVal(it->first->GetPointerPosition());
 
  366      fCanvas->GetCanvas()->Modified();
 
  367      fCanvas->GetCanvas()->Update();
 
  390         fPlot = obs->
frame();
 
  400         map<TGTripleHSlider *, const char *>::iterator it;
 
  407            const char *
name = it->second;
 
  408            fWS->var(
name)->setVal(it->first->GetMaxPosition());
 
  411                                               it->first->GetPointerPosition(), it->first->GetMinPosition(),
 
  412                                               it->first->GetMaxPosition()));
 
  420            const char *
name = it->second;
 
  421            fWS->var(
name)->setVal(it->first->GetMinPosition());
 
  424                                               it->first->GetPointerPosition(), it->first->GetMinPosition(),
 
  425                                               it->first->GetMaxPosition()));
 
  433            const char *
name = it->second;
 
  434            fWS->var(
name)->setVal(it->first->GetPointerPosition());
 
  437                                               it->first->GetPointerPosition(), it->first->GetMinPosition(),
 
  438                                               it->first->GetMaxPosition()));
 
  456      fCanvas->GetCanvas()->Modified();
 
  457      fCanvas->GetCanvas()->Update();
 
  464void ModelInspectorGUI::HandleButtons()
 
  477void ModelInspectorGUI::DoExit()
 
  479   printf(
"Exit application...");
 
  492      filename = 
"results/example_combined_GaussExample_model.root";
 
  497         cout << 
"will run standard hist2workspace example" << endl;
 
  498         gROOT->ProcessLine(
".! prepareHistFactory .");
 
  499         gROOT->ProcessLine(
".! hist2workspace config/example.xml");
 
  500         cout << 
"\n\n---------------------" << endl;
 
  501         cout << 
"Done creating example input" << endl;
 
  502         cout << 
"---------------------\n\n" << endl;
 
  513      cout << 
"StandardRooStatsDemoMacro: Input file " << 
filename << 
" is not found" << endl;
 
  524      cout << 
"workspace not found" << endl;
 
  537      cout << 
"data or ModelConfig was not found" << endl;
 
ROOT::RRangeCast< T, false, Range_t > static_range_cast(Range_t &&coll)
R__EXTERN TApplication * gApplication
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 MapSubwindows
Option_t Option_t TPoint TPoint const char text
R__EXTERN void * gTQSender
char * Form(const char *fmt,...)
Formats a string in a circular formatting buffer.
R__EXTERN TSystem * gSystem
const_iterator begin() const
const_iterator end() const
virtual bool add(const RooAbsArg &var, bool silent=false)
Add the specified argument to list.
Abstract base class for binned and unbinned datasets.
Abstract interface for all probability density functions.
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
Create a new RooPlot on the heap with a drawing frame initialized for this object,...
double getVal(const RooArgSet *normalisationSet=nullptr) const
Evaluate object.
RooArgSet is a container object that can hold multiple RooAbsArg objects.
Object to represent discrete states.
RooFitResult is a container class to hold the input and output of a PDF fit to a dataset.
static RooMsgService & instance()
Return reference to singleton instance.
Plot frame and a container for graphics objects within that frame.
Variable that can be changed from the outside.
Facilitates simultaneous fitting of multiple PDFs to subsets of a given dataset.
ModelConfig is a simple class that holds configuration information specifying how a model should be u...
Persistable container for RooFit projects.
virtual void Terminate(Int_t status=0)
Terminate the application by call TSystem::Exit() unless application has been told to return from Run...
TObject * Get(const char *namecycle) override
Return pointer to object identified by namecycle.
A ROOT file is an on-disk file, usually with extension .root, that stores objects in a file-system-li...
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.
A frame containing two scrollbars (a horizontal and a vertical) and a viewport.
A composite frame that layout their children in horizontal way.
This class handles GUI labels.
This class describes layout hints used by the layout classes.
Defines top level windows that interact with the system Window Manager.
A text buffer is used in several widgets, like TGTextEntry, TGFileDialog, etc.
Yield an action as soon as it is clicked.
A TGTextEntry is a one line text input widget.
TripleSlider inherit from DoubleSlider widgets and allow easy selection of a min, max and pointer val...
A composite frame that layout their children in vertical way.
const char * GetName() const override
Returns name of object.
This class creates a TGCanvas in which a TCanvas is created.
virtual Bool_t AccessPathName(const char *path, EAccessMode mode=kFileExists)
Returns FALSE if one can access a file using the specified access mode.
RooCmdArg Save(bool flag=true)
RooCmdArg DataError(Int_t)
RooCmdArg FillColor(Color_t color)
RooCmdArg LineWidth(Width_t width)
RooCmdArg Normalization(double scaleFactor)
RooCmdArg VisualizeError(const RooDataSet ¶mData, double Z=1)
RooCmdArg MarkerSize(Size_t size)
RooCmdArg Cut(const char *cutSpec)
RooCmdArg LineColor(Color_t color)
The namespace RooFit contains mostly switches that change the behaviour of functions of PDFs (or othe...
MsgLevel
Verbosity level for RooMsgService::StreamConfig in RooMsgService.
Namespace for the RooStats classes.