Skip to main content

Library for calibrating flavour tagging algorithms at LHCb

Project description

lhcb_ftcalib

pipeline status

LHCb Flavour Tagging calibration software

At high-energy proton-proton collider experiments, the production flavour of neutral B mesons needs to be reconstructed from particle charges from hadronisation processes in the associated event, i.e. from additional hadronisations on the signal meson side, as well as hadronisation and decays of the partner B hadron. This is commonly done with ML techniques like (recurrent) neural networks or boosted decision trees. The mistag probability estimates of these models (probability that predicted production flavour is wrong) usually need to have the property of probabilities. This calibration tool optimizes a GLM function to predict the mistag probabilities and takes into account the fact that neutral mesons can undergo oscillation before they decay. In addition, it provides helper functions to measure the performance and correlations of these models.

Documentation: Read the Docs

Installation

pip install lhcb_ftcalib

Command Line Interface Examples

Run ftcalib --help for a list of all options or read the docs

1. Calibrating opposite side taggers in a sample and saving result

ftcalib file:tree -OS VtxCh Charm OSElectronLatest OSMuonLatest OSKaonLatest \
        -mode Bd -tau B_tau -id B_ID -op calibrate -out output

2. Calibrating both tagging sides, combining them inidividually, and calibrating+saving the results

ftcalib file:tree -OS VtxCh Charm OSElectronLatest OSMuonLatest OSKaonLatest \
        -SS SSPion SSProton \
        -mode Bd -tau B_tau -id B_ID -op calibrate combine calibrate -out output

Note: The command line interface is by design not feature complete. Use the API to fine tune the calibration settings.

Requirements

  • uproot >= 4
  • iminuit >= 2.3.0
  • pandas
  • numpy
  • scipy
  • matplotlib
  • numba == 0.53.1

For developers

Testing multiple python versions via tox

Click to expand

To test lhcb_ftcalib in different python environments, interpreters for each version need to be installed. Multiple python versions can be installed with pyenv:

CC=clang pyenv install 3.6.15
pyenv install 3.7.13
pyenv install 3.8.13
pyenv install 3.9.13
pyenv install 3.10.5

Whereby only missing versions need to be installed! Note that python 3.6 has issues with pip throwing segfaults if not built with clang. To make the newly installed versions globally available run

pyenv global 3.6.15 3.7.13 3.8.13 3.9.13 3.10.5

and add $HOME/.pyenv/shims to your PATH. To run the basic tests, execute

tox

in the lhcb_ftcalib directory

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

lhcb_ftcalib-1.2.8.tar.gz (148.6 kB view details)

Uploaded Source

Built Distribution

lhcb_ftcalib-1.2.8-py3-none-any.whl (69.6 kB view details)

Uploaded Python 3

File details

Details for the file lhcb_ftcalib-1.2.8.tar.gz.

File metadata

  • Download URL: lhcb_ftcalib-1.2.8.tar.gz
  • Upload date:
  • Size: 148.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.62.3 importlib-metadata/4.11.1 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.10

File hashes

Hashes for lhcb_ftcalib-1.2.8.tar.gz
Algorithm Hash digest
SHA256 308c234bd2b90a1ac9b3171c7dfb7c1ea606fe5e913cdee7f36b670fb23b7ec4
MD5 23c3e01eed1cce641139941e095008c3
BLAKE2b-256 a9f7e3dceda4ddff803190d7494148982944834b9d8bc2c7e7f208b9d03c18c7

See more details on using hashes here.

File details

Details for the file lhcb_ftcalib-1.2.8-py3-none-any.whl.

File metadata

  • Download URL: lhcb_ftcalib-1.2.8-py3-none-any.whl
  • Upload date:
  • Size: 69.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.62.3 importlib-metadata/4.11.1 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.10

File hashes

Hashes for lhcb_ftcalib-1.2.8-py3-none-any.whl
Algorithm Hash digest
SHA256 91e2b4d8d820ea48cb1a394c7685d22d8cf07e28f20d7d5de3be1da496471670
MD5 321c2d5db5b2f008acf7f3a6c681375b
BLAKE2b-256 6a9e3e4d75aa678ba724cbbf01b8068eb1895efb57e11eb0cb9e8e3bd83ccdc9

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page