-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathLLHScanTutorial.cpp
More file actions
executable file
·30 lines (27 loc) · 1.21 KB
/
LLHScanTutorial.cpp
File metadata and controls
executable file
·30 lines (27 loc) · 1.21 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
// MaCh3 spline includes
#include "Fitters/MaCh3Factory.h"
#include "SamplesTutorial/SampleHandlerTutorial.h"
int main(int argc, char *argv[]){
// Initialise manger responsible for config handling
auto FitManager = MaCh3ManagerFactory(argc, argv);
std::string OutputName = "LLH_" + FitManager->raw()["General"]["OutputFile"].as<std::string>();
FitManager->OverrideSettings("General", "OutputFile", OutputName);
// Initialise covariance class reasonable for Systematics
auto xsec = MaCh3CovarianceFactory<ParameterHandlerGeneric>(FitManager.get(), "Xsec");
// Initialise samplePDF
auto SampleConfig = Get<std::vector<std::string>>(FitManager->raw()["General"]["TutorialSamples"], __FILE__ , __LINE__);
auto mySamples = MaCh3SampleHandlerFactory<SampleHandlerTutorial>(SampleConfig, xsec.get());
// Create MCMC Class
std::unique_ptr<FitterBase> MaCh3Fitter = MaCh3FitterFactory(FitManager.get());
// Add covariance to MCM
MaCh3Fitter->AddSystObj(xsec.get());
for (size_t i = 0; i < SampleConfig.size(); ++i) {
MaCh3Fitter->AddSampleHandler(mySamples[i]);
}
// Run LLH scan
MaCh3Fitter->RunLLHScan();
for (size_t i = 0; i < SampleConfig.size(); ++i) {
delete mySamples[i];
}
return 0;
}