Skip to main content

A utility package for retrieving ATLAS open data URLs and metadata.

Project description

Atlas Open Magic 🪄📊

Tests Dynamic TOML Badge codecov

Atlas Open Magic is a Python package made to simplify working with ATLAS Open Data by providing utilities to manage metadata and URLs for streaming the data.

Installation

You can install this package using pip.

pip install atlasopenmagic

Alternatively, clone the repository and install locally:

git clone https://github.com/atlas-outreach-data-tools/atlasopenmagic.git
cd atlasopenmagic
pip install .

Quick start

First, import the package:

import atlasopenmagic as atom

See the available releases and set to one of the options given by available_releases()

atom.available_releases()
set_release('2024r-pp')

Check in the Monte Carlo Metadata which datasets do you want to retrieve and use the 'Dataset ID'. For example, to get the metadata from Pythia8EvtGen_A14MSTW2008LO_Zprime_NoInt_ee_SSM3000:

all_metadata = atom.get_metadata('301204')

If we only want a specific variable:

xsec = atom.get_metadata('301204', 'cross_section')

To get the URLs to stream the files for that MC dataset:

all_mc = atom.get_urls('301204')

To get some data instead, check the available options:

atom.available_data()

And get the URLs for the one that's to be used:

all_mc = atom.get_urls('2016')

Open Data functions description and usage

available_releases()

Shows the available open data releases keys and descriptions.

Usage:

import atlasopenmagic as atom
atom.available_releases()

get_current_release()

Retrieves the release that the package is currently set at.

Usage:

release = atom.get_current_release()
print(release)

set_release(release, local_path)

Set the release (scope) in which to look for information (research open data, education 8 TeV, et). The release passed to the function has to be one of the keys listed by available_releases(). If a release has been downloaded locally, it is possible to use local_path to point atlasopenmagic towards the location of the datasets to use. Files are expected to be in a single directory. Metadata will be still retrieved remotely.

Additionally, if your facility mounts or mirrors EOS public as a local filesystem, you can provide "eos" as the local_path. In this case, files will be accessed using the native POSIX path

Args:

  • release: name of the release to use.
  • local_path: local directory path to use for downloaded datasets. If provided, the client will assume that datasets are available locally at this path. If 'eos' is provided, the original folder structure for the paths is kept.

Usage (remote storage):

atom.set_release('2024r-pp')

Usage (local storage):

atom.set_release('2024r-pp', local_path='/myproject/opendata/2024r-pp')

get_all_info(key, var)

Retrieves all the information for a given dataset, identified by its number or physics short name.

Args:

  • key: The dataset identifier (e.g., '301204').
  • var: A specific metadata field to retrieve. If None, the entire metadata dictionary is returned.

Usage: You can get a dictionary with all the metadata

metadata = atom.get_metadata('301209')

Or a single variable

xsec = atom.get_metadata('301209', 'cross_section')

The available variables are: dataset_number, physics_short, e_tag, cross_section_pb, genFiltEff, kFactor, nEvents, sumOfWeights, sumOfWeightsSquared, process, generator, keywords, file_list, description, job_path, CoMEnergy, GenEvents, GenTune, PDF, Release, Filters, release, skims.

The keys to be used for research data are the Dataset IDs found in the Monte Carlo Metadata

find_all_files(local_path, warnmissing=False)

Replace cached remote URLs in _metadata with corresponding local file paths if those files exist in the given local_path.

This function only affects the currently active release, and requires _metadata to be populated (it will trigger a fetch automatically).

Args:

  • local_path (str): Root directory of your local dataset copy. Can have any internal subdirectory structure; only filenames are used for matching.

  • warnmissing (bool, optional, default=False): If True, issue a UserWarning for every file that is in metadata but not found locally.

get_metadata(key, var)

Retrieves the metadata (no file lists) for a given MC dataset.

Args:

  • key: The dataset identifier (e.g., '301204').
  • var: A specific metadata field to retrieve. If None, the entire metadata dictionary is returned.

Usage: You can get a dictionary with all the metadata

metadata = atom.get_metadata('301209')

Or a single variable

xsec = atom.get_metadata('301209', 'cross_section')

The available variables are: dataset_number, physics_short, e_tag, cross_section_pb, genFiltEff, kFactor, nEvents, sumOfWeights, sumOfWeightsSquared, process, generator, keywords, description, job_path, CoMEnergy, GenEvents, GenTune, PDF, Release, Filters, release.

The keys to be used for research data are the Dataset IDs found in the Monte Carlo Metadata

get_urls(key, skim, protocol, cache)

Retrieves the list of URLs corresponding to a given key.

Args:

  • key: Dataset ID.
  • skim: Skim for the dataset. This parameter is only taken into account when using the 2025e-13tev-beta release.
  • protocol: protocol for the URLs. Options: 'root' and 'https'.
  • cache: use the simplecache mechanism of fsspec to locally cache files instead of streaming them. Default value (None) corresponds to True for https and False for root protocol.

Usage:

urls = atom.get_urls('12345', protocol='root', cache=True)

available_data()

Retrieves the list of keys for the data available for a scope/release.

Usage:

atom.available_data()

get_all_metadata()

Retrieves the current dictionary of metadata, in its entirety.

Usage:

my_metadata = atom.get_all_metadata()

save_metadata(file_name)

Saves the metadata to an output file. Currently supports writing to json or txt file.

Args:

  • file_name: the name of the file to save the metadata to, with full path and extension.

Usage:

save_metadata('metadata.json')

read_metadata(file_name, release)

Reads the metadata from a file. Currently supports reading from json.

Args:

  • file_name: the name of the file to load the metadata from, with full path
  • release: the name of the release for this metadata; default 'custom'

Usage:

read_metadata('metadata.json', release='2024r-pp')

DEPRECATED get_urls_data(data_key, protocol)

Please use get_urls(key, skim='noskim', protocol=protocol, cache=None) instead.

Retrieves the list of URLs corresponding to one of the keys listed by available_data().

Args:

  • data_key : For non-beta releases (e.g. '2015', '2016', etc.), the data key to look up.
  • skim : Only for the 2025e-13tev-beta release: the skim name to look up.

Usage:

data = get_urls_data(data_key='2016', protocol='https')

Notebooks utilities description and usage

install_from_environment(*packages, environment_file)

Install specific packages listed in an environment.yml file via pip.

Args:

Usage:

import atlasopenmagic as atom
atom.install_from_environment("coffea", "pandas", environment_file="./myfile.yml")

build_dataset(samples_defs, skim='noskim', protocol='https', cache=False)

Build a dict of data and / or MC samples URLs.

Args:

  • samples_defs: Dictionary with DIDs and optional color: { sample_name: {'list': [...urls...], 'color': ...}, … }
  • skim : The MC skim tag (only meaningful in the 2025e-13tev-beta release)
  • protocol : Protocol to use for URLs.
  • cache: use the simplecache mechanism of fsspec to locally cache files instead of streaming them. Default (None) means let atlasopenmagic decide what to do about caching.

Usage:

import atlasopenmagic as atom
atom.set_release('2025e-13tev-beta')
samples_defs = {
    r'Data':                    {'dids': ["data"],                      'color': 'red'},
    r'Background $t\bar t$':    {'dids': [410470],                      'color': 'yellow'},
    r'Background $V+$jets':     {'dids': [700335,700336,700337],        'color': 'orange'},
    r'Background Diboson':      {'dids': [700488,700489,700490,700491],'color': 'green'},
    r'Background $ZZ^{*}$':     {'dids': [700600,700601],               'color': '#ff0000'},
    r'Signal ($m_H$=125 GeV)':  {'dids': [345060,346228],              'color': '#00cdff'},
}

mc_samples = atom.build_dataset(samples_defs, skim='2bjets', protocol='https', cache=True)

Contributing

Contributions are welcome! To contribute:

  1. Fork the repository.
  2. Create a new branch (git checkout -b feature-name).
  3. Commit your changes (git commit -am 'Add some feature').
  4. Push to the branch (git push origin feature-name).
  5. Create a Pull Request.

Please ensure all tests pass before submitting a pull request (just run pytest from the main directory of the package).

Developers can also pip install including additional tools required for testing:

pip install atlasopenmagic[dev]

or with a local copy of the repository:

pip install .[dev]

License

This project is licensed under the Apache 2.0 License

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

atlasopenmagic-1.4.1.tar.gz (19.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

atlasopenmagic-1.4.1-py3-none-any.whl (20.6 kB view details)

Uploaded Python 3

File details

Details for the file atlasopenmagic-1.4.1.tar.gz.

File metadata

  • Download URL: atlasopenmagic-1.4.1.tar.gz
  • Upload date:
  • Size: 19.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for atlasopenmagic-1.4.1.tar.gz
Algorithm Hash digest
SHA256 356d6b25fbf7627ed1fb72aedffc0dfc453331945f630d7bf5c376077d00f4ae
MD5 6eb5f0ec20ee28b0509889afbe0289d5
BLAKE2b-256 bb294b36e56f95d4e91f7898a9f203354261cef232f2e24629970854ac343170

See more details on using hashes here.

Provenance

The following attestation bundles were made for atlasopenmagic-1.4.1.tar.gz:

Publisher: build-and-publish.yml on atlas-outreach-data-tools/atlasopenmagic

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file atlasopenmagic-1.4.1-py3-none-any.whl.

File metadata

  • Download URL: atlasopenmagic-1.4.1-py3-none-any.whl
  • Upload date:
  • Size: 20.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for atlasopenmagic-1.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c5abb493e542469d93b4c3f23afde2728a3efbae4854e9cae7f295e36721e606
MD5 222182d8a640c6cd962f214640ab4313
BLAKE2b-256 89634669bd418764ce056780d2da1a5d02a4e2e464dd4b5e4c196113a8ee5b16

See more details on using hashes here.

Provenance

The following attestation bundles were made for atlasopenmagic-1.4.1-py3-none-any.whl:

Publisher: build-and-publish.yml on atlas-outreach-data-tools/atlasopenmagic

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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