Skip to main content

XANES package using jupyter widgets

Project description

Presentation of thorondor, a program for data analysis and treatment in NEXAFS

Authors : Simonne and Martini

The Program is meant to be imported as a python package, if you download it, please save the thorondor folder in ...\Anaconda3\Lib\site-packages

The installation command can be found here : https://pypi.org/project/thorondor/

To keep the package up to date, please use the following command : pip install thorondor -U

There are two main classes at the core of thorondor:

The class Dataset

A new instance of the Dataset class will be initialized for each Dataset saved in the data folder. This object is then saved in the list "class_list", attribute of the second class "gui". For each Dataset, all the different dataframes that will be created as well as specific information e.g. the edge jump E0 can be found as attributes of this class, after a specific method is used. Certain attributes are instanced directly with the class, such as:

  • name of Dataset,
  • path of original data (the .txt ,.dat, ... file ),
  • timestamp.

At the end of the data reduction, each Dataset should have at least three different data sets as attributes, saved as pandas.DataFrame():

  • renamed_df : original data,
  • shifted_df : if one shifts the energy,
  • reduced_df : if one applies some background reduction or normalization method.

A Logbook entry might also be associated, under Dataset.logbook_entry, this is done via the gui, the logbook should be in the common excel formats.

It is possible to add commentaries for each Dataset by using the Dataset.comment() and to specify some additional information with the function Dataset.metadata().

The class Interface (used to be gui)

This class is a Graphical User Interface (gui) that is meant to be used to process numerous XAS datasets, that focus on similar energy range and absorption edge. There are two ways of initializing the procedure in a jupyter notebook:

  • gui = thorondor.Interface(); one will have to write the name of the data folder in which all his raw datasets are saved in a common data format (.txt, .dat, .csv, .xlsx, .nxs).
  • gui = thorondor.Interface.get_class_list(data_folder = "<yourdatafolder>") ; if one has already worked on a folder and wishes to retrieve his work.

This class makes extensive use of the ipywidgets and is thus meant to be used with a jupyter notebook. Additional informations concerning the use of the Interface functions are provided in the "ReadMe" tab. One may also access method information through the python help built-in function.

All the different attributes of this class can also be exported in a single hdf5 file using the pandas .to_hdf5 methods. They should then be accessed using the read_hdf methods.

Export work

After data reduction and analysis, each Dataset can be retrieved by using the function Dataset.unpickle() with the path of the saved Class as an argument. This is the recommended way to share the data, since it comes with all the metadata linked to the data collection and analysis.

The Dataset class is independent from the thorondor gui and can then be used as a stand alone class to store your data.

You can now also load .nxs files if the data is in root.NXentry.NXdata.data[:] (soft link to table) and save as .nxs (even if not originally a .nxs file) with a tool in the gui.

The necessary Python packages are : numpy, pandas, matplotlib, ipywidgets, iPython, scipy, lmfit, emcee, thorondor and pytables.

Citation and additional details

THORONDOR: software for fast treatment and analysis of low-energy XAS dat. Simonne, D.H., Martini, A., Signorile, M., Piovano, A., Braglia, L., Torelli, P., Borfecchia, E. & Ricchiardi, G. (2020). J. Synchrotron Rad. 27, https://doi.org/10.1107/S1600577520011388.

FlowChart

FlowChart

Please follow the following architecture when using the software

Architecture1

For users on Jupyter Lab, please follow this thread : https://stackoverflow.com/questions/49542417/how-to-get-ipywidgets-working-in-jupyter-lab

(perhaps outdated)

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

thorondor-0.3.30.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

thorondor-0.3.30-py3-none-any.whl (1.3 MB view details)

Uploaded Python 3

File details

Details for the file thorondor-0.3.30.tar.gz.

File metadata

  • Download URL: thorondor-0.3.30.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.1.post20201107 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.8.5

File hashes

Hashes for thorondor-0.3.30.tar.gz
Algorithm Hash digest
SHA256 3358c058a5824fd12564ea48f0ef4de9a9960b0acd49d328bc6836f0bdd47a4c
MD5 72c17551e9a431c72ea6bc2385b76ebd
BLAKE2b-256 461594efd84899392285ffa46cb71223509740637addcdf0d60eb4470abad794

See more details on using hashes here.

File details

Details for the file thorondor-0.3.30-py3-none-any.whl.

File metadata

  • Download URL: thorondor-0.3.30-py3-none-any.whl
  • Upload date:
  • Size: 1.3 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.1.post20201107 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.8.5

File hashes

Hashes for thorondor-0.3.30-py3-none-any.whl
Algorithm Hash digest
SHA256 50470b84d59d36e4e4ce4b1805a2f05559108fdf94abf6dcfacc6a5463606cd9
MD5 172d8e825ec91d1c80909e72998b62ec
BLAKE2b-256 437be0a471505679be11c2efcf66b9e7b0336a1daa7123ee77b80b5b0b107c4b

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