95 using namespace HistFactory;
164 std::vector< HistFactory::Measurement > measurement_list;
185 for(
unsigned int i = 0; i < measurement_list.size(); ++i) {
197 std::string rowTitle = measurement.
GetName();
202 TFile* outFile =
new TFile(outputFileName.c_str(),
"recreate");
204 measurement.
GetLumi(), lumiError,
208 vector<RooWorkspace*> channel_workspaces;
209 vector<string> channel_names;
218 for(
unsigned int chanItr = 0; chanItr < measurement.
GetChannels().size(); ++chanItr ) {
223 string ch_name=channel.
GetName();
224 channel_names.push_back(ch_name);
226 std::vector< EstimateSummary >
dummy;
229 std::cout <<
"Failed to create SingleChannelModel for channel: " << channel.
GetName()
230 <<
" and measurement: " << measurement.
GetName() << std::endl;
234 channel_workspaces.push_back(ws);
239 std::cout <<
"Setting Parameter of Interest as :" << measurement.
GetPOI() << endl;
252 proto_config->
SetPdf( *ws->
pdf(
"newSimPdf") );
260 std::string ChannelFileName = measurement.
GetOutputFilePrefix() +
"_" + ch_name +
"_" + rowTitle +
"_model.root";
268 TFile* chanFile =
TFile::Open( ChannelFileName.c_str(),
"UPDATE" );
275 cout <<
"can't do fit for this channel, no parameter of interest"<<endl;
277 factory.FitModel(ws, ch_name,
"newSimPdf",
"expData",
false);
280 fprintf(
factory.pFile,
" & " );
287 std::cout <<
"Error: Failed to create workspace" << std::endl;
298 cout <<
"Setting Parameter of Interest as :" << measurement.
GetPOI() << endl;
311 combined_config->
SetPdf(*ws->
pdf(
"newSimPdf"));
316 std::string CombinedFileName = measurement.
GetOutputFilePrefix()+
"_combined_"+rowTitle+
"_model.root";
318 TFile* combFile =
TFile::Open( CombinedFileName.c_str(),
"UPDATE" );
328 cout <<
"can't do fit for this channel, no parameter of interest"<<endl;
330 factory.FitModel(ws,
"combined",
"simPdf",
"simData",
false);
virtual const char * GetName() const
Returns name of object.
ModelConfig is a simple class that holds configuration information specifying how a model should be u...
void topDriver(string input)
virtual Bool_t add(const RooAbsCollection &col, Bool_t silent=kFALSE)
Add a collection of arguments to this collection by calling add() for each element in the source coll...
void GuessObsAndNuisance(const RooAbsData &data)
guesses Observables and ParametersOfInterest if not already set
std::string GetPOI(unsigned int i=0)
std::string GetOutputFilePrefix()
static TFile * Open(const char *name, Option_t *option="", const char *ftitle="", Int_t compress=1, Int_t netopt=0)
Create / open a file.
std::vector< RooStats::HistFactory::Channel > & GetChannels()
virtual void SetPdf(const RooAbsPdf &pdf)
Set the Pdf, add to the the workspace if not already there.
std::map< std::string, double > & GetUniformSyst()
RooRealVar represents a fundamental (non-derived) real valued object.
RooAbsData * data(const char *name) const
Retrieve dataset (binned or unbinned) with given name. A null pointer is returned if not found...
std::vector< RooStats::HistFactory::Measurement > GetMeasurementsFromXML(std::string input)
Bool_t writeToFile(const char *fileName, Bool_t recreate=kTRUE)
Save this current workspace into given file.
RooAbsData is the common abstract base class for binned and unbinned datasets.
TObject * obj(const char *name) const
Return any type of object (RooAbsArg, RooAbsData or generic object) with given name) ...
std::vector< std::string > & GetConstantParams()
Namespace for the RooStats classes.
RooAbsPdf * pdf(const char *name) const
Retrieve p.d.f (RooAbsPdf) with given name. A null pointer is returned if not found.
static RooMathCoreReg dummy
std::map< std::string, double > & GetLogNormSyst()
RooRealVar * var(const char *name) const
Retrieve real-valued variable (RooRealVar) with given name. A null pointer is returned if not found...
virtual void SetParametersOfInterest(const RooArgSet &set)
void Print(Option_t *opts=0) const
Print contents of the workspace.
void writeToFile(TFile *file)
The RooWorkspace is a persistable container for RooFit projects.
std::map< std::string, double > & GetGammaSyst()