Skip to content
Snippets Groups Projects
CONTRIBUTING.md 11.3 KiB
Newer Older
Michal Kreps's avatar
Michal Kreps committed
# Steps to add decay file
1. Find if a DecFile you want (or similar enough so you can use it) already exists
1. Read the [event type numbering convention](https://cds.cern.ch/record/855452?ln=en). There is [an unofficial tool](http://lbeventtype.web.cern.ch/) to assist with creating an event type, but keep in mind that it is not a substitute for the documentation.
Michal Kreps's avatar
Michal Kreps committed
1. If you are using an old DecFile as a template, note that it might not follow the established conventions.
1. Test your DecFile (both that it runs and that it produces output you want)
1. Commit to branch and create merge request against master.
1. Open your merge request in web browser and check that all tests are successful. If anything fails, please correct and recheck again day after commit. If you do not understand failure, get in touch with [lhcb-gauss-manager@cernNOSPAMPLEASE.ch](mailto://lhcb-gauss-manager@cernNOSPAMPLEASE.ch)
1. Make sure the CI test *pass*. Make sure no warnings / errors pop up, if they do then either fix it, or understand it and add a comment in the MR on why this popped up. See below for more information about the CI test. 
1. Watch discussion in merge request for any comments we might have.

# Branch to use
For new decay files to be used in Sim09 productions, one should target `master` branch.
The decay files which are meant only for Sim10 should target `Sim10` branch.
If the decay file should be available in both Sim09 and Sim10 and will work without modifications in both branches, target `master` branch and make note in MR that it is required also in Sim10 (While decay files are regularly copied to Sim10 from Sim09, comment will tell that we should do it without delay).
# Correct Descriptor usage in DECfiles
A DECfile is using the EvtGen Descriptors syntax, see Gen/DecFiles/scripts/evt.pdl for naming conventions.
This EvtGen syntax is used:
1. In the second line of your DECfile (starting with 'Descriptor:')
1. For the actual definition of your decay in the lower half of your DECfile. (starting with 'Alias', etc.)

If you are using generator level cuts in a python-code insertion, you have to use the [DecayDescriptor syntax](https://twiki.cern.ch/twiki/bin/view/LHCb/FAQ/LoKiNewDecayFinders#Grammar_in_short) for this part:
1. Especially the correct usage of arrows (->, =>, ==>, etc.)  in tightCut.Decay = '[...]' is important.
Michal Kreps's avatar
Michal Kreps committed
# Testing a decay file
 This is done in three steps:
## Write the decay file and create the options
If you do not already have the environment set up, prepare it to run one of the latest Gauss version (v49rX for Sim09 productions, or v50rX for upgrade productions). In the examples below, v49r17 is used (please use LbEnv due to making package ready for python3).
Michal Kreps's avatar
Michal Kreps committed
```shell
lb-set-platform x86_64-slc6-gcc49-opt 
lb-dev Gauss/v49r25
cd ./GaussDev_v49r25
Michal Kreps's avatar
Michal Kreps committed
Then get the Gen/DecFiles package from gitlab.
```shell
Michal Kreps's avatar
Michal Kreps committed
```

**NB** if you need a different branch, pass `-b`, e.g.:
```shell
git lb-clone-pkg Gen/DecFiles -b Sim10
```

Michal Kreps's avatar
Michal Kreps committed
Add the new decay file in the dkfiles subdirectory and create the options to be used by Gauss.
```shell
Michal Kreps's avatar
Michal Kreps committed
```
If there is no mistake in the decay file, an option file called NNNNNNNN.py is present in the options subdirectory, where NNNNNNNN is the event type number of the decay file.  It is also recommended to run the decay file convention parser
```shell
Michal Kreps's avatar
Michal Kreps committed
./decparser.sh ../dkfiles/DecFile.dec
```
This should check for convention correctness for the event type and some basic mistakes, but it also has some limitations. This is our tool to help in checking, but at the end all failures are individually considered. Feel free to email any comments to lhcb-gauss-manager.  
## Run Gauss to create a .xgen file 
The .xgen file contains the generator level information (both in HepMC and MCParticles format) when running Gauss with only the generator part, without the simulation and Geant4 being activated.
```shell
lb-set-platform x86_64-slc6-gcc49-opt 
gaudirun.py $GAUSSOPTS/Gauss-Job.py $GAUSSOPTS/Gauss-2016.py $GAUSSOPTS/GenStandAlone.py \
            $DECFILESROOT/options/NNNNNNNN.py $LBPYTHIA8ROOT/options/Pythia8.py
```

Michal Kreps's avatar
Michal Kreps committed
The number of events to generate (5 by default) is set in the Gauss-Job.py file.  Gauss will then produce a file called by default Gauss-NNNNNNNN-5ev-YYYYMMDD.xgen, with a name formed from the event type (NNNNNNNN), the number of events (5ev by default) and the day (in format YYYYMMDD).  
The above command includes spillover, which you should use for timing of your event type. If for development reasons you want to remove spillover, you can use $GAUSSOPTS/Gauss-Dev.py instead of $GAUSSOPTS/Gauss-2016.py.
Michal Kreps's avatar
Michal Kreps committed
## Create a MCDecayTreeTuple from the .xgen file
Use DaVinci to read the file produced by Gauss and to create a ROOT file with the information from the generator level history.
```shell
lb-run -c best DaVinci/v45r4 gaudirun.py tupleResult.py
Michal Kreps's avatar
Michal Kreps committed
```
where tupleResult.py contains
```python
from Configurables import (
    DaVinci,
    EventSelector,
    PrintMCTree,
    MCDecayTreeTuple
)
from DecayTreeTuple.Configuration import *

"""Configure the variables below with:
decay: Decay you want to inspect, using 'newer' LoKi decay descriptor syntax,
decay_heads: Particles you'd like to see the decay tree of,
datafile: Where the file created by the Gauss generation phase is, and
year: What year the MC is simulating.
"""

# https://twiki.cern.ch/twiki/bin/view/LHCb/FAQ/LoKiNewDecayFinders
decay = "[B0 => ^(Lambda_c~- ==> ^p~- ^K+ ^pi-) ^p+ ^pi- ^pi+]CC"
decay_heads = ["B0", "B~0"]
datafile = "Gauss-11166070-5ev-20140429.xgen"
year = 2012

# For a quick and dirty check, you don't need to edit anything below here.
##########################################################################

# Create an MC DTT containing any candidates matching the decay descriptor
mctuple = MCDecayTreeTuple("MCDecayTreeTuple")
mctuple.Decay = decay
mctuple.ToolList = [
    "MCTupleToolHierarchy",
    "LoKi::Hybrid::MCTupleTool/LoKi_Photos"
]
# Add a 'number of photons' branch
mctuple.addTupleTool("MCTupleToolKinematic").Verbose = True
mctuple.addTupleTool("LoKi::Hybrid::TupleTool/LoKi_Photos").Variables = {
    "nPhotos": "MCNINTREE(('gamma' == MCABSID))"
}

# Print the decay tree for any particle in decay_heads
printMC = PrintMCTree()
printMC.ParticleNames = decay_heads

# Name of the .xgen file produced by Gauss
EventSelector().Input = ["DATAFILE='{0}' TYP='POOL_ROOTTREE' Opt='READ'".format(datafile)]
Michal Kreps's avatar
Michal Kreps committed

# Configure DaVinci
DaVinci().TupleFile = "DVntuple.root"
DaVinci().Simulation = True
DaVinci().Lumi = False
DaVinci().DataType = str(year)
DaVinci().UserAlgorithms = [printMC, mctuple]
```
If you get the error
```
ToolSvc.OdinTim...  FATAL ODINDecodeTool:: Exception throw: Cannot find RawEvent in [Trigger/RawEvent, DAQ/RawEvent] StatusCode=FAILURE
```
try adding this to your file (copied from https://gitlab.cern.ch/lhcb/Bender/blob/master/Phys/BenderTools/python/BenderTools/GenFiles.py):
```python
Wenqian Huang's avatar
Wenqian Huang committed
from Gaudi.Configuration import appendPostConfigAction
Michal Kreps's avatar
Michal Kreps committed
def doIt():
    """
    specific post-config action for (x)GEN-files 
    """
    extension = "xgen"
    ext = extension.upper()

    from Configurables import DataOnDemandSvc
    dod  = DataOnDemandSvc ()
    from copy import deepcopy 
    algs = deepcopy ( dod.AlgMap ) 
    bad  = set() 
    for key in algs :
        if     0 <= key.find ( 'Rec'     )                  : bad.add ( key )
        elif   0 <= key.find ( 'Raw'     )                  : bad.add ( key )
        elif   0 <= key.find ( 'DAQ'     )                  : bad.add ( key )
        elif   0 <= key.find ( 'Trigger' )                  : bad.add ( key )
        elif   0 <= key.find ( 'Phys'    )                  : bad.add ( key )
        elif   0 <= key.find ( 'Prev/'   )                  : bad.add ( key )
        elif   0 <= key.find ( 'Next/'   )                  : bad.add ( key )
        elif   0 <= key.find ( '/MC/'    ) and 'GEN' == ext : bad.add ( key )
        
    for b in bad :
        del algs[b]
            
    dod.AlgMap = algs
    
    from Configurables import EventClockSvc, CondDB 
    EventClockSvc ( EventTimeDecoder = "FakeEventTime" )
    CondDB  ( IgnoreHeartBeat = True )
    
appendPostConfigAction( doIt )
```

# Efficiency of generator level cuts
This number can be extracted from the GeneratorLog.xml file (produced by your gauss job), where the printout is of the form
```xml
<efficiency name = "generator level cut">
    <after> 5 </after>
    <before> 27 </before>
    <value> 0.18519 </value>
    <error> 0.074757 </error>
  </efficiency>
```
the efficiency is therefore 5/27 in this example.


# Commiting a decay file
Pre-requisite: have account on gitlab.cern.ch 
You must commit your decay file to separate branch and create merge request against master branch. It is recommended that you check out a clean version
```shell
git lb-clone-pkg  Gen/DecFiles
cd Gen/DecFiles
git checkout -b ${USER}/my-changes
```
Copy your decfile(s) into `dkfiles/` and add them to commit
```shell
git add dkfiles/[your decfile]
```
Michal Kreps's avatar
Michal Kreps committed
```shell
git status 
git commit #(with a commit message of what you updated)
Michal Kreps's avatar
Michal Kreps committed
git push -u origin ${USER}/my-changes
```
Go to [gitlab.cern.ch](https://gitlab.cern.ch/lhcb-datapkg/Gen/DecFiles) and create merge request. 
Michal Kreps's avatar
Michal Kreps committed
If you find out that something in merge request needs to be updated, just commit and push to the same branch and merge request will automatically update.
There is no need to close merge request and start new one and it is discouraged as it splits discussion.

# Automatic testing of a decay file
When you create merge request or update with new commit, automatic test will be performed. You can find results of the test directly on gitlab page of your merge request under text like "Pipeline #nnnnnnn passed/failed ..." You can click on it and see details of all tests. Three things are done in this test, generating option files, running decparser and running Gauss itself for few events. If you see a failure, please fix issue. If you do not understand failure, get in touch with [lhcb-gauss-manager@cernNOSPAMPLEASE.ch](mailto://lhcb-gauss-manager@cernNOSPAMPLEASE.ch). The merge requests cannot be merged until it passes tests and do not assume that somebody will remind that it needs to be done (or fix it behind the scenes).
The CI test contains three states when it parses the DecFile:
1. Errors
2. Warnings
3. Cautions

Errors represent important failures, and should almost always be fixed before it gets merged. These are picked up by the CI test and will result in a failed CI output (red X), and are represented in red in the logs. If you are sure that the error is well understood, leave a comment explaining so.

Warnings represent important information and should be fixed before it gets merged, but is less dangerous then the errors. THese will result in a passed with warning CI output (yellow !), and are represented as orange warnings in the log.  If you are sure that the error is well understood, leave a comment explaining so.

Cautions are information that might be nice to fix, but won't block merges if they occur. THey will result with a passed CI output, and represented in a passed CI output (green tick), and are represented with a yellow caution in the log. 

Michal Kreps's avatar
Michal Kreps committed
# Potential issues
If you see problem with "Inclusive&Marked decay in LoKi", try to check https://gitlab.cern.ch/lhcb/LHCb/-/issues/113 and possibly look to example how it was resolved at https://gitlab.cern.ch/lhcb-datapkg/Gen/DecFiles/-/merge_requests/775.