448 lines
15 KiB
C++
448 lines
15 KiB
C++
/**
|
|
* @file options.hh
|
|
* @author Christoph Langenbruch, Renata Kopecna
|
|
* @date 2009-03-18
|
|
*
|
|
* This file contains the options class which is used to store all the settings which are needed
|
|
* for the fit. The likelihood, fitter, and plotter classes each
|
|
* hold a pointer to an options object which must be supplied in their constructor.
|
|
* On initialisation of the fitter class, the chosen options are printed
|
|
* and should be redirected to a logfile
|
|
*
|
|
*/
|
|
|
|
#ifndef OPTIONS_H
|
|
#define OPTIONS_H
|
|
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
#include <constants.hh>
|
|
|
|
|
|
|
|
namespace fcnc {
|
|
|
|
///class that stores the options used in the analysis
|
|
class options {
|
|
public:
|
|
///number of cores to use
|
|
unsigned int ncores;
|
|
///use angular acceptance in the likelihood
|
|
bool use_angular_acc;
|
|
/// fit angular acceptance correction coefficients
|
|
bool angularacceptance;
|
|
/// get angular acceptance corrections for every year individually
|
|
bool angacccorrperyear;
|
|
/// combine every 2 years (2011+12, 2015+16, 2017+18) for acceptance correction
|
|
bool angacccorrpertwoyears;
|
|
/// combine the dataset of both runs for the angular acceptance correction:
|
|
bool angacccorrbothruns;
|
|
/// only calculate chi2's from the 1D projections of cos(tl), cos(tk), phi and q2
|
|
bool only_4_1D_chi2;
|
|
/// scan the parametrization of angular acceptance corrections coefficients
|
|
/// by changing the max. order of legendre polynoms
|
|
bool scan_max_order_angacccorrection;
|
|
///do plots after every step in a toystudy
|
|
bool project;
|
|
///write .eps files
|
|
bool write_eps;
|
|
///write .C files (of plots)
|
|
bool write_C;
|
|
///write .jpg files (of plots)
|
|
bool write_jpg;
|
|
///write .pdf files (of plots)
|
|
bool write_pdf;
|
|
///read only out truthmatched bs candidates from file
|
|
bool only_truthmatched;
|
|
///use only true quantities for the fit. Not implemented yet
|
|
bool use_truth;
|
|
///use numerically optimal summation of likelihoods
|
|
bool shift_lh;
|
|
///repeat on fail
|
|
bool repeat_on_fail;
|
|
///use minos for error calculation
|
|
bool minos_errors;
|
|
///use simplex first
|
|
bool simplex_prerun;
|
|
///use Markov chain Monte Carlo
|
|
bool use_mcmc;
|
|
///hesse postrun
|
|
bool hesse_postrun;
|
|
///use accymptotic hesse, broken at this moment!!!
|
|
bool asymptotic;
|
|
///weighted fit
|
|
bool weighted_fit;
|
|
///generate background with acceptance correction in the PDF
|
|
bool use_weighted_bkg;
|
|
///in the case of a folded and acc corrected fit, use full angular PDF for background
|
|
bool fit_full_angular_bkg;
|
|
///use event q2 when determining weight
|
|
bool use_event_norm;
|
|
///static seed for toys
|
|
bool static_seed;
|
|
///Always use the same seed for toy generation, useful in systematics
|
|
bool always_static_seed;
|
|
///extended ml fit
|
|
bool extended_ml;
|
|
///refitting of nominal values for systematic studies
|
|
bool refitting_nominal;
|
|
///Options to set the mass shape
|
|
bool crystalball;
|
|
bool twotailedcrystalball;
|
|
bool swave;
|
|
bool simple_mkpi;
|
|
//THIS TURNS ON FITTING BOTH K*mass and B+ mass
|
|
//AND it turns off the angle fits
|
|
bool only_mass2DFit;
|
|
bool use_p2;
|
|
//order of fitted polynomials
|
|
unsigned int eff_order_costhetal;
|
|
unsigned int eff_order_costhetak;
|
|
unsigned int eff_order_phi;
|
|
unsigned int eff_order_q2;
|
|
int orderincrease;
|
|
//order of background, currently does nothing, might be useful in the future
|
|
unsigned int bkg_order_costhetal;
|
|
unsigned int bkg_order_costhetak;
|
|
unsigned int bkg_order_phi;
|
|
|
|
//minimum and maximum mass
|
|
bool cutsignalwindow;
|
|
double m_min; //signal window left edge
|
|
double m_max; //signal window right edge
|
|
double m_low; //considered mass spectrum left edge
|
|
double m_high; //considered mass spectrum right edge
|
|
double q2_min;//this is only used in weighted generation
|
|
double q2_max;
|
|
//Initialize using the SM values?
|
|
bool initSM;
|
|
///Options for all plots
|
|
double ctl_min;
|
|
double ctl_max;
|
|
double ctk_min;
|
|
double ctk_max;
|
|
double phi_min;
|
|
double phi_max;
|
|
unsigned int plots_m_bins;
|
|
unsigned int plots_mkpi_bins;
|
|
unsigned int plots_costhetal_bins;
|
|
unsigned int plots_costhetak_bins;
|
|
unsigned int plots_phi_bins;
|
|
std::string plot_label;
|
|
std::string plot_folder;
|
|
std::string q2_label;
|
|
bool plot_chi2;
|
|
std::string name;
|
|
double minuit_strategy;
|
|
bool flat_bkg;
|
|
bool full_angular; //If false, use folding
|
|
bool always_generate_full_angular; //I have no idea what it does but it is always true everywhere
|
|
unsigned int fitsperjob;
|
|
int job_id;
|
|
//Fit only mass/angles/kpi mass
|
|
bool only_Bmass; //For whatever fucking reason, this forces mkpi probability to be 1, so unless you don't fit it, set this to false
|
|
bool only_angles;
|
|
bool only_mkpi;
|
|
bool reset_start;
|
|
//for a simultaneous fit: TRUE if all param names have individual suffix to distinguish between sets of parameters
|
|
bool use_individual_param_names;
|
|
bool fit_asymmetries;
|
|
bool fit_fl;
|
|
bool fit_afb;
|
|
bool fit_pprimes;
|
|
//fit m(Kpi) mass spectrum?
|
|
bool fit_mkpi; //4D+1D fit
|
|
bool fit_lambda;
|
|
//use the information of the m(Kpi) dimension in the angular_prob
|
|
bool use_mkpi; //5D fit
|
|
bool individual_penalties;
|
|
double mkpi_min;
|
|
double mkpi_max;
|
|
bool update_efficiencies;
|
|
bool squared_hesse;
|
|
bool mkpi_threshold;
|
|
bool mkpi_full_range_norm;
|
|
//Generation
|
|
bool generate_mkpi;
|
|
bool generate_only_bkg;
|
|
bool isobar;
|
|
bool multiply_eff;
|
|
bool cache_fis;
|
|
bool mcweight;
|
|
bool chisquaredstudy;
|
|
int systematic;
|
|
bool useMC;
|
|
int run;
|
|
int year;
|
|
int verbose;
|
|
std::string DDLL;
|
|
bool DTF;
|
|
bool KS;
|
|
std::vector<double> TheQ2binsmin;
|
|
std::vector<double> TheQ2binsmax;
|
|
bool IsFlatQ2;
|
|
int folding;
|
|
bool reject_identical_muon_TRUEID;
|
|
//File used for latex output //TODO
|
|
std::string latexFileTag;
|
|
|
|
///constructor
|
|
options(std::string argument=""):
|
|
ncores(1),
|
|
use_angular_acc(false),
|
|
angularacceptance(false),
|
|
angacccorrperyear(false),
|
|
angacccorrpertwoyears(false),
|
|
angacccorrbothruns(false),
|
|
only_4_1D_chi2(false),
|
|
scan_max_order_angacccorrection(false),
|
|
project(false),
|
|
write_eps(false),
|
|
write_C(false),
|
|
write_jpg(false),
|
|
write_pdf(false),
|
|
shift_lh(false),
|
|
repeat_on_fail(false),
|
|
minos_errors(false),
|
|
simplex_prerun(false),
|
|
use_mcmc(false),
|
|
hesse_postrun(true),
|
|
asymptotic(false),
|
|
weighted_fit(false),
|
|
use_weighted_bkg(false),
|
|
fit_full_angular_bkg(true),
|
|
use_event_norm(false),
|
|
static_seed(false),
|
|
always_static_seed(false),
|
|
extended_ml(false),
|
|
refitting_nominal(true),
|
|
crystalball(!DOUBLE_CB),
|
|
twotailedcrystalball(DOUBLE_CB),
|
|
swave(false),
|
|
simple_mkpi(false),
|
|
only_mass2DFit(false),
|
|
use_p2(false),
|
|
eff_order_costhetal(ORDER_COSTHETAL),
|
|
eff_order_costhetak(ORDER_COSTHETAK),
|
|
eff_order_phi(ORDER_PHI),
|
|
eff_order_q2(ORDER_Q2),
|
|
orderincrease(0),
|
|
bkg_order_costhetal(2), //TODO
|
|
bkg_order_costhetak(4), //TODO
|
|
bkg_order_phi(0), //TODO
|
|
|
|
cutsignalwindow(false),
|
|
m_min(PDGMASS_B-B_MASS_TIGHT_WINDOW),
|
|
m_max(PDGMASS_B+B_MASS_TIGHT_WINDOW),
|
|
m_low(B_MASS_LOW),
|
|
m_high(B_MASS_HIGH),
|
|
q2_min(-1.0),
|
|
q2_max(-1.0),
|
|
initSM(false),
|
|
ctl_min(CTL_MIN),
|
|
ctl_max(CTL_MAX),
|
|
ctk_min(CTK_MIN),
|
|
ctk_max(CTK_MAX),
|
|
phi_min(PHI_MIN),
|
|
phi_max(PHI_MAX),
|
|
plots_m_bins(PLOT_NBINS_MB),
|
|
plots_mkpi_bins(PLOT_NBINS_MKSTAR),
|
|
plots_costhetal_bins(PLOT_NBINS_ANGLES),
|
|
plots_costhetak_bins(PLOT_NBINS_ANGLES),
|
|
plots_phi_bins(PLOT_NBINS_ANGLES),
|
|
plot_label("LHCb 9.1 fb^{-1}"),
|
|
plot_folder(""),
|
|
q2_label("1.1 < q^2 < 19.0"),
|
|
plot_chi2(false),
|
|
name(argument),
|
|
minuit_strategy(2.0),
|
|
flat_bkg(false),
|
|
full_angular(false),
|
|
always_generate_full_angular(true),
|
|
fitsperjob(10),
|
|
job_id(-1),
|
|
only_Bmass(false),
|
|
only_angles(false),
|
|
only_mkpi(false),
|
|
reset_start(true),
|
|
use_individual_param_names(false),
|
|
fit_asymmetries(false),
|
|
fit_fl(false),
|
|
fit_afb(false),
|
|
fit_pprimes(false),
|
|
fit_mkpi(false),
|
|
fit_lambda(false),
|
|
use_mkpi(false),
|
|
individual_penalties(false),
|
|
mkpi_min(KPI_MASS_MIN),
|
|
mkpi_max(KPI_MASS_MAX),
|
|
update_efficiencies(true),
|
|
squared_hesse(true),
|
|
mkpi_threshold(false),
|
|
mkpi_full_range_norm(false),
|
|
generate_mkpi(false),
|
|
generate_only_bkg(false),
|
|
isobar(false),
|
|
multiply_eff(false),
|
|
cache_fis(false),
|
|
mcweight(false), //Not changed anywhere, only in pdf to decide what weights to use and there it is always true, no clue what it is supposed to do
|
|
chisquaredstudy(false),
|
|
systematic(-1),
|
|
useMC(false),
|
|
run(-1),
|
|
year(-1),
|
|
verbose(2), //Set to info
|
|
DDLL("DD"),
|
|
DTF(true),
|
|
KS(true),
|
|
TheQ2binsmin(std::vector<double>(6, 0.0)),
|
|
TheQ2binsmax(std::vector<double>(6, 0.0)),
|
|
IsFlatQ2(true),
|
|
folding(-1),
|
|
reject_identical_muon_TRUEID(false),
|
|
latexFileTag("_basic") //TODO
|
|
{
|
|
};
|
|
|
|
//assignment operator:
|
|
options operator=(const options o){
|
|
//self-assignment guard
|
|
// if (this == &o) //TODO: requires operator==
|
|
// return *this;
|
|
ncores = o.ncores;
|
|
use_angular_acc = o.use_angular_acc;
|
|
angularacceptance = o.angularacceptance;
|
|
angacccorrperyear = o.angacccorrperyear;
|
|
angacccorrpertwoyears = o.angacccorrpertwoyears;
|
|
angacccorrbothruns = o.angacccorrbothruns;
|
|
only_4_1D_chi2 = o.only_4_1D_chi2;
|
|
scan_max_order_angacccorrection = o.scan_max_order_angacccorrection;
|
|
project = o.project;
|
|
write_eps = o.write_eps;
|
|
write_C = o.write_C;
|
|
write_jpg = o.write_jpg;
|
|
write_pdf = o.write_pdf;
|
|
only_truthmatched = o.only_truthmatched;
|
|
use_truth = o.use_truth;
|
|
shift_lh = o.shift_lh;
|
|
repeat_on_fail = o.repeat_on_fail;
|
|
minos_errors = o.minos_errors;
|
|
simplex_prerun = o.simplex_prerun;
|
|
use_mcmc = o.use_mcmc;
|
|
asymptotic = o.asymptotic;
|
|
hesse_postrun = o.hesse_postrun;
|
|
weighted_fit = o.weighted_fit;
|
|
use_weighted_bkg = o.use_weighted_bkg;
|
|
fit_full_angular_bkg = o.fit_full_angular_bkg;
|
|
use_event_norm = o.use_event_norm;
|
|
static_seed = o.static_seed;
|
|
always_static_seed = o.always_static_seed;
|
|
extended_ml = o.extended_ml;
|
|
refitting_nominal = o.refitting_nominal;
|
|
crystalball = o.crystalball;
|
|
twotailedcrystalball = o.twotailedcrystalball;
|
|
swave = o.swave;
|
|
simple_mkpi = o.simple_mkpi;
|
|
only_mass2DFit = o.only_mass2DFit;
|
|
use_p2 = o.use_p2;
|
|
eff_order_costhetal = o.eff_order_costhetal;
|
|
eff_order_costhetak = o.eff_order_costhetak;
|
|
eff_order_phi = o.eff_order_phi;
|
|
eff_order_q2 = o.eff_order_q2;
|
|
bkg_order_costhetal = o.bkg_order_costhetal;
|
|
bkg_order_costhetak = o.bkg_order_costhetak;
|
|
bkg_order_phi = o.bkg_order_phi;
|
|
orderincrease = o.orderincrease;
|
|
cutsignalwindow = o.cutsignalwindow;
|
|
m_min = o.m_min;
|
|
m_max = o.m_max;
|
|
m_low = o.m_low;
|
|
m_high = o.m_high;
|
|
q2_min = o.q2_min;
|
|
q2_max = o.q2_max;
|
|
initSM = o.initSM;
|
|
ctl_min = o.ctl_min;
|
|
ctl_max = o.ctl_max;
|
|
ctk_min = o.ctk_min;
|
|
ctk_max = o.ctk_max;
|
|
phi_min = o.phi_min;
|
|
phi_max = o.phi_max;
|
|
plots_m_bins = o.plots_m_bins;
|
|
plots_mkpi_bins = o.plots_mkpi_bins;
|
|
plots_costhetal_bins = o.plots_costhetal_bins;
|
|
plots_costhetak_bins = o.plots_costhetak_bins;
|
|
plots_phi_bins = o.plots_phi_bins;
|
|
plot_label = o.plot_label;
|
|
plot_folder = o.plot_folder;
|
|
q2_label = o.q2_label;
|
|
plot_chi2 = o.plot_chi2;
|
|
name = o.name;
|
|
minuit_strategy = o.minuit_strategy;
|
|
flat_bkg = o.flat_bkg;
|
|
full_angular = o.full_angular;
|
|
always_generate_full_angular = o.always_generate_full_angular;
|
|
fitsperjob = o.fitsperjob;
|
|
job_id = o.job_id;
|
|
only_Bmass = o.only_Bmass;
|
|
only_angles = o.only_angles;
|
|
only_mkpi = o.only_mkpi;
|
|
reset_start = o.reset_start;
|
|
use_individual_param_names = o.use_individual_param_names;
|
|
fit_asymmetries = o.fit_asymmetries;
|
|
fit_fl = o.fit_fl;
|
|
fit_afb = o.fit_afb;
|
|
fit_pprimes = o.fit_pprimes;
|
|
fit_mkpi = o.fit_mkpi;
|
|
fit_lambda = o.fit_lambda;
|
|
use_mkpi = o.use_mkpi;
|
|
individual_penalties = o.individual_penalties;
|
|
mkpi_min = o.mkpi_min;
|
|
mkpi_max = o.mkpi_max;
|
|
update_efficiencies = o.update_efficiencies;
|
|
squared_hesse = o.squared_hesse;
|
|
mkpi_threshold = o.mkpi_threshold;
|
|
mkpi_full_range_norm = o.mkpi_full_range_norm;
|
|
generate_mkpi = o.generate_mkpi;
|
|
generate_only_bkg = o.generate_only_bkg;
|
|
isobar = o.isobar;
|
|
multiply_eff = o.multiply_eff;
|
|
cache_fis = o.cache_fis;
|
|
mcweight = o.mcweight;
|
|
chisquaredstudy = o.chisquaredstudy;
|
|
systematic = o.systematic;
|
|
useMC = o.useMC;
|
|
run = o.run;
|
|
year = o.year;
|
|
verbose = o.verbose;
|
|
DDLL = o.DDLL;
|
|
DTF = o.DTF;
|
|
KS = o.KS;
|
|
TheQ2binsmin = o.TheQ2binsmin;
|
|
TheQ2binsmax = o.TheQ2binsmax;
|
|
IsFlatQ2 = o.IsFlatQ2;
|
|
folding = o.folding;
|
|
reject_identical_muon_TRUEID = o.reject_identical_muon_TRUEID;
|
|
return *this;
|
|
}
|
|
|
|
int get_job_id();
|
|
//Check if the angle ranges are not interfering with the folding
|
|
bool canIFold();
|
|
void reset_angle_ranges();
|
|
void update_angle_ranges();
|
|
unsigned int get_nQ2bins();
|
|
//Reutrns a vector with strings of all types that are required by write_eps, write_C, write_jpg and write_pdf
|
|
std::vector<std::string> getAllPlotTypes();
|
|
void print();
|
|
};
|
|
|
|
}
|
|
|
|
std::vector<std::string> get_observables_vec (fcnc::options opts); //TODO: add into fcnc class
|
|
void set_ang_year_options(fcnc::options &opts);
|
|
|
|
//If true, than the parameter is folded and typically set to 0 //TODO: add into fcnc class
|
|
bool is_param_folded(int param, fcnc::options *opts);
|
|
#endif
|