== Simplified - Fast Simulation (SFS) of detector response == 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. 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. * Prerequisites: !FastJet {{{ $> ./bin/ma5 -R ma5> install fastjet ma5> set main.fastsim.package = fastjet }}} First-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. Jet reconstruction contains two possible options, namely jet smearing and substructure smearing. These options can be set via {{{ ma5> set main.fastsim.jetrecomode = }}} where `` 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. == Reconstruction Efficiencies == This submodule can be used on jets (`j`, `21`), electrons (`e`,`11`), muons (`mu`,`13`), hadronic taus (`ta`,`15`) or photons (`a`,`22`). It simply takes three input; {{{ ma5> define reco_efficiency [] }}} where `` represents the desired object to be reconstructed, `` 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. `` can also include any functional form like trigonometric or hyperbolic functions. `` 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. Example: {{{ ma5> define reco_efficiency e 0.0 [pt <= 10.0 or abseta > 2.5] ma5> define reco_efficiency e 0.7 [pt > 10.0 and abseta <= 1.5] ma5> define reco_efficiency e 0.55 [pt > 10.0 and abseta > 1.5 and abseta <= 2.5] }}} 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 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. == Object Smearing == Here 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; {{{ define smearer with [] }}} Here `` stands for the object to be smeared, `` is the variable to be smeared which can be `E`, `PT`, `PX`, `PY`, `PZ`, `PHI` and `ETA`. `` and `` are, as defined above, stands for the function and the domain that this function will be active. Note that `` and `` are separated with the keyword `with`. Example: {{{ ma5> define smearer j with PT sqrt(0.06^2 + pt^2*1.3e-3^2) [abseta <= 0.5 and pt > 0.1] ma5> 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] ma5> 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] }}} Here 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. == Particle Identification == `tagger` submodule is used to set particle identification or misidentification efficiencies for desired objects. It can be defined as follows; {{{ ma5> define tagger as [] }}} where `` stands for the true object that will be reconstructed as `` object. If `` and `` objects are same, the module will apply efficiency to reconstruct the given object. If, on the other hand, the `` and `` objects are different, the module will apply misidentification efficiency on the `` 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. It is important to note that `` and `` are separated by the keyword `as`. Example: {{{ ma5> define tagger j as ta 0.01 [ntracks >= 2 and abseta <= 2.7] ma5> define tagger j as ta 0.02 [ntracks == 1 and abseta <= 2.7] ma5> define tagger j as ta 0.0 [abseta > 2.7] ma5> define tagger b as b 0.80*tanh(0.003*pt)*(30/(1+0.086*pt)) }}} Here 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. The algorithm gives the importance to first b-jets, where if a jet is mistagged as c-jet it won't be mistagged as b, tau, electron or photon. Similar order goes for all other objects, we simply set the importance as follows b > c > tau > muon > electron > photon which means that if a jet is mistagged as any of the objects on this sequence it won't be mistagged as the following objects. == SFS in Expert Mode == SFS 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; {{{ $> ./bin/ma5 -Re }}} To use the SFS machinery in expert mode, the expert mode has to be initialized alongside with `RECO` mode. `` is optional input to create the analysis folder, `` is, again, optional to write a null analysis file with the given name and finally the optional `` generates the detector environment for the analysis and the detector effects will be applied live during the analysis. == LHC Recasting with SFS == SFS machinery can be used for LHC recasting. Details on how to write an analysis for [http://madanalysis.irmp.ucl.ac.be/wiki/PublicAnalysisDatabase Public Analysis Database] can be found [https://madanalysis.irmp.ucl.ac.be/wiki/WritingAnalyses here]. User should initialize the code with PDGIDs for hadrons and invisible particles as follows; {{{ PHYSICS->mcConfig().Reset(); PHYSICS->mcConfig().AddHadronicId(); PHYSICS->mcConfig().AddInvisibleId(); }}} a suggested list can be found