Add 'CompareVariables.cpp'

Renata Kopecná 2022-01-31 11:31:03 +01:00
parent 481d6a1fd5
commit 6de2744f8f

301
CompareVariables.cpp.md Normal file

@ -0,0 +1,301 @@
Older function created before my time, so you will find new lines without brackets here and other lovely features.
## Table of Contents
* [Global variables:](#global-variables)
* [Classes](#classes)
* [Functions](#functions)
* [int evalOperation()](#int-evaloperation)
* [double evalOperation()](#double-evaloperation)
* [int compareVariables()](#int-comparevariables)
* [int compareVariablesKplusKshort()](#int-comparevariableskpluskshort)
* [int compareAllKshorts()](#int-compareallkshorts)
* [int compareAllKshortsWeightedAndUnweighted()](#int-compareallkshortsweightedandunweighted)
* [int compareKshortPreSelectionAndStrippingVariables()](#int-comparekshortpreselectionandstrippingvariables)
* [int compareKshortMVAonly()](#int-comparekshortmvaonly)
* [int compareMuIPKplusResolved()](#int-comparemuipkplusresolved)
* [int compareAllKplusResolved()](#int-compareallkplusresolved)
* [int compareAllKplusMerged()](#int-compareallkplusmerged)
* [int compareKplusResolvedMVAonly()](#int-comparekplusresolvedmvaonly)
* [int compareAllKplus()](#int-compareallkplus)
* [int compareAll()](#int-compareall)
* [int compareTrackMultiplicities()](#int-comparetrackmultiplicities)
* [int compareAnglesInPHSP()](#int-compareanglesinphsp)
* [int compareAllAnglesInPHSP()](#int-compareallanglesinphsp)
* [int compareAnglesInMC()](#int-compareanglesinmc)
* [int compareAllAnglesInMC()](#int-compareallanglesinmc)
* [int compareAnglesInPHSPbeforeAndAfterBDTcut()](#int-compareanglesinphspbeforeandafterbdtcut)
* [int compareAllPHSPAnglesBeforeAndAfterBDT()](#int-compareallphspanglesbeforeandafterbdt)
* [int compareNTracksAndBplusPT()](#int-comparentracksandbpluspt)
* [int compareAllNtracksAndBplusPT()](#int-compareallntracksandbpluspt)
* [int compareAllKplusKshort()](#int-compareallkpluskshort)
* [int compareAllKplusAllRunsAndWeights()](#int-compareallkplusallrunsandweights)
## Global variables:
* const bool CutInQ2 = false //If true, select only events between minQ2 and maxQ2
* double minQ2 = 15.0
* double maxQ2 = 100.0
* const bool CutInMuPt = false //If true, select only events between minPT and maxPT
* double minPT = 1100.0 //2500
* double maxPT = 2500.0 //10000
* const bool separateCharge = false //Check for B+ and B- separately
* bool plusCharge = false //If separateCharge, do you want to plot B+ or B-?
# Functions
### int evalOperation()
Before I discovered that ROOT can take formulas, I had to figure it out on my own. So this takes x and y and performs the desired operation. It is useful when comparing eg momentum-momentum or 1-log(momentum).
* **Parameters**
* bool useTwoVars = false
* int x = 0
* int y = 0
* std::string operation = "plus"
* bool bLogVar = false
* bool bLog1minusVar = false
* **Return**
* Operation(x,y)
### double evalOperation()
Before I discovered that ROOT can take formulas, I had to figure it out on my own. So this takes x and y and performs the desired operation.
* **Parameters**
* bool useTwoVars = false
* double x = 0.0
* double y = 0.0
* std::string operation = "plus"
* bool bLogVar = false
* bool bLog1minusVar = false
* **Return**
* Operation(x,y)
### int compareVariables()
Compute and plot a desired variable for given year and subdecay channel. Choose weither it is sWeighted, not weighted, weighted by nTracks or 2 * 1D reweighted by first and second weighting variables defined in [[GlobalFunctions.hh|GlobalFunctions.hh]]. The data sample can be sweighted, so the weighting only concerns the MC sample. Choose whether to print the plots to pdf and root files. Variables can be plotted in log(var) or log(1 - var), using the according booleans.
* **Parameters**
* int year = 2011
* std::string variable = "B_plus_PT"
* bool sWeight = true
* bool bWeighted = true
* bool b2Dweighted = true
* bool bLogVar = false
* bool bLog1minusVar = false
* bool bPrint = true
* bool KshortDecayInVelo = true
* std::string weightBranch = "CB"
* bool useTwoVars = false
* string operation = ""
* string variable2 = ""
* string xAxis = ""
* **Return**
* 0 if something fails, 1 otherwise
### int compareVariablesKplusKshort()
Seems to do the same thing as [compareVariables()](#int-comparevariables). Probably obsolete.
* **Parameters**
* int year = 2011
* std::string variable = "B_plus_PT"
* bool sWeightKplus = false
* bool sWeightKshort = true
* bool bWeighted = true
* bool b2Dweighted = true
* bool bLogVar = false
* bool bLog1minusVar = false
* bool bPrint = true
* bool KshortDecayInVelo = true
* std::string weightBranch = firstMCweight
* **Return**
* 0 if something fails, 1 otherwise
### int compareAllKshorts()
Calls [compareVariables()](#int-comparevariables) for all variables needed by the KS channel.
* **Parameters**
* bool sWeight = true
* bool bWeighted = true
* bool b2DWeighted = true
* int Run = 1
* std::string weightBranch = firstMCweight
* **Return**
* 0 if something fails, 1 otherwise
### int compareAllKshortsWeightedAndUnweighted()
Calls [compareAllKshorts()](#int-compareallkshorts), Run 1, with no weights, 1D weights and 2D weights.
* **Return**
* Always 1
### int compareKshortPreSelectionAndStrippingVariables()
Calls [compareVariables()](#int-comparevariables) for all pi+ PIDK and mu+- ProbNNmu.
* **Parameters**
* int Run = 1
* **Return**
### int compareKshortMVAonly()
Calls [compareVariables()](#int-comparevariables) for all variables used in MVA training defined in [[TMVA_variables_TheDecayDL.txt|MVA-Class]] **TODO** used by the KS channel.
* **Parameters**
* bool sWeight = true
* bool bWeighted = true
* bool b2DWeighted = true
* int Run = 1
* std::string weightBranch = firstMCweight
* **Return**
* 0 if something fails, 1 otherwise
### int compareMuIPKplusResolved()
Calls [compareAllKshorts()](#int-compareallkshorts) for mu+- IP chi2.
* **Parameters**
* int Run = 1
* std::string weightBranch = firstMCweight
* **Return**
* 0 if something fails, 1 otherwise
### int compareAllKplusResolved()
Calls [compareAllKshorts()](#int-compareallkshorts) for all useful variables in the K+pi0 channel.
* **Parameters**
* bool sWeight = true
* bool bWeighted = true
* bool b2DWeighted = false
* int Run = 1
* std::string weightBranch = firstMCweight
* **Return**
* 0 if something fails, 1 otherwise
### int compareAllKplusMerged()
Obsolete, was checking the merged pi0 subchannel.
* **Parameters**
* bool sWeight = true
* bool bWeighted = true
* bool b2DWeighted = false
* int Run = 1
* std::string weightBranch = firstMCweight
* **Return**
* 0 if something fails, 1 otherwise
### int compareKplusResolvedMVAonly()
Calls [compareVariables()](#int-comparevariables) for all variables used in MVA training defined in [[TMVA_variables_TheDecayDL.txt|MVA-Class]] **TODO** used by the K+pi0 channel.
* **Parameters**
* bool sWeight = true
* bool bWeighted = true
* bool b2DWeighted = true
* int Run = 1
* std::string weightBranch = firstMCweight
* **Return**
* 0 if something fails, 1 otherwise
### int compareAllKplus()
Calls [compareAllKplusResolved()](#int-compareallkplusresolved) for both runs, with different weights and specified weightBranch.
* **Parameters**
* std::string weightBranch = firstMCweight
* **Return**
* 0 if something fails, 1 otherwise
### int compareAll()
Calls either [compareKplusResolvedMVAonly()](#int-comparekplusresolvedmvaonly) or [compareKshortMVAonly()](#int-comparekshortmvaonly)
* **Parameters**
* int Run = 1
* **Return**
* 0 if something fails, 1 otherwise
### int compareTrackMultiplicities()
Comparison of track multiplicities between Run I and Run II.
* **Parameters**
* bool KshortDecaysInVelo = false
* bool MC = false
* std::string weightBranch = firstMCweight
* **Return**
* 0 if something fails, 1 otherwise
### int compareAnglesInPHSP()
Comparison of the angles between (2D-)weighted and non-weighted PHSP MC.
* **Parameters**
* int year = 2011
* bool sWeight = true
* bool b2Dweighted = true
* bool KshortDecayInVelo = true
* std::string weightBranch = firstMCweight
* **Return**
* 0 if something fails, 1 otherwise
### int compareAllAnglesInPHSP()
Calls [compareAnglesInPHSP()](#int-compareanglesinphsp) for all years and LL/DD.
* **Parameters**
* int Run = 1
* **Return**
* 0 if something fails, 1 otherwise
### int compareAnglesInMC()
Cmparison of the ngles between (2D-)weighted and non-weighted signal MC.
* **Parameters**
* int year = 2011
* bool sWeight = true
* bool b2Dweighted = true
* bool KshortDecayInVelo = true
* std::string weightBranch = firstMCweight
* **Return**
* 0 if something fails, 1 otherwise
### int compareAllAnglesInMC()
Calls [compareAllAnglesInMC()](#int-compareallanglesinmc) for all years and LL/DD.
* **Parameters**
* int Run = 1
* **Return**
* 0 if something fails, 1 otherwise
### int compareAnglesInPHSPbeforeAndAfterBDTcut()
Cmparison of the angles in PHSP MC before and after the MVA cut.
* **Parameters**
* int year = 2011
* bool bweighted = true
* bool b2Dweighted = true
* bool KshortDecayInVelo = true
* std::string weightBranch = firstMCweight
* **Return**
* 0 if something fails, 1 otherwise
### int compareAllPHSPAnglesBeforeAndAfterBDT()
Calls [compareAnglesInPHSPbeforeAndAfterBDTcut()](#int-compareanglesinphspbeforeandafterbdtcut) for all years and LL/DD.
* **Parameters**
* int Run = 1
* **Return**
* 0 if something fails, 1 otherwise
### int compareNTracksAndBplusPT()
Comparison of nTracks and B_plus_PT between signal and reference channel MC.
* **Parameters**
* int year = 2011
* bool KshortDecayInVelo = true
* **Return**
* 0 if something fails, 1 otherwise
### int compareAllNtracksAndBplusPT()
Calls [compareNTracksAndBplusPT()](#int-comparentracksandbpluspt) for all years and LL/DD.
* **Parameters**
* int Run = 1
* **Return**
* 0 if something fails, 1 otherwise
### int compareAllKplusKshort()
Comparison of Kplus and Kshort.
* **Parameters**
* bool sWeightKplus = false
* bool sWeightKshort = true
* bool bWeighted = true
* bool b2DWeighted = false
* int Run = 1
* bool KshortDecayInVelo = true
* std::string weightBranch = "nTracks"
* **Return**
* 0 if something fails, 1 otherwise
### int compareAllKplusAllRunsAndWeights()
Calls [compareAllKplusKshort()](#int-compareallkpluskshort) for both runs and not/using weight sin K+ and/or KS.
* **Parameters**
* bool bWeighted = true
* bool b2DWeighted = false
* **Return**
* 0 if something fails, 1 otherwise