Changes between Version 3 and Version 4 of SFS


Ignore:
Timestamp:
Jun 9, 2020, 1:20:16 PM (5 years ago)
Author:
jackaraz
Comment:

--

Legend:

Unmodified
Added
Removed
Modified
  • SFS

    v3 v4  
    22== Simplified - Fast Simulation (SFS) of detector response ==
    33
    4 This page contains a brief introduction about the usage of SFS machinery, for details, please see [CITE]. SFS machinery allows the user to simulate detector response within !MadAnalysis 5 framework using only !FastJet libraries. Although we provide default ATLAS and CMS cards which are validated against corresponding !Delphes cards for four different physics process, this introduction will provide all information that is needed to use SFS machinery for any homebrew detector simulation.
     4This page contains a brief introduction about the usage of SFS machinery, for details, please see [CITE]. SFS machinery allows the user to simulate detector response within !MadAnalysis 5 framework using only !FastJet libraries. It is fully integrated with [http://madanalysis.irmp.ucl.ac.be/wiki/PublicAnalysisDatabase Public Analysis Database], and the user can recast experimental analyses using SFS' fast interface, for details, please see below. Although we provide default ATLAS and CMS cards which are validated against corresponding Delphes cards for four different physics process, this introduction will provide all information that is needed to use SFS machinery for any homebrew detector simulation.
    55
    6 * Prerequisites: only !FastJet
     6* Prerequisites: !FastJet
    77{{{
    8 $> ./bin/ma5 -R
     8$>   ./bin/ma5 -R
    99ma5> install fastjet
     10ma5> set main.fastsim.package = fastjet
    1011}}}
    1112
    12 SFS contains three submodules, namely `reco_efficiency`, `smearer` and `tagger`. These submodules set a probability distribution to reconstruct a given object, smear gave objects four-momentum using normalized Gaussian function and sets identification efficiencies respectively. The goal is to create a CPU efficient, user-friendly, easy-to-use and inclusive environment. Thus given transfer functions are translated into C++ functions to act on reconstructed final state objects such as jets, hadronic taus, electrons, muons and photons. It is also possible to manipulate jet constituents for substructure analyses which are described below.
     13First-line activates the `RECO` mode for !MadAnalysis 5 framework, the second line is to install !FasJet interface and finally last line activates the !FastJet interface for the corresponding session. User can set the desired reconstruction algorithm as before, please see [https://arxiv.org/abs/1808.00480 arXiv:1808.00480] for details on the usage of !FastJet module in !MadAnalysis 5. SFS contains three submodules, namely `reco_efficiency`, `smearer` and `tagger`. These submodules set a probability distribution to reconstruct a given object, smear given object's four-momentum using normalized Gaussian functions and sets identification efficiencies respectively. The goal is to create a CPU efficient, user-friendly, easy-to-use and generic environment. Thus given transfer functions are translated into C++ functions to act on reconstructed final state objects such as jets, hadronic taus, electrons, muons and photons.
    1314
     15Jet reconstruction contains two possible options, namely jet smearing and substructure smearing. These options can be set via
     16{{{
     17ma5> set main.fastsim.jetrecomode = <opt>
     18}}}
     19where `<opt>` represents user-defined input which can either be `jets` or `constituents` (default `jets`).  `jets` option allows the `reco_efficiency` and `smearer` submodules to act on clustered jet objects. The latter option, `constituents`, enables the possibility to apply detector response at the hadron level.
    1420
    1521== Reconstruction Efficiencies ==
     
    2026ma5> define reco_efficiency <obj> <func> [<domain>]
    2127}}}
    22 where `<obj>` represents the desired object to be reconstructed, `<func>` is the transfer function which can depend on any observable like `PT`, `E`, `ETA`,`ABSETA`,`PHI` etc. `<func>` can also include any functional forms like trigonometric or hyperbolic functions. `<dom>` represents the domain where this function lives. It creates a piecewise function to construct probability distribution for the given object. This piece of input will generate a probability distribution for the desired object to decide if its going to be used in the analysis or not.
     28where `<obj>` represents the desired object to be reconstructed, `<func>` is the transfer function which can depend on any observable like `PT`, `E`, `ETA`,`ABSETA`,`PHI` etc. which are defined in !MadAnalysis 5's interface. `<func>` can also include any functional form like trigonometric or hyperbolic functions. `<dom>` represents the domain where defined function will be active. The module creates a piecewise function to construct a probability distribution for the given object. This piece of input will generate a probability distribution for the desired object to decide if it's going to be used in the analysis or not.
    2329
    2430Example:
     
    2834ma5> define reco_efficiency e 0.55  [pt > 10.0 and abseta > 1.5 and abseta <= 2.5]
    2935}}}
    30 Here we exemplify an electron reconstruction efficiency where an electron object will not be reconstructed if it has less than 10 GeV transverse momentum or its pseudorapidity is above 2.5. Additionally, it will be reconstructed with 70% probability if it's within |\eta| < 1.5 and pT >= 10 GeV and with 55% probability if its between 1.5 < |\eta| <= 2.5. Domain inputs has to be separated with `and` or `or` keywords to be effective.
    31 
    32 
     36Here we exemplify an electron reconstruction efficiency where an electron object will not be reconstructed if it has less than 10 GeV transverse momentum or its pseudorapidity is above 2.5. Additionally, it will be reconstructed with 70% probability if it's within |\eta| < 1.5 and pT >= 10 GeV and with 55% probability if its between 1.5 < |\eta| <= 2.5. Domain inputs have to be separated with `and` or `or` keywords to be effective, `and` enforces all domain conditions to be true and `or` requires at least one domain to be true.
    3337
    3438== Object Smearing ==
    3539
     40Here we introduce the smearing function which uses a user-defined standard deviation function which can depend on any observable given in !MadAnalysis 5's framework. This function can be, again, defined in a piecewise manner in order to have different sensitivities to different phase-spaces. This submodule can be defined as follows;
     41{{{
     42define smearer <obj> with <var> <func> [<dom>]
     43}}}
     44Here `<obj>` stands for the object to be smeared, `<var>` is the variable to be smeared which can be `E`, `PT`, `PX`, `PY`, `PZ`, `PHI` and `ETA`. `<func>` and `<dom>` are, as defined above, stands for the function and the domain that this function will be active. Note that `<obj>` and `<var>` are separated with the keyword `with`.
    3645
     46Example:
     47{{{
     48ma5> define smearer j with PT sqrt(0.06^2 + pt^2*1.3e-3^2) [abseta <= 0.5 and pt > 0.1]
     49ma5> define smearer j with PT sqrt(0.1^2  + pt^2*1.7e-3^2) [abseta > 0.5 and abseta <= 1.5 and pt > 0.1]
     50ma5> define smearer j with PT sqrt(0.25^2 + pt^2*3.1e-3^2) [abseta > 1.5 and abseta <= 2.5 and pt > 0.1]
     51}}}
     52Here we exemplified transverse momentum smearing of the jet object. This function simply generates a standard deviation which depends on `PT` of the given jet. This STD will be further used in a normalized Gaussian function to simulate the uncertainty on the transverse momentum observation. The transverse momentum then shifted within the Gaussian width.
    3753
    3854== Particle Identification ==
    3955
     56`tagger` submodule is used to set particle identification or misidentification efficiencies for desired objects. It can be defined as follows;
     57{{{
     58ma5> define tagger <true> as <reco> <func> [<dom>]
     59}}}
     60
     61where `<true>` stands for the true object that will be reconstructed as `<reco>` object. If `<true>` and `<reco>` objects are same, the module will apply efficiency to reconstruct the given object. If, on the other hand, the `<true>` and `<reco>` objects are different, the module will apply misidentification efficiency on the `<true>` object. This submodule can be used on jets (`j`, `21`), b-jets (`b` , `5`), c-jets (`c`,`4`), electrons (`e`, `11`), muons (`mu`,`13`), hadronic taus (`ta`,`15`) or photons (`a`,`22`) where within certain physical limitations each object can be reconstructed as other objects, please see [CITE] for the available options.
     62
     63Example:
     64{{{
     65ma5> define tagger j as ta 0.01 [ntracks >= 2 and abseta <= 2.7]
     66ma5> define tagger j as ta 0.02 [ntracks == 1 and abseta <= 2.7]
     67ma5> define tagger j as ta 0.0  [abseta > 2.7]
     68
     69ma5> define tagger b as b 0.80*tanh(0.003*pt)*(30/(1+0.086*pt))
     70}}}
     71Here first three examples show the jet misidentification as a hadronic tau object where it can be misidentified with respect to the number of prongs inside the jet. The last line shows the b-jet tagging efficiency, which depends on its transverse momentum.
    4072
    4173
    4274== SFS in Expert Mode ==
    4375
     76SFS machinery can be used with expert mode as well. User can set up a detector card with the desired options which are exemplified above and give to !MadAnalysis as input;
     77{{{
     78$> ./bin/ma5 -Re <folder_name> <analysis_name> <SFS_card>
     79}}}
     80To use the SFS machinary in expert mode, the expertmode has to be initialized alongside with `RECO` mode. `<folder_name>` is optional input to create the analysis folder, `<analysis_name>` is, again, optional to write a null analysis file with given name and finally the optional `<SFS_card>` generates the detector environment for the analysis and the detector effects will be applied live during the analysis.
    4481
    4582