Python implementation of the BumpHenter algorithm used by HEP community.
Project description
pyBumpHunter
This is a python version of the BumpHunter algorithm, see arXiv:1101.0390, G. Choudalakis, designed to find localized excess (or deficit) of events in a 1D distribution.
The main BumpHunter function will scan a data distribution using variable-width window sizes and calculate the p-value of data with respect to a given background distribution in each window. The minimum p-value obtained from all windows is the local p-value. To cope with the "look-elsewhere effect" a global p-value is calculated by performing background-only pseudo-experiments.
The BumpHunter algorithm can also perform signal injection tests where more and more signal is injected in toy data until a given signal significance (global) is reached.
Content
- pyBumpHunter : The pyBumpHunter package
- example/example.py : A little example script that use pyBumpHunter
- example/example.ipynb : A little example notebook that use pyBumpHunter
- example/results : Folder containing the outputs of example script
- testing : Folder containing the testing scripts (based on pytest)
- data/data.root : Toy data used in the examples and tests
- data/gen_data.C : Code used to generate the toy data with ROOT
python dependancies
pyBumpHunter depends on the following python libraries :
- numpy
- scipy
- matplotlib
pyBumpHunter wiki
Examples
The examples provided in example.py and test.ipynb require the uproot package in order to read the data from a ROOT software file.
The data provided in the example consists of three histograms: a steeply falling 'background' distribution in a [0,20] x-axis range, a 'signal' gaussian shape centered on a value of 5.5, and a 'data' distribution sampled from background and signal distributions, with a signal fraction of 0.15%. The data file is produced by running gen_data.C in ROOT.
In order to run the example script, simply type python3 example.py
in a terminal.
You can also open the example notebook with jupyter or binder.
- Bump hunting:
- Tomography scan:
- Test statistics and global p-value:
See the wiki for a detailed overview of all the features offered by pyBumpHunter.
To do list
- Run BH on 2D histograms
Authors and contributors
Louis Vaslin (main developper), Julien Donini
Thanks to Samuel Calvet for his help in cross-checking and validating pyBumpHunter against the (internal) C++ version of BumpHunter developped by the ATLAS collaboration.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pyBumpHunter-0.0.0.tar.gz
.
File metadata
- Download URL: pyBumpHunter-0.0.0.tar.gz
- Upload date:
- Size: 1.9 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.3.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8fdd2ae9e27a19d0255e5f22d4e1e40d6b7cdde2f49b8bbfa2a496c01205f122 |
|
MD5 | b96c58f01d42ea59fab7048bd6d6c50a |
|
BLAKE2b-256 | f981fd76f5e2bb6ecb3ac9616488cca82313e800ca4272d97792aa6831cf9883 |
File details
Details for the file pyBumpHunter-0.0.0-py3-none-any.whl
.
File metadata
- Download URL: pyBumpHunter-0.0.0-py3-none-any.whl
- Upload date:
- Size: 3.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.3.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5f084f32080a78ce92c5d63a227b68f53251b47e613e5600975730b17c2b0326 |
|
MD5 | c71db2c6d39d56dbe781dd7d556a0a12 |
|
BLAKE2b-256 | 03cbd147887f3d100d045562f364040edf8473d7c1370faefd1dcc953403be31 |