MaCh3  2.4.2
Reference Guide
Public Member Functions | Protected Member Functions | Protected Attributes | List of all members
MCMCBase Class Referenceabstract

Base class for MCMC fitting algorithms. More...

#include <Fitters/MCMCBase.h>

Inheritance diagram for MCMCBase:
[legend]
Collaboration diagram for MCMCBase:
[legend]

Public Member Functions

 MCMCBase (Manager *const fitMan)
 Constructor. More...
 
virtual ~MCMCBase ()=default
 Destructor. More...
 
void RunMCMC () override
 Actual implementation of MCMC fitting algorithm. More...
 
void StartFromPreviousFit (const std::string &FitName) override
 Allow to start from previous fit/chain. More...
 
void setChainLength (unsigned int L)
 Set how long chain should be. More...
 
- Public Member Functions inherited from FitterBase
 FitterBase (Manager *const fitMan)
 Constructor. More...
 
virtual ~FitterBase ()
 Destructor for the FitterBase class. More...
 
void AddSampleHandler (SampleHandlerBase *sample)
 This function adds a sample PDF object to the analysis framework. The sample PDF object will be utilized in fitting procedures or likelihood scans. More...
 
void AddSystObj (ParameterHandlerBase *cov)
 This function adds a Covariance object to the analysis framework. The Covariance object will be utilized in fitting procedures or likelihood scans. More...
 
void DragRace (const int NLaps=100)
 Calculates the required time for each sample or covariance object in a drag race simulation. Inspired by Dan's feature. More...
 
void RunLLHScan ()
 Perform a 1D likelihood scan. More...
 
void RunLLHMap ()
 Perform a general multi-dimensional likelihood scan. More...
 
void GetStepScaleBasedOnLLHScan ()
 LLH scan is good first estimate of step scale. More...
 
void Run2DLLHScan ()
 Perform a 2D likelihood scan. More...
 
void RunSigmaVar ()
 Perform a 1D/2D sigma var for all samples. More...
 
std::string GetName () const
 Get name of class. More...
 

Protected Member Functions

void DoMCMCStep ()
 The full StartStep->DoStep->EndStep chain. More...
 
virtual void ProposeStep ()=0
 Propose a step. More...
 
void PreStepProcess ()
 Actions before step proposal [start stopwatch]. More...
 
void PostStepProcess ()
 Actions after step proposal [end stopwatch, fill tree]. More...
 
virtual void DoStep ()=0
 The MCMC step proposal and acceptance. More...
 
virtual double AcceptanceProbability ()=0
 Step acceptance probability. More...
 
bool IsStepAccepted (const double acc_prob)
 Is step accepted? More...
 
void AcceptStep ()
 Accept a step. More...
 
void AdaptiveStep ()
 Adaptive MCMC step. More...
 
void PrintProgress (const bool StepsPrint=true)
 Print the progress. More...
 
- Protected Member Functions inherited from FitterBase
void ProcessMCMC ()
 Process MCMC output. More...
 
void PrepareOutput ()
 Prepare the output file. More...
 
void SaveOutput ()
 Save output and close files. More...
 
void SanitiseInputs ()
 Remove obsolete memory and make other checks before fit starts. More...
 
void SaveSettings ()
 Save the settings that the MCMC was run with. More...
 
bool GetScanRange (std::map< std::string, std::vector< double >> &scanRanges) const
 YSP: Set up a mapping to store parameters with user-specified ranges, suggested by D. Barrow. More...
 
void GetParameterScanRange (const ParameterHandlerBase *cov, const int i, double &CentralValue, double &lower, double &upper, const int n_points, const std::string &suffix="") const
 Helper function to get parameter scan range, central value. More...
 
bool CheckSkipParameter (const std::vector< std::string > &SkipVector, const std::string &ParamName) const
 KS: Check whether we want to skip parameter using skip vector. More...
 
void CustomRange (const std::string &ParName, const double sigma, double &ParamShiftValue) const
 For comparison with other fitting frameworks (like P-Theta) we usually have to apply different parameter values then usual 1, 3 sigma. More...
 

Protected Attributes

bool out_of_bounds
 Do we reject based on hitting boundaries in systs. More...
 
bool accept
 Accept. More...
 
unsigned int chainLength
 number of steps in chain More...
 
bool anneal
 simulated annealing More...
 
double AnnealTemp
 simulated annealing temperature More...
 
- Protected Attributes inherited from FitterBase
ManagerfitMan
 The manager for configuration handling. More...
 
unsigned int step
 current state More...
 
double logLCurr
 current likelihood More...
 
double logLProp
 proposed likelihood More...
 
double accProb
 current acceptance prob More...
 
int accCount
 counts accepted steps More...
 
unsigned int stepStart
 step start, by default 0 if we start from previous chain then it will be different More...
 
std::vector< double > sample_llh
 store the llh breakdowns More...
 
std::vector< double > syst_llh
 systematic llh breakdowns More...
 
std::vector< SampleHandlerBase * > samples
 Sample holder. More...
 
unsigned int TotalNSamples
 Total number of samples used, single SampleHandler can store more than one analysis sample! More...
 
std::vector< ParameterHandlerBase * > systematics
 Systematic holder. More...
 
std::unique_ptr< TStopwatch > clock
 tells global time how long fit took More...
 
std::unique_ptr< TStopwatch > stepClock
 tells how long single step/fit iteration took More...
 
double stepTime
 Time of single step. More...
 
std::unique_ptr< TRandom3 > random
 Random number. More...
 
TFile * outputFile
 Output. More...
 
TDirectory * CovFolder
 Output cov folder. More...
 
TDirectory * SampleFolder
 Output sample folder. More...
 
TTree * outTree
 Output tree with posteriors. More...
 
int auto_save
 auto save every N steps More...
 
bool fTestLikelihood
 Necessary for some fitting algorithms like PSO. More...
 
bool FileSaved
 Checks if file saved not repeat some operations. More...
 
bool SettingsSaved
 Checks if setting saved not repeat some operations. More...
 
bool OutputPrepared
 Checks if output prepared not repeat some operations. More...
 
std::string AlgorithmName
 Name of fitting algorithm that is being used. More...
 

Detailed Description

Base class for MCMC fitting algorithms.

Inherits from FitterBase and defines the interface for MCMC-based fitting, including chain management and step handling.

Author
Asher Kaboth

Definition at line 8 of file MCMCBase.h.

Constructor & Destructor Documentation

◆ MCMCBase()

MCMCBase::MCMCBase ( Manager *const  fitMan)

Constructor.

Parameters
fitManA pointer to a manager object, which will handle all settings.

Definition at line 6 of file MCMCBase.cpp.

6  : FitterBase(man) {
7 // *************************
8  // Beginning step number
9  stepStart = 0;
10 
11  // Starting parameters should be thrown
12  out_of_bounds = false;
13  chainLength = Get<unsigned>(fitMan->raw()["General"]["MCMC"]["NSteps"], __FILE__, __LINE__);
14  if (chainLength < 10){
15  MACH3LOG_ERROR("MCMC chain length must be at least 10 steps, otherwise this will result in a floating point exception.");
16  throw MaCh3Exception(__FILE__, __LINE__);
17  }
18 
19  AnnealTemp = GetFromManager<double>(fitMan->raw()["General"]["MCMC"]["AnnealTemp"], -999);
20  if (AnnealTemp < 0)
21  anneal = false;
22  else
23  {
24  MACH3LOG_INFO("Enabling simulated annealing with T = {}", AnnealTemp);
25  anneal = true;
26  }
27 }
#define MACH3LOG_ERROR
Definition: MaCh3Logger.h:37
#define MACH3LOG_INFO
Definition: MaCh3Logger.h:35
FitterBase(Manager *const fitMan)
Constructor.
Definition: FitterBase.cpp:16
Manager * fitMan
The manager for configuration handling.
Definition: FitterBase.h:108
unsigned int stepStart
step start, by default 0 if we start from previous chain then it will be different
Definition: FitterBase.h:121
bool anneal
simulated annealing
Definition: MCMCBase.h:69
unsigned int chainLength
number of steps in chain
Definition: MCMCBase.h:66
double AnnealTemp
simulated annealing temperature
Definition: MCMCBase.h:71
bool out_of_bounds
Do we reject based on hitting boundaries in systs.
Definition: MCMCBase.h:60
Custom exception class used throughout MaCh3.
YAML::Node const & raw() const
Return config.
Definition: Manager.h:41

◆ ~MCMCBase()

virtual MCMCBase::~MCMCBase ( )
virtualdefault

Destructor.

Member Function Documentation

◆ AcceptanceProbability()

virtual double MCMCBase::AcceptanceProbability ( )
protectedpure virtual

Step acceptance probability.

Implemented in MR2T2, and DelayedMR2T2.

◆ AcceptStep()

void MCMCBase::AcceptStep ( )
protected

Accept a step.

Definition at line 206 of file MCMCBase.cpp.

206  {
207 // *************************
208  ++accCount;
209  logLCurr = logLProp;
210 
211  // Loop over systematics and accept
212  for (size_t s = 0; s < systematics.size(); ++s)
213  {
214  systematics[s]->AcceptStep();
215  }
216 }
double logLProp
proposed likelihood
Definition: FitterBase.h:115
int accCount
counts accepted steps
Definition: FitterBase.h:119
double logLCurr
current likelihood
Definition: FitterBase.h:113
std::vector< ParameterHandlerBase * > systematics
Systematic holder.
Definition: FitterBase.h:134

◆ AdaptiveStep()

void MCMCBase::AdaptiveStep ( )
inlineprotected

Adaptive MCMC step.

Definition at line 176 of file MCMCBase.cpp.

176  {
177 // *************************
178  // Save the Adaptive output
179  for (const auto &syst : systematics)
180  {
181  if (syst->GetDoAdaption()){
182  syst->UpdateAdaptiveCovariance();
183  }
184  }
185 }

◆ DoMCMCStep()

void MCMCBase::DoMCMCStep ( )
inlineprotected

The full StartStep->DoStep->EndStep chain.

Starts step timer, prints progress

Step proposal, acceptance etc

Tree filling etc.

Definition at line 80 of file MCMCBase.cpp.

80  {
81 // *******************
85  DoStep();
88 }
void PreStepProcess()
Actions before step proposal [start stopwatch].
Definition: MCMCBase.cpp:91
virtual void DoStep()=0
The MCMC step proposal and acceptance.
void PostStepProcess()
Actions after step proposal [end stopwatch, fill tree].
Definition: MCMCBase.cpp:104

◆ DoStep()

virtual void MCMCBase::DoStep ( )
protectedpure virtual

The MCMC step proposal and acceptance.

Implemented in MR2T2, and DelayedMR2T2.

◆ IsStepAccepted()

bool MCMCBase::IsStepAccepted ( const double  acc_prob)
protected

Is step accepted?

Parameters
acc_probused for telling whether step is accepted or not

Definition at line 188 of file MCMCBase.cpp.

188  {
189 // *************************
190  // Get the random number
191  const double fRandom = random->Rndm();
192  // Do the accept/reject
193  #ifdef DEBUG
194  debugFile << " logLProp: " << logLProp << " logLCurr: " << logLCurr << " acc_prob: " << acc_prob << " fRandom: " << fRandom << std::endl;
195  #endif
196 
197  if (fRandom > acc_prob)
198  {
199  // Reject
200  return false;
201  }
202  return true;
203 }
std::unique_ptr< TRandom3 > random
Random number.
Definition: FitterBase.h:144

◆ PostStepProcess()

void MCMCBase::PostStepProcess ( )
inlineprotected

Actions after step proposal [end stopwatch, fill tree].

Definition at line 104 of file MCMCBase.cpp.

104  {
105 // *************************
106  //KS: Some version of ROOT keep spamming about accessing already deleted object which is wrong and not helpful...
107  int originalErrorLevel = gErrorIgnoreLevel;
108  gErrorIgnoreLevel = kFatal;
109 
110  stepClock->Stop();
111  stepTime = stepClock->RealTime();
112 
113  // Write step to output tree
114  outTree->Fill();
115 
116  // Do Adaptive MCMC
117  AdaptiveStep();
118 
119  if (step % auto_save == 0){
120  outTree->AutoSave();
121  }
122  gErrorIgnoreLevel = originalErrorLevel;
123 }
unsigned int step
current state
Definition: FitterBase.h:111
double stepTime
Time of single step.
Definition: FitterBase.h:141
std::unique_ptr< TStopwatch > stepClock
tells how long single step/fit iteration took
Definition: FitterBase.h:139
int auto_save
auto save every N steps
Definition: FitterBase.h:155
TTree * outTree
Output tree with posteriors.
Definition: FitterBase.h:153
void AdaptiveStep()
Adaptive MCMC step.
Definition: MCMCBase.cpp:176

◆ PreStepProcess()

void MCMCBase::PreStepProcess ( )
inlineprotected

Actions before step proposal [start stopwatch].

Definition at line 91 of file MCMCBase.cpp.

91  {
92 // *******************
93  stepClock->Start();
94  out_of_bounds = false;
95 
96  // Print 10 steps in total
97  if ((step - stepStart) % (chainLength / 10) == 0)
98  {
99  PrintProgress();
100  }
101 }
void PrintProgress(const bool StepsPrint=true)
Print the progress.
Definition: MCMCBase.cpp:127

◆ PrintProgress()

void MCMCBase::PrintProgress ( const bool  StepsPrint = true)
inlineprotected

Print the progress.

Definition at line 127 of file MCMCBase.cpp.

127  {
128 // *******************
129  if(StepsPrint) MACH3LOG_INFO("Step:\t{}/{}, current: {:.2f}, proposed: {:.2f}", step - stepStart, chainLength, logLCurr, logLProp);
130  if(StepsPrint) MACH3LOG_INFO("Accepted/Total steps: {}/{} = {:.2f}", accCount, step - stepStart, static_cast<double>(accCount) / static_cast<double>(step - stepStart));
131 
132  for (size_t i = 0; i < samples.size(); ++i) {
133  samples[i]->PrintRates();
134  }
135 
136  for (ParameterHandlerBase *cov : systematics) {
137  cov->PrintNominalCurrProp();
138  }
139 #ifdef DEBUG
140  if (debug)
141  {
142  debugFile << "\n-------------------------------------------------------" << std::endl;
143  debugFile << "Step:\t" << step + 1 << "/" << chainLength << " | current: " << logLCurr << " proposed: " << logLProp << std::endl;
144  }
145 #endif
146 }
std::vector< SampleHandlerBase * > samples
Sample holder.
Definition: FitterBase.h:129
Base class responsible for handling of systematic error parameters. Capable of using PCA or using ada...

◆ ProposeStep()

virtual void MCMCBase::ProposeStep ( )
protectedpure virtual

Propose a step.

Implemented in MR2T2.

◆ RunMCMC()

void MCMCBase::RunMCMC ( )
overridevirtual

Actual implementation of MCMC fitting algorithm.

Implements FitterBase.

Definition at line 32 of file MCMCBase.cpp.

32  {
33 // *******************
34  // Save the settings into the output file
35  SaveSettings();
36 
37  // Prepare the output branches
38  PrepareOutput();
39 
40  // Remove obsolete memory and make other checks before fit starts
42 
43  // Print Progress before Propose Step
44  PrintProgress(false);
45 
46  // Only propose step if we are running fresh chain. If we are running from previous chain then it's not needed and we can use usual pipeline
47  if(stepStart == 0) {
48  // Reconfigure the samples, systematics and oscillation for first weight
49  // ProposeStep sets logLProp
50  ProposeStep();
51  // Set the current logL to the proposed logL for the 0th step
52  // Accept the first step to set logLCurr: this shouldn't affect the MCMC because we ignore the first N steps in burn-in
54  }
55 
56  // Begin MCMC
57  const auto StepEnd = stepStart + chainLength;
58  for (step = stepStart; step < StepEnd; ++step)
59  {
60  DoMCMCStep();
61  }
62  // Save all the MCMC output
63  SaveOutput();
64 
65  // Process MCMC
66  ProcessMCMC();
67 
68  // Save the adaptive MCMC
69  for (const auto &syst : systematics)
70  {
71  if (syst->GetDoAdaption())
72  {
73  auto adaptive_handler = syst->GetAdaptiveHandler();
74  adaptive_handler->SaveAdaptiveToFile(adaptive_handler->GetOutFileName(), syst->GetName(), true);
75  }
76  }
77 }
void ProcessMCMC()
Process MCMC output.
Definition: FitterBase.cpp:414
void SaveOutput()
Save output and close files.
Definition: FitterBase.cpp:231
void SaveSettings()
Save the settings that the MCMC was run with.
Definition: FitterBase.cpp:79
void PrepareOutput()
Prepare the output file.
Definition: FitterBase.cpp:153
void SanitiseInputs()
Remove obsolete memory and make other checks before fit starts.
Definition: FitterBase.cpp:223
void DoMCMCStep()
The full StartStep->DoStep->EndStep chain.
Definition: MCMCBase.cpp:80
virtual void ProposeStep()=0
Propose a step.

◆ setChainLength()

void MCMCBase::setChainLength ( unsigned int  L)
inline

Set how long chain should be.

Parameters
Lnew chain length

Definition at line 26 of file MCMCBase.h.

26 { chainLength = L; };

◆ StartFromPreviousFit()

void MCMCBase::StartFromPreviousFit ( const std::string &  FitName)
overridevirtual

Allow to start from previous fit/chain.

Parameters
FitNameName of previous chain

Reimplemented from FitterBase.

Definition at line 149 of file MCMCBase.cpp.

149  {
150 // *******************
151  // Use base class
153 
154  // For MCMC we also need to set stepStart
155  TFile *infile = M3::Open(FitName, "READ", __FILE__, __LINE__);
156  TTree *posts = infile->Get<TTree>("posteriors");
157  unsigned int step_val = 0;
158 
159  posts->SetBranchAddress("step", &step_val);
160  posts->GetEntry(posts->GetEntries() - 1);
161 
162  stepStart = step_val;
163  // KS: Also update number of steps if using adaption
164  for (unsigned int i = 0; i < systematics.size(); ++i)
165  {
166  if (systematics[i]->GetDoAdaption())
167  {
168  systematics[i]->SetNumberOfSteps(step_val);
169  }
170  }
171  infile->Close();
172  delete infile;
173 }
virtual void StartFromPreviousFit(const std::string &FitName)
Allow to start from previous fit/chain.
Definition: FitterBase.cpp:348
TFile * Open(const std::string &Name, const std::string &Type, const std::string &File, const int Line)
Opens a ROOT file with the given name and mode.

Member Data Documentation

◆ accept

bool MCMCBase::accept
protected

Accept.

Definition at line 63 of file MCMCBase.h.

◆ anneal

bool MCMCBase::anneal
protected

simulated annealing

Definition at line 69 of file MCMCBase.h.

◆ AnnealTemp

double MCMCBase::AnnealTemp
protected

simulated annealing temperature

Definition at line 71 of file MCMCBase.h.

◆ chainLength

unsigned int MCMCBase::chainLength
protected

number of steps in chain

Definition at line 66 of file MCMCBase.h.

◆ out_of_bounds

bool MCMCBase::out_of_bounds
protected

Do we reject based on hitting boundaries in systs.

Definition at line 60 of file MCMCBase.h.


The documentation for this class was generated from the following files: