-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMCMCTutorial.cpp
executable file
·32 lines (27 loc) · 1.11 KB
/
MCMCTutorial.cpp
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
31
32
// MaCh3 spline includes
#include "mcmc/MaCh3Factory.h"
#include "samplePDF/samplePDFTutorial.h"
int main(int argc, char *argv[]) {
// Initialise manger responsible for config handling
auto FitManager = MaCh3ManagerFactory(argc, argv);
// Initialise covariance class reasonable for Systematics
auto xsec = MaCh3CovarianceFactory<covarianceXsec>(FitManager.get(), "Xsec");
auto osc = MaCh3CovarianceFactory<covarianceOsc>(FitManager.get(), "Osc");
// Initialise samplePDF
auto SampleConfig = FitManager->raw()["General"]["TutorialSamples"].as<std::vector<std::string>>();
auto mySamples = MaCh3SamplePDFFactory<samplePDFTutorial>(SampleConfig, xsec.get(), osc.get());
// Create MCMC Class
std::unique_ptr<FitterBase> MaCh3Fitter = MaCh3FitterFactory(FitManager.get());
// Add covariance to MCM
MaCh3Fitter->addSystObj(xsec.get());
MaCh3Fitter->addSystObj(osc.get());
for (size_t i = 0; i < SampleConfig.size(); ++i) {
MaCh3Fitter->addSamplePDF(mySamples[i]);
}
// Run MCMCM
MaCh3Fitter->runMCMC();
for (size_t i = 0; i < SampleConfig.size(); ++i) {
delete mySamples[i];
}
return 0;
}