Skip to main content

ATLAS Flavour Tagging Tools

Project description

Code style: black PyPI version codecov

ATLAS FTAG Python Tools

This is a collection of Python tools for working with files produced with the FTAG ntuple dumper. The code is intended to be used a library for other projects. Please see the example notebook for usage.

Quickstart

Installation

If you want to use this package without modification, you can install from pypi using pip.

pip install atlas-ftag-tools

To additionally install the development dependencies (for formatting and linting) use

pip install atlas-ftag-tools[dev]

Development

If you plan on making changes to teh code, instead clone the repository and install the package from source in editable mode with

python -m pip install -e .

Include development dependencies with

python -m pip install -e ".[dev]"

You can set up and run pre-commit hooks with

pre-commit install
pre-commmit run --all-files

To run the tests you can use the pytest or coverage command, for example

coverage run --source ftag -m pytest --show-capture=stdout

Running coverage report will display the test coverage.

Usage

Please see the example notebook for full usage. Additional functionality is also documented below.

Calculate WPs

This package contains a script to calculate tagger working points (WPs). The script is working_points.py and can be run after installing this package with

wps \
    --ttbar "path/to/ttbar/*.h5" \
    --tagger GN2v01 \
    --fc 0.1

Both the --tagger and --fc options accept a list if you want to get the WPs for multiple taggers. If you are doing c-tagging or xbb-tagging, dedicated fx arguments are available ()you can find them all with -h.

If you want to use the ttbar WPs get the efficiencies and rejections for the zprime sample, you can add --zprime "path/to/zprime/*.h5" to the command. Note that a default selection of $p_T > 250 ~GeV$ to jets in the zprime sample.

If instead of defining the working points for a series of signal efficiencies, you wish to calculate a WP corresponding to a specific background rejection, the --rejection option can be given along with the desired background.

By default the working points are printed to the terminal, but you can save the results to a YAML file with the --outfile option.

See wps --help for more options and information.

Calculate efficiency at discriminant cut

The same script can be used to calculate the efficiency and rejection values at a given discriminant cut value. The script working_points.py can be run after intalling this package as follows

wps \
    --ttbar "path/to/ttbar/*.h5" \
    --tagger GN2v01 \
    --fx 0.1
    --disc_cuts 1.0 1.5

The --tagger, --fx, and --outfile follow the same procedure as in the 'Calculate WPs' script as described above.

H5 Utils

Create virtual file

This package contains a script to easily merge a set of H5 files. A virtual file is a fast and lightweight way to wrap a set of files. See the h5py documentation for more information on virtual datasets.

The script is vds.py and can be run after installing this package with

vds <pattern> <output path>

The <pattern> argument should be a quotes enclosed glob pattern, for example "dsid/path/*.h5"

See vds --help for more options and information.

h5move

A script to move/rename datasets inside an h5file. Useful for correcting discrepancies between group names. See h5move.py for more info.

h5split

A script to split a large h5 file into several smaller files. Useful if output files are too large for EOS/grid storage. See h5split.py for more info.

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

atlas_ftag_tools-0.2.1.tar.gz (22.4 kB view details)

Uploaded Source

Built Distribution

atlas_ftag_tools-0.2.1-py3-none-any.whl (27.6 kB view details)

Uploaded Python 3

File details

Details for the file atlas_ftag_tools-0.2.1.tar.gz.

File metadata

  • Download URL: atlas_ftag_tools-0.2.1.tar.gz
  • Upload date:
  • Size: 22.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.0 CPython/3.12.4

File hashes

Hashes for atlas_ftag_tools-0.2.1.tar.gz
Algorithm Hash digest
SHA256 6280e6239230e11d58afb2b55ed7820e1face907db1d576b0f5049fd889ca0fc
MD5 baf8d9d53b34eb6c6180eda6268c4e5b
BLAKE2b-256 f3b3bab0cfce861a92be3d4f7ecf62f3347681081267a9110cab8f7e9ad052e6

See more details on using hashes here.

File details

Details for the file atlas_ftag_tools-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for atlas_ftag_tools-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 78bf4c8e8d15e88d9a8bf5061f4677a18f455598cc7d8ce5be67cc5788e91cc3
MD5 3c1cc6547fbd00ed0b3573cbde872e19
BLAKE2b-256 a0309f8c0545c27890bb8f80ea03f7b21fd8e3ede5b9f08addb7bd026cc83ec4

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