Skip to content

Latest commit

 

History

History
185 lines (137 loc) · 10.5 KB

README.md

File metadata and controls

185 lines (137 loc) · 10.5 KB

YCrossFit

A shared library for analyzing dimuon resonances, built by Giulio Cordova and Matilde Carminati for the CMEPDA exam.

docs License: GPL v3

Using the Y(1S,2S,3S) resonances in two muons from the CMS open data, the main goals of this library are essentially two:

  • fitting them with customizable parameters;
  • plotting the differential cross section in $p_T $.

This functionalities are built in order to recreate similar plots of the article Measurements of the Υ(1S), Υ(2S), and Υ(3S) differential cross sections in pp collisions at √s = 7 TeV by the CMS collaboration, even if the data set are not the same.

Requirements

  • CMake 3.5
  • CERN ROOT 6.26

A simple example usage

The whole project is built with CMake, so the first thing we want to do is to create a build directory where the makefiles and executables are going to be. This is simply done by typing in the terminal:

$ cmake -S . -B ./build

$ make -C build

Default options (Cross mode)

If we run the main of the library without specifying any flags or options, as it follows:

$ ./build/main/YLaunch

the program will create the plot of the differential cross section in pt of the Y resonances.

In order to avoid typing the whole command, one can also use the bash script YCross.sh, which will compile and execute the script in CrossSection mode

$ ./YCross.sh

The default applied filters are:

  • For the single muon:

    • $p_T &gt; 3$ GeV for 1.4 < | $\eta$| < 1.6,
    • $p_T &gt; 3.5$ GeV for 1.2 < | $\eta$| < 1.4,
    • $p_T &gt; 4.5$ GeV for | $\eta$| < 1.2.
  • an invariant mass of the Dimuon pair between 8.5 and 11.5 GeV

  • at least 2 muons of opposite charge in each event

Final Result

The cut on the absolute value of rapidity is customizable by adding the flags -y and -Y, as described in the documentation of ProcessArgs()

Fit mode

This programs also offers a Fit functionality where the differential cross section is not calculated nor plotted, but a singular fit is performed. This is called by adding the option --mode (-m) fit to the executable call.

$ ./build/main/YLaunch --mode fit

As for the CrossSection mode, a bash script is also provided for Fit mode, which will compile and execute the program:

$ ./YFit.sh

The following graph is produced, while the results of the fit are printed in the terminal. Fit Mode

Custimize options

In Fit mode we can customize some cuts on the dimuon state using the flags described in the documentation of the file OptionParse.h.

Say for example, that we want to apply the cuts $20.0 \lt p_T \lt 30.0$ GeV and $|y|\lt 0.5$ for the dimuon state and save the plot in a file named CustomizeCuts.pdf. We can type in the terminal

$ ./build/main/YLaunch -m fit -n “CustomizeCuts” -p 20. -P 30. -Y 0.5

and the following figure is produced and saved in the file CustomizeCut.pdf inside the Plots folder.

CustomizeCuts An exhaustive list of options are flags can also be obtained by typing in the terminal

$ ./build/main/YLaunch --help

Description of main (and functionality of libraries)

In order to use the library as the author thought, a main is provided with it. In this section, the structure of the program is explained as if we were reading the code starting from the main and following the function calls.

Choice of the parameters and flags

The first thing one wants to do is to initialize some parameters. This step is necessary because the options and flags are passed as pointers in the function ProcessArgs(), so that they can be modified by the user with the flag syntax while calling the executable from terminal. The default values are:

  • fitFunction = 0, i.e. Breit-Wigner
  • ptm, ptM, ym, yM = NaN, i.e. no cuts on $p_T$ or rapidity $y$
  • nameFile = "YResonacesFit", name of the figure that will be saved
  • verbose = 0, i.e. no output stream from Minuit
  • mode = 1, i.e. CrossMode
  • canvas = 0, i.e. display canvas

In the optionParse.C file are also defined functions in order to handle parameters out of bounds and non-existing ones.

Data Load

The data are loaded and manipulated (to have useful variables) using the functions defined inside df_set.C. Since the data are heavy, it is really slow to read them online every time one calls the program. Therefore, it was decided to download them and store them in a folder Data.

Note: The folder Data is not in this repository because is too heavy. The first time you call this function, the data are going to be downloaded from the CMS Open Data portal, so it might take a while (up to 40 minutes depending on the internet connection).

The Dataset is saved through a Snapshot of the Dataframe with new useful variables:

  • Dimuon_FourVec: Four Vector containing the Pt, Eta, Phi and Mass of the Dimuon pair
  • Dimuon_mass: Invariant Mass of the Dimuon Four Vector
  • Dimuon_pt: Transverse Momentum of the Dimuon Four Vector
  • Dimuon_beta: Beta (velocity) of the Dimuon Four Vector
  • Dimuon_y: Rapidity of the Dimuon Four Vector

This variables are defined in order to make fast and efficient cuts on the Dataframe.

In the functiondf_set() is also handled the creation of the folder Data if not already existing.

Apply some cuts!

In the file Cuts.C one can decide the cuts to be applied in the dataframe.

It is possible to choose custom cuts on the trasverse momentum and the rapidity of the dimuon state, by adding an option while calling the program from the terminal. For example, the line

$ ./build/main/YLaunch -m fit -p 12 -P 50 -y 0.2 -Y 1.4

requests the cuts to be $12\lt p_T \lt 50$ GeV and $0.2&lt;|y|&lt;1.4$ , this dataframe is not saved. Once the dataframe is cut, the report on the cuts is printed on stream.

Draw a preliminary Spectrum Plot

The selected data are preliminary drawn on a canvas as an histohgramm of the invariant mass of the dimuon.

PreliminaryHisto

The canvas is saved as nameFile_Preliminary.pdf, where nameFile is the name passed through command line with the flag -n or --nameFile.

If no argument is provided, the default value for nameFile is "YResonacesFit".

In the file Cuts.C is also defined a function in order to handle the saving of figures in the folder Plots. If it does not exist, it is recreated.

Fit the Function and save it in a canvas

In fitRoo.C the plotted histogramm is fitted by RooFit to a PDF choosable with the flag -f [--fitFunction]. The options are:

  • a BreitWigner [-f bw] (default)
  • a Gaussian [-f gaus]
  • a t-Student [-f stud] (still not stable in this version)

The histogram and the fitted function are drawn on a canvas which is saved as nameFile.pdf. If there are custom cuts, these are printed on the canvas.

Calculate and plot the differential cross section

Using the customizable function fitRoo(), it is possible calculate the differential cross section of the process $Y-&gt;\mu^+\mu^-$, defined as

$$\frac{d\sigma}{dp_T}=\frac{N}{L \Delta p_T \epsilon A}$$

where $N$ is a fit parameter that says how many events are under the signal function, $\Delta p_t$ is the width of the bin in $p_T$ (i.e. the width of cut on the trasverse momentum), $\epsilon$ the efficiency and $A$ the acceptance. A more detailed description of the functions used it can be found in [diffCrossSection.h].

Testing

Since the program is built with CMake, the testing was performed using CTest. A brief description of each test is presented below. To run the test, one must move inside the build folder and run the simple command ctest.

$ cd build
$ ctest

It is important to compile the program first, otherwise the test executable are not created, and the build folder will not be there in first place...

Test 0

Test0 handles the reading of the command arguments and flags. In this test one define some variables, call the processArgs() and sees if the definition stands, then one modify the arguments and check if the options are evolved according to the made changes.

Test 1

Here is tested the online reading of the data and the behavior in case the Data folder or the Data file is missing. In the test, the folder Data is deleted and the function df_set() is called. This function should handle the creation of the folder Data and the downloading and saving of the data. Once finished this first step, we check if the Data folder exists and if it contains the file data.root Next, we keep the folder Data and we eliminate the file data.root. The function df_set() is called again and after it finished, one check if the data is successfully recreated.

Test 2

In this test the fit results are controlled. First off, one defines a model with a similar shape to the one expected and calls the function fitRoo() passing this model as an argument instead of the real data. The test checks if the fit converged by looking at the fitStatus and also check if the returned parameters are inside 5 sigma of the initial value.

Test 3

This one tests the function SavePlot() which handles the saving of a canvas with a specific filename. If the folder Plots does not exist, it creates it.

Test 4

This test is useful to check if the printing of the custom cuts on the canvas work. It compares the strings returned by the function formatYString() or formatPtString() with the expected ones.

Documentation

The documentation of this project is built with Doxygen. The online page of this documentation is built via Continous Integration and Github Actions, through a .yml file in the .github/workflow folder.

Documentation Hell

Coding Style Options

The styling of the code files is formatted and checked using the library clang-format, using the guidelines provided by the ROOT official page.