46 releases

0.8.7 Jan 22, 2025
0.8.6 Oct 18, 2024
0.8.3 Aug 30, 2024
0.8.2 Jul 22, 2024
0.1.0 Jun 11, 2020

#327 in Science

Download history 263/week @ 2024-10-22 64/week @ 2024-10-29 44/week @ 2024-11-05 41/week @ 2024-11-12 39/week @ 2024-11-19 91/week @ 2024-11-26 4/week @ 2024-12-03 24/week @ 2024-12-10 45/week @ 2024-12-17 17/week @ 2025-01-07 33/week @ 2025-01-14 165/week @ 2025-01-21 112/week @ 2025-01-28 197/week @ 2025-02-04

522 downloads per month
Used in 2 crates

GPL-3.0-or-later

390KB
9K SLoC

Rust codecov Documentation crates.io

PineAPPL

PineAPPL is a library for recording and storing predictions for high-energy physics observables independently of their parton distribution functions.


lib.rs:

PineAPPL is not an extension of APPLgrid.

Overview

The main type of this crate is Grid, which represents the interpolation grids that PineAPPL implements. Roughly speaking, a Grid is a three-dimensional array of Subgrid objects together with metadata. The three dimensions are

  1. (perturbative) orders, represented by the type Order and accessible by Grid::orders(),
  2. bins, whose limits can be accessed by Grid::bin_info(), and
  3. channels, whose definition is returned by Grid::channels().

Subgrid is a trait and objects that implement it are of the type SubgridEnum. The latter is an enum of different types that are optimized to different scenarios: fast event filling, small storage profile, etc.

Metadata

Metadata is a collection of key--value pairs, in which both keys and values are String objects. In metadata anything a user whishes can be stored. However, there are special keys, which have meaning to PineAPPL and/or its CLI pineappl. This metadata enables the CLI to automatically generate plots that are correctly labeled, for instance. For more applications see also the CLI tutorial.

Dependencies

~3.5MB
~72K SLoC