Heavy Meson Analysis
Last updated
Last updated
Particles like the , , and decay in a similar way into two oppositly charged pions and a neutral decay meson, that can either be a neutral pion, or in the case of the an meson.
These analyses share a common analysis task: AliAnalysisTaskNeutralMesonToPiPlPiMiPiNeutralMeson.cxx and can use the same script of the afterburner with different settings for the different mesons and involved NDM.
For the 7 and 13 TeV analysis of the meson, this was done using a post-processing chain explained on the bottom of this page. Since then, a second version (V2) was created, which is explained in this section:
The entire post-processing from the signal extraction up to the production of the final results is managed be the start_FullPiPlPiMiNDMAnalysis.sh macro. Different parameters can be used to trigger different parts of the analysis chain:
-e triggers the extraction of the raw yield in data in ExtactSignalPiPlPiMiPiZeroV2.C
-f triggers the full analysis, which includes the signal extraction in both data and MC using ExtactSignalPiPlPiMiNDMV2.C, as well as the correction of the yield using CorrectSignalPiPlPiMiNDMV2.C
-p triggers the plotting of all monitoring plots using PiPlPiMiNDMMonitoring.C
-c triggers a cutstudy, comparing the extracted histograms for the different cutsettings
-s triggers the calculation of the systematic uncertainties, however, this script will have to be very much personalized for each analysis
-b triggers the combination of the spectra from the different NDM reconstruction methods using the blue method
-r triggers the calculation and plotting of the final results
-d activated the debug mode, in which only one cutstring will be run for code debugging
-0 switches on the analysis of the
-h or simply no argument at all will display a short explaination and a list of the possible arguments
Analysis settings and data paths are specified in CutSelection.csv, included as a template in your Afterburner package. Every row of this table corresponds to one analysis/variation, for which the signal extraction and correction is performed. The systematics and combination are then done based on the entire table.
The first column states, whether a given row should be analyzed or simply ignored. To have the analysis run over a given row simply put an x or similar as the first entry. The second column is used to cluster different cuts into groups of systematic uncertainties, but this is only needed in for the calculation of the systematic uncertainties, so we will ignore this column for now. The next fields are pretty self explainatory: The analysed energy, meson, data and MC period, as well as the paths to the LEGO train output. Then you have to give the Trainconfig and enter a cutnumber included in the file. The next field asks for a ExtractionCutnumber, which is a five digit number, that similar to the established cutstring sets different parameters for the signal extraction. For details on this, please have a look at the PiPlPiMiNDM.h file, in which the different possible parameters are then set, based on the ExtractionCutnumber. The default setting is 00000. The next field asks for the PhotonMode, which you can take from the following table:
60
PCM-PCM
61
PCM-EMCal
62
PCM-PHOS
63
PCM-DCal
64
EMCal-EMCal
65
PHOS-PHOS
66
DCal-DCal
67
PCM-Dalitz
68
EMcal-Dalitz
69
PHOS-Dalitz
70
DCal-Dalitz
After configuring the analysis parameters and data paths in the CutSelection.csv for you analysis, all you have to do to get your corrected cross-sections and everything else is:
The following files are part of the NDM post-processing chain:
ExtractSignalPiPlPiMiNMDV2.C: Transforms the train output into raw meson yields - applied to both data and MC
CorrectSignalPiPlPiMiNMDV2.C: Combines the raw data and MC yields to create a corrected yield and cross-section
PiPlPiMiNDM.h: General heavy meson header file including the mass ranges to be set for each meson and energy
PiPlPiMiNDMMonitoring.C: Plotting of the signal extraction and correction (inv. mass bins, efficiency, S/B, ...)
CutStudiesPiPlPiMiPiZero.C: Compares the output from the signal extraction and correction script for all cutstrings in the CutSelection.csv file
SystematicsPiPlPiMiPiZero.C: Calculates the systematic uncertainty for the 5TeV pp and pPb omega analysis - here, every analysis will need its own file
CombineSignalPiPlPiMiPiZero.C: Combines the corrected yields/cross sections from different photon reconstruction methods using the BLUE method
In case either the data- or MC-file is missing, you can just pass the macro a dummy string. E.g the command
If you start the start_FullOmegaAnalysis.sh macro by hand, you will be asked about several things needed for the signal extraction and correction. The questions are similar to the ones asked e.g. by start_FullMesonAnalysis_TaskV3.sh, however there are some differences, so we will go through the questions one-by-one in the following chapter.
First we start the macro using (e.g.):
40
PCM-PCM
41
PCM-EMCal
42
PCM-PHOS
43
PCM-DCal
44
EMCal-EMCal
45
PHOS-PHOS
46
DCal-DCal
47
PCM-Dalitz
48
EMcal-Dalitz
49
PHOS-Dalitz
50
DCal-Dalitz
This information will later be used by the signal extraction macro to check if your choice is actually consistent with the input files you provided. After you entered the desired mode, you will be asked
If you select no, the macro will write all the cut strings found in the input file in a file called CutSelection.log sperated by [ENTER] (using the MakeCutLog.C macro) and then run the signal extraction (and correction) for each cut string in that file. If you select yes, the macro will search for an existing CutSelection.log file in the current working directory and run the afterburners for all cut strings contained in that file. This option is therefore useful if you just want to run the afterburners on a particular set of cut strings.
Let's assume we want to run the afterburners on all the cuts contained in the input file, so we answer with "no". The output should look something like this:
Make sure that the macro detected all the cuts correctly and proceed by entering the collision system you are analysing. In this example, we will choose pp@7Tev.
Example usage (Data):
Example usage (MC):
Finally you can enter a description used for some plotting and comparison purposed (cutstudies), and the range, in which the signal is to be extracted. The binning has to be set per energy and meson in ExtractSignalBinning.h.
ProduceFinalResultsPiPlPiMiNDM.C: Plots the cross-sections, and NDM/ ratio
Because the and the can both decay into , the analysis in this decay channel is organized in a single analysis task: AliAnalysisTaskNeutralMesonToPiPlPiMiPiZero.cxx.
Analogue to the neutral pion analysis, there is a single macro that starts the first afterburners needed to process the output files of the task. The start_FullOmegaMesonAnalysis.sh macro -- even though the name might be misleading -- takes care of the signal extraction (using ExtactSignalPiPlPiMiPiZero.cxx) and its correction (using CorrectSignalPiPlPiMiPiZero.cxx) for and .
will run the signal extraction macro two times -- once for the and once for the -- but won't run the correction macro afterwards, because it detected that you didn't provide it with a valid MC file.
There are several options available for this macro (which are still work in progress) that let you e.g. only analyse the (--omegaOnly) or the (--etaOnly). For a full list of available options please use the -h flag.
First, the macro will print the full path of the input files you specified. This comes in handy to track down if you got something wrong while using e.g. relative paths. The first thing you will be asked is to specify the method (mode) used to reconstruct the decay-photons of the :
As you may have noticed, the mode numbers used for this analyisis differ from the ones used for the -analysis. This was implimented to avoid any conflicts between the two analysis (e.g. between and ). The modes currently implemented are marked with a '*'. For the sake of completeness, you can find a nicely formated table of the numbering scheme used in this analysis below:
After the collision system was selected, you have to specify how many -bins should be analysed. This question is a bit misleading, because you are actually specifying up to what index in your -bin array stored in ExtractSignalBinning.h you want to do the analysis. The total number of analysed bins would then be . Important: Make sure that the -bin choosen here is not actually greater than the length of the array containing your binning for this analysis (see ExtractSignalBinning.h) ! Also: At the moment only the use of same number of bins for and are supported.
After choosing the desired fitting function for the / -peak (using gaussian is recommended, no testing was done for crystal ball so far), you will be asked if you are sure to process all cuts. After confirming this final question, the afterburners should go to work!
This macro is used to extract the invariant mass distribution of the meson signal for each analyzed -bin and its usage and tasks are almost identical to ExtractSignalV2.C. You can start the macro using:
The following macros that allow further processing of the extracted signals have been implemented for / analysis so far: