Skip to main content

Read and write turn-by-turn measurement files from different particle accelerator formats.

Project description

Turn-By-Turn

Cron Testing Code Climate coverage Code Climate maintainability (percentage) GitHub last commit GitHub release

This package provides reading functionality for turn-by-turn BPM measurements data from different particle accelerators. It also provides writing functionality in the LHC's own SDDS format, through our sdds package. Files are read into a custom-made TbtData dataclass encompassing the relevant information.

Installing

Installation is easily done via pip:

pip install turn_by_turn

Example Usage

The package is imported as turn_by_turn, and exports top-level functions for reading and writing:

import turn_by_turn as tbt

# Loading a file is simple and returns a custom dataclass named TbtData
data: tbt.TbtData = tbt.read("Beam2@BunchTurn@2018_12_02@20_08_49_739.sdds", datatype="lhc")

# Easily access relevant information from the loaded data: transverse data, measurement date, 
# number of turns, bunches and IDs of the recorded bunches
first_bunch_transverse_positions: tbt.TransverseData = data.matrices[0]
measurement_date = data.date  # a datetime.datetime object

# Transverse positions are recorded as pandas DataFrames
first_bunch_x = first_bunch_transverse_positions.X.copy()
first_bunch_y = first_bunch_transverse_positions.Y.copy()

# Do any operations with these as you usually do with pandas
first_bunch_mean_x = first_bunch_x.mean()

# Average over all bunches/particles at all used BPMs from the measurement
averaged_tbt: tbt.TbtData = tbt.utils.generate_average_tbtdata(data)

# Writing out to disk (in the LHC's SDDS format) is simple too, potentially with added noise
tbt.write("path_to_output.sdds", averaged_tbt, noise=1e-5)

See the API documentation for details.

License

This project is licensed under the MIT License - see the LICENSE file for details.

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

turn_by_turn-0.2.1.tar.gz (15.5 kB view details)

Uploaded Source

Built Distribution

turn_by_turn-0.2.1-py3-none-any.whl (19.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: turn_by_turn-0.2.1.tar.gz
  • Upload date:
  • Size: 15.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.7.12

File hashes

Hashes for turn_by_turn-0.2.1.tar.gz
Algorithm Hash digest
SHA256 c7d19c2be8754da2714d3227ed6fdcd7b2dd803d8782c63e87212699bd2a288b
MD5 3b3c85fa39e5b6aeaea7c28140072242
BLAKE2b-256 1bef583c5d784477d3a0371a1ca03be261790206c9cc0e7bcd31196c1dc77b52

See more details on using hashes here.

File details

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

File metadata

  • Download URL: turn_by_turn-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 19.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.7.12

File hashes

Hashes for turn_by_turn-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 94ebe985df1a1b40cef2f503cc8991e76d7e289c0814f868d7be7d9c2d194f8e
MD5 65289e8180a0aaf3506768e432175de2
BLAKE2b-256 4f7e8440f6689b05e392dc5aeeb9928b8594162fa932c2a9f8dfaf0d8221b8a0

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