Page MenuHomeHEPForge

No OneTemporary

diff --git a/inc/LauAbsFitModel.hh b/inc/LauAbsFitModel.hh
index 3430147..d605208 100644
--- a/inc/LauAbsFitModel.hh
+++ b/inc/LauAbsFitModel.hh
@@ -1,909 +1,893 @@
// Copyright University of Warwick 2004 - 2014.
// Distributed under the Boost Software License, Version 1.0.
// (See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
// Authors:
// Thomas Latham
// John Back
// Paul Harrison
/*! \file LauAbsFitModel.hh
\brief File containing declaration of LauAbsFitModel class.
*/
/*! \class LauAbsFitModel
\brief Abstract interface to the fitting and toy MC model
Abstract interface to the fitting and toy MC model
Any class inheriting from this must implement the following functions:
- cacheInputFitVars()
- checkInitFitParams()
- finaliseFitResults()
- fixdSpeciesNames()
- freeSpeciesNames()
- genExpt()
- getEventSum()
- getTotEvtLikelihood()
- initialise()
- initialiseDPModels()
- propagateParUpdates()
- recalculateNormalisation()
- scfDPSmear()
- setAmpCoeffSet()
- setNBkgndEvents()
- setNSigEvents()
- setupBkgndVectors()
- setupGenNtupleBranches()
- setupSPlotNtupleBranches()
- splitSignal()
- storePerEvtLlhds()
- twodimPDFs()
- updateCoeffs()
- variableNames()
- weightEvents()
- writeOutTable()
*/
#ifndef LAU_ABS_FIT_MODEL
#define LAU_ABS_FIT_MODEL
#include "TMatrixD.h"
#include "TString.h"
#include "TStopwatch.h"
#include "TVectorDfwd.h"
#include <iosfwd>
#include <set>
#include <vector>
#include "LauFitObject.hh"
#include "LauFormulaPar.hh"
#include "LauSimFitSlave.hh"
// LauSPlot included to get LauSPlot::NameSet typedef
#include "LauSPlot.hh"
class TMessage;
class TMonitor;
class TSocket;
class TTree;
class LauAbsCoeffSet;
class LauAbsPdf;
class LauComplex;
class LauFitDataTree;
class LauFitNtuple;
class LauGenNtuple;
class LauAbsRValue;
class LauParameter;
class LauAbsFitModel : public LauFitObject, public LauSimFitSlave {
public:
//! Constructor
LauAbsFitModel();
//! Destructor
virtual ~LauAbsFitModel();
//! Is the Dalitz plot term in the likelihood
Bool_t useDP() const { return usingDP_; }
//! Switch on/off the Dalitz plot term in the Likelihood (allows fits to other quantities, e.g. B mass)
/*!
\param [in] usingDP the boolean flag
*/
void useDP(Bool_t usingDP) { usingDP_ = usingDP; }
//! Return the flag to store the status of using an sFit or not
Bool_t doSFit() const { return doSFit_; }
//! Do an sFit (use sWeights to isolate signal decays rather than using background histograms)
/*!
\param [in] sWeightBranchName name of the branch of the tree containing the sWeights
\param [in] scaleFactor scaling factor to get the uncertainties correct
*/
void doSFit( const TString& sWeightBranchName, Double_t scaleFactor = 1.0 );
//! Determine whether an extended maximum likelihood fit it being performed
Bool_t doEMLFit() const {return emlFit_;}
//! Choice to perform an extended maximum likelihood fit
/*!
\param [in] emlFit boolean specifying whether or not to perform the EML
*/
void doEMLFit(Bool_t emlFit) {emlFit_ = emlFit;}
//! Determine whether the two-stage fit is enabled
virtual Bool_t twoStageFit() const {return twoStageFit_;}
//! Turn on or off the two stage fit
/*!
The two-stage fit allows certain parameters to be fixed
in one stage and floated in another stage of the fit.
Can be used, for example, in a CP fit where the
CP-parameters are fixed to zero in the first stage
(while the CP-average parameters are determined), then
floated in the second.
\param [in] doTwoStageFit boolean specifying whether or not the two-stage fit should be enabled
*/
virtual void twoStageFit(Bool_t doTwoStageFit) {twoStageFit_ = doTwoStageFit;}
//! Determine whether calculation of asymmetric errors is enabled
Bool_t useAsymmFitErrors() const {return useAsymmFitErrors_;}
//! Turn on or off the computation of asymmetric errors (e.g. MINOS routine in Minuit)
/*!
\param [in] useAsymmErrors boolean specifying whether or not the computation of asymmetric errors is enabled
*/
void useAsymmFitErrors(Bool_t useAsymmErrors) {useAsymmFitErrors_ = useAsymmErrors;}
//! Determine whether Poisson smearing is enabled for the toy MC generation
Bool_t doPoissonSmearing() const {return poissonSmear_;}
//! Turn Poisson smearing (for the toy MC generation) on or off
/*!
\param [in] poissonSmear boolean specifying whether or not to do Poisson smearing
*/
void doPoissonSmearing(Bool_t poissonSmear) {poissonSmear_ = poissonSmear;}
//! Determine whether embedding of events is enabled in the generation
Bool_t enableEmbedding() const {return enableEmbedding_;}
//! Turn on or off embedding of events in the generation
/*!
\param [in] enable boolean specifying whether to embed events
*/
void enableEmbedding(Bool_t enable) {enableEmbedding_ = enable;}
//! Mark that the fit is calculating asymmetric errors
/*!
This is called by the fitter interface to mark when
entering and exiting the asymmetric error calculation
\param [in] inAsymErrCalc boolean marking that the fit is calculating the asymmetric errors
*/
virtual void withinAsymErrorCalc(Bool_t inAsymErrCalc) {withinAsymErrorCalc_ = inAsymErrCalc;}
//! Determine whether writing out of the latex table is enabled
Bool_t writeLatexTable() const {return writeLatexTable_;}
//! Turn on or off the writing out of the latex table
/*!
\param [in] writeTable boolean specifying whether or not the latex table should be written out
*/
void writeLatexTable(Bool_t writeTable) {writeLatexTable_ = writeTable;}
//! save files containing graphs of the resonance's PDFs
Bool_t saveFilePDF() const {return savePDF_;}
//! Turn on or off the save of files containing graphs of the resonance's PDFs
/*!
\param [in] savePDF boolean specifying whether or not the save of files containing graphs of the resonance's PDFs
*/
void saveFilePDF(Bool_t savePDF) {savePDF_ = savePDF;}
//! Set up the sPlot ntuple
/*!
\param [in] fileName the sPlot file name
\param [in] treeName the sPlot tree name
\param [in] storeDPEfficiency whether or not to store the efficiency information too
\param [in] verbosity define the level of output
*/
void writeSPlotData(const TString& fileName, const TString& treeName, Bool_t storeDPEfficiency, const TString& verbosity = "q");
//! Determine whether the sPlot data is to be written out
Bool_t writeSPlotData() const {return writeSPlotData_;}
//! Determine whether the efficiency information should be stored in the sPlot ntuple
Bool_t storeDPEff() const {return storeDPEff_;}
//! Determine whether the initial values of the fit parameters, in particular the isobar coefficient parameters, are to be randomised
Bool_t useRandomInitFitPars() const {return randomFit_;}
//! Randomise the initial values of the fit parameters, in particular the isobar coefficient parameters
void useRandomInitFitPars(Bool_t boolean) {randomFit_ = boolean;}
//! Set the number of experiments and the first experiment
/*!
\param [in] nExperiments the number of experiments
\param [in] firstExperiment the number of the first experiment
*/
void setNExpts(UInt_t nExperiments, UInt_t firstExperiment = 0) {
nExpt_ = nExperiments;
firstExpt_ = firstExperiment;
}
//! Obtain the total number of events in the current experiment
UInt_t eventsPerExpt() const {return evtsPerExpt_;}
//! Obtain the number of experiments
UInt_t nExpt() const {return nExpt_;}
//! Obtain the number of the first experiment
UInt_t firstExpt() const {return firstExpt_;}
//! Obtain the number of the current experiment
UInt_t iExpt() const {return iExpt_;}
//! Setup the background class names
/*!
\param [in] names a vector of all the background names
*/
virtual void setBkgndClassNames( const std::vector<TString>& names );
//! Returns the number of background classes
inline UInt_t nBkgndClasses() const {return bkgndClassNames_.size();}
//! Set the number of signal events
/*!
\param [in] nSigEvents contains the signal yield and option to fix it
*/
virtual void setNSigEvents(LauParameter* nSigEvents) = 0;
//! Set the number of background events
/*!
The name of the parameter must be that of the corresponding background category (so that it can be correctly assigned)
\param [in] nBkgndEvents contains the name, yield and option to fix the yield of the background
*/
virtual void setNBkgndEvents(LauParameter* nBkgndEvents) = 0;
//! Set the DP amplitude coefficients
/*!
\param [in] coeffSet the set of coefficients
*/
virtual void setAmpCoeffSet(LauAbsCoeffSet* coeffSet) = 0;
//! Specify that a toy MC sample should be created for a successful fit to an experiment
/*!
Generation uses the fitted parameters so that the user can compare the fit to the data
\param [in] toyMCScale the scale factor to get the number of events to generate
\param [in] mcFileName the file name where the toy sample will be stored
\param [in] tableFileName name of the output tex file
\param [in] poissonSmearing turn smearing on or off
*/
void compareFitData(UInt_t toyMCScale = 10, const TString& mcFileName = "fitToyMC.root",
const TString& tableFileName = "fitToyMCTable.tex", Bool_t poissonSmearing = kTRUE);
//! Reweighting - allows e.g. MC events to be weighted by the DP model
/*!
\param [in] dataFileName the name of the data file
\param [in] dataTreeName the name of the tree containing the data
*/
virtual void weightEvents( const TString& dataFileName, const TString& dataTreeName ) = 0;
//! Start the toy generation / fitting
/*!
\param [in] applicationCode specifies what to do, perform a fit ("fit") or generate toy MC ("gen")
\param [in] dataFileName the name of the input data file
\param [in] dataTreeName the name of the tree containing the data
\param [in] histFileName the file name for the output histograms
\param [in] tableFileName the file name for the latex output file
*/
void run(const TString& applicationCode, const TString& dataFileName, const TString& dataTreeName,
const TString& histFileName, const TString& tableFileName = "");
//! Start the slave process for simultaneous fitting
/*!
\param [in] dataFileName the name of the input data file
\param [in] dataTreeName the name of the tree containing the data
\param [in] histFileName the file name for the output histograms
\param [in] tableFileName the file name for the latex output file
\param [in] addressMaster the hostname of the machine running the master process
\param [in] portMaster the port number on which the master process is listening
*/
void runSlave(const TString& dataFileName, const TString& dataTreeName,
const TString& histFileName, const TString& tableFileName = "",
const TString& addressMaster = "localhost", const UInt_t portMaster = 9090);
//! This function sets the parameter values from Minuit
/*!
This function has to be public since it is called from the global FCN.
It should not be called otherwise!
\param [in] par an array storing the various parameter values
\param [in] npar the number of free parameters
*/
virtual void setParsFromMinuit(Double_t* par, Int_t npar);
//! Calculates the total negative log-likelihood
/*!
This function has to be public since it is called from the global FCN.
It should not be called otherwise!
*/
virtual Double_t getTotNegLogLikelihood();
//! Store constraint information for fit parameters
/*!
\param [in] formula the formula to be used in the LauFormulaPar
\param [in] pars a vector of LauParameter names to be used in the Formula, in the order specified by the formula
\param [in] mean the value of the mean of the Gaussian constraint
\param [in] width the value of the width of the Gaussian constraint
*/
virtual void addConstraint(const TString& formula, const std::vector<TString>& pars, const Double_t mean, const Double_t width);
protected:
// Some typedefs
//! List of Pdfs
typedef std::vector<LauAbsPdf*> LauPdfList;
//! List of parameter pointers
typedef std::vector<LauParameter*> LauParameterPList;
//! List of parameter pointers
typedef std::vector<LauAbsRValue*> LauAbsRValuePList;
//! Set of parameter pointers
typedef std::set<LauParameter*> LauParameterPSet;
//! List of parameters
typedef std::vector<LauParameter> LauParameterList;
//! A type to store background classes
typedef std::map<UInt_t,TString> LauBkgndClassMap;
//! Clear the vectors containing fit parameters
void clearFitParVectors();
//! Clear the vectors containing extra ntuple variables
void clearExtraVarVectors();
//! Generate toy MC
/*!
\param [in] dataFileName the name of the file where the generated events are stored
\param [in] dataTreeName the name of the tree used to store the variables
\param [in] histFileName the name of the histogram output file (currently not used)
\param [in] tableFileNameBase the name the latex output file
*/
virtual void generate(const TString& dataFileName, const TString& dataTreeName, const TString& histFileName, const TString& tableFileNameBase);
//! The method that actually generates the toy MC events for the given experiment
/*!
\return the success/failure flag of the generation procedure
*/
virtual Bool_t genExpt() = 0;
//! Perform the total fit
/*!
\param [in] dataFileName the name of the data file
\param [in] dataTreeName the name of the tree containing the data
\param [in] histFileName the name of the histogram output file
\param [in] tableFileNameBase the name the of latex output file
*/
void fit(const TString& dataFileName, const TString& dataTreeName, const TString& histFileName, const TString& tableFileNameBase);
//! Slaves required when performing a simultaneous fit
/*!
\param [in] dataFileName the name of the data file
\param [in] dataTreeName the name of the tree containing the data
\param [in] histFileName the name of the histogram output file
\param [in] tableFileNameBase the name the of latex output file
*/
void fitSlave(const TString& dataFileName, const TString& dataTreeName, const TString& histFileName, const TString& tableFileNameBase);
//! Routine to perform the actual fit for a given experiment
void fitExpt();
//! Routine to perform the minimisation
/*!
\return the success/failure flag of the fit
*/
Bool_t runMinimisation();
//! Create a toy MC sample from the fitted parameters
/*!
\param [in] mcFileName the file name where the toy sample will be stored
\param [in] tableFileName name of the output tex file
*/
void createFitToyMC(const TString& mcFileName, const TString& tableFileName);
//! Read in the data for the specified experiment
/*!
\param [in] exptIndex the experiment number to be read
\return the number of events read in
*/
virtual UInt_t readExperimentData( const UInt_t exptIndex );
//! Store variables from the input file into the internal data storage
/*!
\param [in] dataFileName the name of the input file
\param [in] dataTreeName the name of the input tree
*/
Bool_t cacheFitData(const TString& dataFileName, const TString& dataTreeName);
//! Cache the input data values to calculate the likelihood during the fit
virtual void cacheInputFitVars() = 0;
//! Cache the value of the sWeights to be used in the sFit
virtual void cacheInputSWeights();
//! Initialise the fit par vectors
/*!
Each class that inherits from this one must implement
this sensibly for all vectors specified in
clearFitParVectors, i.e. specify parameter names,
initial, min, max and fixed values
*/
virtual void initialise() = 0;
//! Recalculate normalisation the signal DP model(s)
virtual void recalculateNormalisation() = 0;
//! Initialise the DP models
virtual void initialiseDPModels() = 0;
/*!
For each amp in the fit this function takes its
particular parameters and from them calculates the
single complex number that is its coefficient.
The vector of these coeffs can then be passed to the
signal dynamics.
*/
virtual void updateCoeffs() = 0;
//! This function (specific to each model) calculates anything that depends on the fit parameter values
virtual void propagateParUpdates() = 0;
//! Calculate the sum of the log-likelihood over the specified events
/*!
\param [in] iStart the event number of the first event to be considered
\param [in] iEnd the event number of the final event to be considered
*/
Double_t getLogLikelihood( UInt_t iStart, UInt_t iEnd );
//! Calculate the penalty terms to the log likelihood from Gaussian constraints
Double_t getLogLikelihoodPenalty();
//! Calculates the likelihood for a given event
/*!
\param [in] iEvt the event number
*/
virtual Double_t getTotEvtLikelihood(UInt_t iEvt) = 0;
//! Returns the sum of the expected events over all hypotheses; used in the EML fit scenario
virtual Double_t getEventSum() const = 0;
//! Prints the values of all the fit variables for the specified event - useful for diagnostics
/*!
\param [in] iEvt the event number
*/
virtual void printEventInfo(UInt_t iEvt) const;
//! Same as printEventInfo, but printing out the values of the variables in the fit
virtual void printVarsInfo() const;
//! Update initial fit parameters if required
virtual void checkInitFitParams() = 0;
//! Package the initial fit parameters for transmission to the master
/*!
\param [out] array the array to be filled with the LauParameter objects
*/
virtual void prepareInitialParArray( TObjArray& array );
//! Perform all finalisation actions
/*!
- Receive the results of the fit from the master
- Perform any finalisation routines
- Package the finalised fit parameters for transmission back to the master
\param [in] fitStat the convergence/error matrix status of the fit
\param [in] NLL the minimised negative log likelihood
\param [in] parsFromMaster the parameters at the fit minimum
\param [in] covMat the fit covariance matrix
\param [out] parsToMaster the array to be filled with the finalised LauParameter objects
*/
virtual void finaliseResults( const Int_t fitStat, const Double_t NLL, const TObjArray* parsFromMaster, const TMatrixD* covMat, TObjArray& parsToMaster );
//! Write the results of the fit into the ntuple
/*!
\param [in] tableFileName the structure containing the results of the fit
*/
virtual void finaliseFitResults(const TString& tableFileName) = 0;
//! Save the pdf Plots for all the resonances of experiment number fitExp
/*!
\param [in] label prefix for the file name to be saved
*/
virtual void savePDFPlots(const TString& label) = 0;
//! Save the pdf Plots for the sum of ressonances correspondint to "sin" of experiment number fitExp
/*!
\param [in] label prefix for the file name to be saved
\param [in] spin spin of the wave to be saved
*/
virtual void savePDFPlotsWave(const TString& label, const Int_t& spin) = 0;
//! Write the latex table
/*!
\param [in] outputFile the name of the output file
*/
virtual void writeOutTable(const TString& outputFile) = 0;
//! Store the per-event likelihood values
virtual void storePerEvtLlhds() = 0;
//! Write out any fit results
virtual void writeOutAllFitResults();
//! Calculate the sPlot data
virtual void calculateSPlotData();
//! Make sure all parameters hold their genValue as the current value
void setGenValues();
//! Method to set up the storage for background-related quantities called by setBkgndClassNames
virtual void setupBkgndVectors() = 0;
//! Check if the given background class is in the list
/*!
\param [in] className the name of the class to check
\return true or false
*/
Bool_t validBkgndClass( const TString& className ) const;
//! The number assigned to a background class
/*!
\param [in] className the name of the class to check
\return the background class ID number
*/
UInt_t bkgndClassID( const TString& className ) const;
//! Get the name of a background class from the number
/*!
\param [in] classID the ID number of the background class
\return the class name
*/
const TString& bkgndClassName( UInt_t classID ) const;
//! Set the number of events in the current experiment
void eventsPerExpt(UInt_t nEvents) {evtsPerExpt_ = nEvents;}
//! Setup the generation ntuple branches
virtual void setupGenNtupleBranches() = 0;
//! Add a branch to the gen tree for storing an integer
/*!
\param [in] name the name of the branch
*/
virtual void addGenNtupleIntegerBranch(const TString& name);
//! Add a branch to the gen tree for storing a double
/*!
\param [in] name the name of the branch
*/
virtual void addGenNtupleDoubleBranch(const TString& name);
//! Set the value of an integer branch in the gen tree
/*!
\param [in] name the name of the branch
\param [in] value the value to be stored
*/
virtual void setGenNtupleIntegerBranchValue(const TString& name, Int_t value);
//! Set the value of a double branch in the gen tree
/*!
\param [in] name the name of the branch
\param [in] value the value to be stored
*/
virtual void setGenNtupleDoubleBranchValue(const TString& name, Double_t value);
//! Get the value of an integer branch in the gen tree
/*!
\param [in] name the name of the branch
\return the value of the parameter
*/
virtual Int_t getGenNtupleIntegerBranchValue(const TString& name) const;
//! Get the value of a double branch in the gen tree
/*!
\param [in] name the name of the branch
\return the value of the parameter
*/
virtual Double_t getGenNtupleDoubleBranchValue(const TString& name) const;
//! Fill the gen tuple branches
virtual void fillGenNtupleBranches();
//! Setup the branches of the sPlot tuple
virtual void setupSPlotNtupleBranches() = 0;
//! Add a branch to the sPlot tree for storing an integer
/*!
\param [in] name the name of the branch
*/
virtual void addSPlotNtupleIntegerBranch(const TString& name);
//! Add a branch to the sPlot tree for storing a double
/*!
\param [in] name the name of the branch
*/
virtual void addSPlotNtupleDoubleBranch(const TString& name);
//! Set the value of an integer branch in the sPlot tree
/*!
\param [in] name the name of the branch
\param [in] value the value to be stored
*/
virtual void setSPlotNtupleIntegerBranchValue(const TString& name, Int_t value);
//! Set the value of a double branch in the sPlot tree
/*!
\param [in] name the name of the branch
\param [in] value the value to be stored
*/
virtual void setSPlotNtupleDoubleBranchValue(const TString& name, Double_t value);
//! Fill the sPlot tuple
virtual void fillSPlotNtupleBranches();
//! Returns the names of all variables in the fit
virtual LauSPlot::NameSet variableNames() const = 0;
//! Returns the names and yields of species that are free in the fit
virtual LauSPlot::NumbMap freeSpeciesNames() const = 0;
//! Returns the names and yields of species that are fixed in the fit
virtual LauSPlot::NumbMap fixdSpeciesNames() const = 0;
//! Returns the species and variables for all 2D PDFs in the fit
virtual LauSPlot::TwoDMap twodimPDFs() const = 0;
//! Check if the signal is split into well-reconstructed and mis-reconstructed types
virtual Bool_t splitSignal() const = 0;
//! Check if the mis-reconstructed signal is to be smeared in the DP
virtual Bool_t scfDPSmear() const = 0;
//! Add parameters of the PDFs in the list to the list of all fit parameters
/*!
\param [in] pdfList a list of Pdfs
\return the number of parameters added
*/
UInt_t addFitParameters(LauPdfList& pdfList);
//! Add parameters to the list of Gaussian constrained parameters
void addConParameters();
//! Print the fit parameters for all PDFs in the list
/*!
\param [in] pdfList a list of Pdfs
\param [in] fout the output stream to write to
*/
void printFitParameters(const LauPdfList& pdfList, std::ostream& fout) const;
//! Update the fit parameters for all PDFs in the list
/*!
\param [in] pdfList a list of Pdfs
*/
void updateFitParameters(LauPdfList& pdfList);
//! Have all PDFs in the list cache the data
/*!
\param [in] pdfList the list of pdfs
\param [in] theData the data from the fit
*/
void cacheInfo(LauPdfList& pdfList, const LauFitDataTree& theData);
//! Calculate the product of the per-event likelihoods of the PDFs in the list
/*!
\param [in] pdfList the list of pdfs
\param [in] iEvt the event number
*/
Double_t prodPdfValue(LauPdfList& pdfList, UInt_t iEvt);
//! Do any of the PDFs have a dependence on the DP?
/*!
\return the flag to indicated if there is a DP dependence
*/
Bool_t pdfsDependOnDP() const {return pdfsDependOnDP_;}
//! Do any of the PDFs have a dependence on the DP?
/*!
\param [in] dependOnDP the flag to indicated if there is a DP dependence
*/
void pdfsDependOnDP(Bool_t dependOnDP) { pdfsDependOnDP_ = dependOnDP; }
//! Access the fit variables
const LauParameterPList& fitPars() const {return fitVars_;}
LauParameterPList& fitPars() {return fitVars_;}
//! Access the fit variables which affect the DP normalisation
const LauParameterPSet& resPars() const {return resVars_;}
LauParameterPSet& resPars() {return resVars_;}
//! Access the extra variables
const LauParameterList& extraPars() const {return extraVars_;}
LauParameterList& extraPars() {return extraVars_;}
//! Access the Gaussian constrained variables
const LauAbsRValuePList& conPars() const {return conVars_;}
LauAbsRValuePList& conPars() {return conVars_;}
//! Access the fit ntuple
const LauFitNtuple* fitNtuple() const {return fitNtuple_;}
LauFitNtuple* fitNtuple() {return fitNtuple_;}
//! Access the gen ntuple
const LauGenNtuple* genNtuple() const {return genNtuple_;}
LauGenNtuple* genNtuple() {return genNtuple_;}
//! Access the sPlot ntuple
const LauGenNtuple* sPlotNtuple() const {return sPlotNtuple_;}
LauGenNtuple* sPlotNtuple() {return sPlotNtuple_;}
//! Access the data store
const LauFitDataTree* fitData() const {return inputFitData_;}
LauFitDataTree* fitData() {return inputFitData_;}
//! Access the current NLL value
Double_t nll() const {return NLL_;}
//! Access the fit status information
Int_t fitStatus() const {return fitStatus_;}
//! Access the fit covariance matrix
const TMatrixD& covarianceMatrix() const {return covMatrix_;}
private:
//! Copy constructor (not implemented)
LauAbsFitModel(const LauAbsFitModel& rhs);
//! Copy assignment operator (not implemented)
LauAbsFitModel& operator=(const LauAbsFitModel& rhs);
- // Setup a struct to store information on constrained fit parameters
- /*!
- \struct StoreConstraints
- \brief Struct to store constraint information until the fit is run
- */
- struct StoreConstraints {
- //! The formula to be used in the LauFormulaPar
- TString formula_;
- //! The list of LauParameter names to be used in the LauFormulaPar
- std::vector<TString> conPars_;
- //! The mean value of the Gaussian constraint to be applied
- Double_t mean_;
- //! The width of the Gaussian constraint to be applied
- Double_t width_;
- };
-
//! Store the constraints for fit parameters until initialisation is complete
std::vector<StoreConstraints> storeCon_;
// Various control booleans
//! Option to perform a two stage fit
Bool_t twoStageFit_;
//! Option to use asymmetric errors
Bool_t useAsymmFitErrors_;
//! Option to make toy from 1st successful experiment
Bool_t compareFitData_;
//! Option to output a .C file of PDF's
Bool_t savePDF_;
//! Option to output a Latex format table
Bool_t writeLatexTable_;
//! Option to write sPlot data
Bool_t writeSPlotData_;
//! Option to store DP efficiencies in the sPlot ntuple
Bool_t storeDPEff_;
//! Option to randomise the initial values of the fit parameters
Bool_t randomFit_;
//! Option to perform an extended ML fit
Bool_t emlFit_;
//! Option to perform Poisson smearing
Bool_t poissonSmear_;
//! Option to enable embedding
Bool_t enableEmbedding_;
//! Option to include the DP as part of the fit
Bool_t usingDP_;
//! Option to state if pdfs depend on DP position
Bool_t pdfsDependOnDP_;
// Info on number of experiments and number of events
//! The number of the first experiment to consider
UInt_t firstExpt_;
//! The number of experiments to consider
UInt_t nExpt_;
//! The number of events per experiment
UInt_t evtsPerExpt_;
//! The number of the current experiment
UInt_t iExpt_;
//! Internal vector of fit parameters
LauParameterPList fitVars_;
//! Internal set of fit parameters upon which the DP normalisation depends
LauParameterPSet resVars_;
//! Extra variables that aren't in the fit but are stored in the ntuple
LauParameterList extraVars_;
//! Internal vectors of Gaussian parameters
LauAbsRValuePList conVars_;
// Input data and output ntuple
//! The input data
LauFitDataTree* inputFitData_;
//! The fit ntuple
LauFitNtuple* fitNtuple_;
//! The generated ntuple
LauGenNtuple* genNtuple_;
//! The sPlot ntuple
LauGenNtuple* sPlotNtuple_;
// Fit bookeeping variables
//! The status of the fit
Int_t fitStatus_;
//! The negative log-likelihood
Double_t NLL_;
//! The fit covariance matrix
TMatrixD covMatrix_;
//! The number of good fits
UInt_t numberOKFits_;
//! The number of bad fits
UInt_t numberBadFits_;
//! The number of fit parameters
UInt_t nParams_;
//! The number of free fit parameters
UInt_t nFreeParams_;
//! The worst LL value found so far
Double_t worstLogLike_;
//! Flag to indicate if the asymmetric error calculation (e.g. MINOS) is currently running
Bool_t withinAsymErrorCalc_;
// Background class names
//! The background class names
LauBkgndClassMap bkgndClassNames_;
//! An empty string
const TString nullString_;
// sFit related variables
//! Option to perfom the sFit
Bool_t doSFit_;
//! The name of the sWeight branch
TString sWeightBranchName_;
//! The vector of sWeights
std::vector<Double_t> sWeights_;
//! The sWeight scaling factor
Double_t sWeightScaleFactor_;
// Fit timers
//! The fit timer
TStopwatch timer_;
//! The total fit timer
TStopwatch cumulTimer_;
//! The output table name
TString outputTableName_;
// Comparison toy MC related variables
//! The output file name for Toy MC
TString fitToyMCFileName_;
//! The output table name for Toy MC
TString fitToyMCTableName_;
//! The scaling factor (toy vs data statistics)
UInt_t fitToyMCScale_;
//! Option to perform Poisson smearing
Bool_t fitToyMCPoissonSmear_;
// sPlot related variables
//! The name of the sPlot file
TString sPlotFileName_;
//! The name of the sPlot tree
TString sPlotTreeName_;
//! Control the verbosity of the sFit
TString sPlotVerbosity_;
ClassDef(LauAbsFitModel,0) // Abstract interface to fit/toyMC model
};
#endif
diff --git a/inc/LauFitObject.hh b/inc/LauFitObject.hh
index 0671a08..038e643 100644
--- a/inc/LauFitObject.hh
+++ b/inc/LauFitObject.hh
@@ -1,82 +1,98 @@
// Copyright University of Warwick 2013 - 2013.
// Distributed under the Boost Software License, Version 1.0.
// (See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
// Authors:
// Thomas Latham
// John Back
// Paul Harrison
/*! \file LauFitObject.hh
\brief File containing declaration of LauFitObject class.
*/
/*! \class LauFitObject
\brief The abstract interface for the objects that control the calculation of the likelihood.
*/
#ifndef LAU_FIT_OBJECT
#define LAU_FIT_OBJECT
#include "TObject.h"
#include "TVirtualFitter.h"
class LauFitObject : public TObject {
public:
//! Destructor
virtual ~LauFitObject() {}
//! Mark that the fit is calculating asymmetric errors
/*!
This is called by the fitter interface to mark when
entering and exiting the asymmetric error calculation
\param [in] inAsymErrCalc boolean marking that the fit is calculating the asymmetric errors
*/
virtual void withinAsymErrorCalc(Bool_t inAsymErrCalc) = 0;
//! This function sets the parameter values from Minuit
/*!
This function has to be public since it is called from the global FCN.
It should not be called otherwise!
\param [in] par an array storing the various parameter values
\param [in] npar the number of free parameters
*/
virtual void setParsFromMinuit(Double_t* par, Int_t npar) = 0;
//! Calculate the new value of the negative log likelihood
/*!
This function has to be public since it is called from the global FCN.
It should not be called otherwise!
*/
virtual Double_t getTotNegLogLikelihood() = 0;
//! Store constraint information for fit parameters
/*!
\param [in] formula the formula to be used in the LauFormulaPar
\param [in] pars a vector of LauParameter names to be used in the Formula, in the order specified by the formula
\param [in] mean the value of the mean of the Gaussian constraint
\param [in] width the value of the width of the Gaussian constraint
*/
virtual void addConstraint(const TString& formula, const std::vector<TString>& pars, const Double_t mean, const Double_t width) = 0;
protected:
//! Constructor
LauFitObject() : TObject() {}
+ // Setup a struct to store information on constrained fit parameters
+ /*!
+ \struct StoreConstraints
+ \brief Struct to store constraint information until the fit is run
+ */
+ struct StoreConstraints {
+ //! The formula to be used in the LauFormulaPar
+ TString formula_;
+ //! The list of LauParameter names to be used in the LauFormulaPar
+ std::vector<TString> conPars_;
+ //! The mean value of the Gaussian constraint to be applied
+ Double_t mean_;
+ //! The width of the Gaussian constraint to be applied
+ Double_t width_;
+ };
+
private:
//! Copy constructor (not implemented)
LauFitObject(const LauFitObject& rhs);
//! Copy assignment operator (not implemented)
LauFitObject& operator=(const LauFitObject& rhs);
ClassDef(LauFitObject,0)
};
#endif
diff --git a/inc/LauSimFitMaster.hh b/inc/LauSimFitMaster.hh
index b1399b9..6399ce7 100644
--- a/inc/LauSimFitMaster.hh
+++ b/inc/LauSimFitMaster.hh
@@ -1,270 +1,254 @@
// Copyright University of Warwick 2013 - 2013.
// Distributed under the Boost Software License, Version 1.0.
// (See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
// Authors:
// Thomas Latham
// John Back
// Paul Harrison
/*! \file LauSimFitMaster.hh
\brief File containing declaration of LauSimFitMaster class.
*/
/*! \class LauSimFitMaster
\brief The master process for simultaneous/combined fits
Implementation of the JFit method described in arXiv:1409.5080 [physics.data-an].
This class acts as the interface between the slave processes and the minimiser.
*/
#ifndef LAU_SIM_FIT_MASTER
#define LAU_SIM_FIT_MASTER
#include <map>
#include <vector>
#include "TMatrixD.h"
#include "TStopwatch.h"
#include "TString.h"
#include "LauFitObject.hh"
class TMessage;
class TMonitor;
class TSocket;
class LauAbsRValue;
class LauParameter;
class LauFitNtuple;
class LauSimFitMaster : public LauFitObject {
public:
//! Constructor
/*!
\param [in] numSlaves the number of slaves processes to expect connections from
\param [in] port the port on which to listen for connections from the slaves
*/
LauSimFitMaster( UInt_t numSlaves, UInt_t port = 9090 );
//! Destructor
virtual ~LauSimFitMaster();
//! Run the fit
/*!
\param [in] fitNtupleFileName the file to which the ntuple containing the fit results should be written
\param [in] nExpt the number of experiments to be fitted
\param [in] firstExpt the ID of the first experiment to be fitted
\param [in] useAsymmErrors should asymmetric errors be calculated or not
\param [in] twoStageFit should the fit be performed in two stages or not
*/
void runSimFit( const TString& fitNtupleFileName, UInt_t nExpt, UInt_t firstExpt = 0, Bool_t useAsymmErrors = kFALSE, Bool_t twoStageFit = kFALSE );
//! Mark that the fit is calculating asymmetric errors
/*!
This function has to be public since it is called by
the fitter interface to mark when entering and exiting
the asymmetric error calculation.
It should not be called otherwise!
\param [in] inAsymErrCalc boolean marking that the fit is calculating the asymmetric errors
*/
virtual void withinAsymErrorCalc(Bool_t inAsymErrCalc) { withinAsymErrorCalc_ = inAsymErrCalc; }
//! This function sets the parameter values from Minuit
/*!
This function has to be public since it is called from the global FCN.
It should not be called otherwise!
\param [in] par an array storing the various parameter values
\param [in] npar the number of free parameters
*/
virtual void setParsFromMinuit(Double_t* par, Int_t npar);
//! Calculate the new value of the negative log likelihood
/*!
This function has to be public since it is called from the global FCN.
It should not be called otherwise!
*/
virtual Double_t getTotNegLogLikelihood();
//! Store constraint information for fit parameters
/*!
\param [in] formula the formula to be used in the LauFormulaPar
\param [in] pars a vector of LauParameter names to be used in the Formula, in the order specified by the formula
\param [in] mean the value of the mean of the Gaussian constraint
\param [in] width the value of the width of the Gaussian constraint
*/
virtual void addConstraint(const TString& formula, const std::vector<TString>& pars, const Double_t mean, const Double_t width);
protected:
//! Print information on the parameters
void printParInfo() const;
//! Initialise
void initialise();
//! Initialise socket connections for the slaves
void initSockets();
//! Determine/update the parameter initial values from all slaves
void getParametersFromSlaves();
//! Determine the parameter names and initial values from all slaves
void getParametersFromSlavesFirstTime();
//! Update and verify the parameter initial values from all slaves
void updateParametersFromSlaves();
//! Check for compatibility between two same-named parameters, which should therefore be identical
void checkParameter( const LauParameter* param, UInt_t index ) const;
//! Add parameters to the list of Gaussian constrained parameters
void addConParameters();
//! Calculate the penalty terms to the log likelihood from Gaussian constraints
Double_t getLogLikelihoodPenalty();
//! Instruct the slaves to read the input data for the given experiment
/*!
\return success/failure of the reading operations
*/
Bool_t readData();
//! Instruct the slaves to perform the caching
/*!
\return success/failure of the caching operations
*/
Bool_t cacheInputData();
//! Perform the fit for the current experiment
void fitExpt( Bool_t useAsymmErrors, Bool_t twoStageFit );
//! Instruct the slaves to update the initial fit parameter values, if required
void checkInitFitParams();
//! Return the final parameters to the slaves and instruct them to perform their finalisation
Bool_t finalise();
//! Instruct the slaves to write out the fit results
Bool_t writeOutResults();
private:
//! Copy constructor (not implemented)
LauSimFitMaster(const LauSimFitMaster& rhs);
//! Copy assignment operator (not implemented)
LauSimFitMaster& operator=(const LauSimFitMaster& rhs);
- // Setup a struct to store information on constrained fit parameters
- /*!
- \struct StoreConstraints
- \brief Struct to store constraint information until the fit is run
- */
- struct StoreConstraints {
- //! The formula to be used in the LauFormulaPar
- TString formula_;
- //! The list of LauParameter names to be used in the LauFormulaPar
- std::vector<TString> conPars_;
- //! The mean value of the Gaussian constraint to be applied
- Double_t mean_;
- //! The width of the Gaussian constraint to be applied
- Double_t width_;
- };
-
//! Store the constraints for fit parameters until initialisation is complete
std::vector<StoreConstraints> storeCon_;
//! The number of slaves
const UInt_t nSlaves_;
//! The requested port
const UInt_t reqPort_;
//! The number of fit parameters
UInt_t nParams_;
//! The number of free fit parameters
UInt_t nFreeParams_;
//! Flag to indicate if the asymmetric error calculation (e.g. MINOS) is currently running
Bool_t withinAsymErrorCalc_;
//! The number of successful fits
UInt_t numberOKFits_;
//! The number of fit failures
UInt_t numberBadFits_;
//! The status of the current fit
Int_t fitStatus_;
//! The experiment number of the current fit
UInt_t iExpt_;
//! The negative log-likelihood
Double_t NLL_;
//! The fit covariance matrix
TMatrixD covMatrix_;
//! The covariance sub-matrices for each slave
std::vector<TMatrixD> covMatrices_;
//! Parallel setup monitor
TMonitor* socketMonitor_;
//! Sockets for each of the slaves
std::vector<TSocket*> sSlaves_;
//! Messages to slaves
std::vector<TMessage*> messagesToSlaves_;
//! Message from slaves to the master
TMessage* messageFromSlave_;
//! Map of parameter names to index in the values vector
std::map< TString, UInt_t > parIndices_;
//! Reverse map of index in the values vector to parameter names
std::map< UInt_t, TString > parNames_;
//! Parameters
std::vector<LauParameter*> params_;
//! Gaussian constraints
std::vector<LauAbsRValue*> conVars_;
//! Parameter values
std::vector<Double_t> parValues_;
//! Lists of indices for each slave
std::vector< std::vector<UInt_t> > slaveIndices_;
//! Lists of indices of free parameters for each slave
std::vector< std::vector<UInt_t> > slaveFreeIndices_;
//! Parameter values to send to the slaves
std::vector<Double_t*> vectorPar_;
//! Likelihood values returned from the slaves
std::vector<Double_t> vectorRes_;
//! The fit timer
TStopwatch timer_;
//! The total fit timer
TStopwatch cumulTimer_;
//! The fit results ntuple
LauFitNtuple* fitNtuple_;
ClassDef(LauSimFitMaster,0);
};
#endif

File Metadata

Mime Type
text/x-diff
Expires
Tue, Nov 19, 7:10 PM (1 d, 12 h)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
3805772
Default Alt Text
(43 KB)

Event Timeline