Skip to main content

Python module to evaluate experimental data

Project description

Welcome to pyEvalData

This is a Python module to read and evaluate experimental data. It can handle raw data from different sources such as spec, hdf5, NeXus files which are common data formats at synchrotrons, FELs, as well as in a growing number of laboratories. The evaluation provides common functionalities such as binning, error calculation, and advanced data manipulation via algebraic expressions as well as pre- and post-data-filters. Furthermore, advanced wrapper functions allow for plotting and fitting sequences of one or multiple scans in dependence of an external parameter.

A minimal code example would look like this:

import pyEvalData as ped
# define your data source
spec = ped.io.Spec(file_name='data.spec')
# initialize the evaluation
ev = ped.Evaluation(spec)
# define the x- and y-data
ev.xcol = 'motor1'
ev.clist = ['ct1', 'ct2', 'ct1/ct2']
# create a plot for scans 1-3
ev.plot_scans([1, 2, 3])

Please follow the user guide and examples for your first steps with pyEvalData.

Features

  • reading of several pre-defined raw data formats
    • spec
    • hdf5
    • NeXus
    • user-defined text files
    • camera images (Dectris Pilatus, Princeton MTE, Greateyes, ...)
    • composite sources
  • easy implementation of new raw data formats using an interface class
  • common methods for plotting and fitting of experimental data, including:
    • data binning
    • error calculation
    • data manipulation via algebraic expressions
    • common data pre- and post-filters

Installation

You can either install directly from pypi.org using the command

$ pip install pyEvalData

or if you want to work on the latest develop release you can clone pyEvalData from the main git repository:

$ git clone https://github.com/dschick/pyEvalData.git pyEvalData

To work in editable mode (source is only linked but not copied to the python site-packages), just do:

$ pip install -e ./pyEvalData

Or to do a normal install with

$ pip install ./pyEvalData

Optionally, you can also let pip install directly from the repository:

$ pip install git+https://github.com/dschick/pyEvalData.git

You can have the following optional installation to enable unit tests, as well as building the documentation:

$ pip install pyEvalData[testing]
$ pip install pyEvalData[documentation]

Contribute & Support

If you are having issues please let us know via the issue tracker.

You can contribute to the project via pull-requests following the GitHub flow concept.

License

The project is licensed under the MIT 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

pyEvalData-1.4.2.tar.gz (26.7 kB view details)

Uploaded Source

Built Distribution

pyEvalData-1.4.2-py3-none-any.whl (34.6 kB view details)

Uploaded Python 3

File details

Details for the file pyEvalData-1.4.2.tar.gz.

File metadata

  • Download URL: pyEvalData-1.4.2.tar.gz
  • Upload date:
  • Size: 26.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.0 importlib_metadata/4.8.2 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.12

File hashes

Hashes for pyEvalData-1.4.2.tar.gz
Algorithm Hash digest
SHA256 0465c9f103238c6f4d2018dd7c041f7c3dc3e62d3cff97d7abd484f8fd4cfcb6
MD5 0be0f3d9d6cd775dcddc6cdf4221a315
BLAKE2b-256 6873954f0a9099ca9bc1814e3d9c37a27f7ba886978fe8f59646960b292fb529

See more details on using hashes here.

File details

Details for the file pyEvalData-1.4.2-py3-none-any.whl.

File metadata

  • Download URL: pyEvalData-1.4.2-py3-none-any.whl
  • Upload date:
  • Size: 34.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.0 importlib_metadata/4.8.2 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.12

File hashes

Hashes for pyEvalData-1.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 17efa9dfa48d271a6fe766476423b8be6c11cfaac568f2e88792f69a3faa6ad2
MD5 5aa3bc6256b79b292556ad57d91fd662
BLAKE2b-256 65582b9e564160232cb17738ad439ce7ce75fd771ea88a73783fc917a39fdb78

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