Skip to main content

Total scattering function manipulator

Project description

Total Scattering Function Manipulator:

Health Release Other
Build Status PyPI version Binder
codecov Anaconda-Server Badge License: GPL v3
Documentation Status Project Status: Active – The project has reached a stable, usable state and is being actively developed.

From total scattering functions, we have reciprocal-space structure factors and real-space pair distribution functions that are related via a Fourier transform. PyStoG is a package that allows for:

  1. Converting between the various functions used by different "communities" (ie researchers who study crystalline versus amorphous or glass materials). Conversions are for either real-space or reciprocal-space.
  2. Perform the transform between the different available functions of choice
  3. Fourier filter to remove spurious artificats in the data (ie aphysical, sub-angstrom low-r peaks in G(r) from experiments)

alt text

The name PyStoG comes from the fact that this is a Pythonized version of StoG, a ~30 year old Fortran program that is part of the RMCProfile software suite. StoG means "S(Q) to G(r)" for the fact that it takes recirpocal-space S(Q) patterns from files and transforms them into a single G(r) pattern. The original StoG program has been developed, in reverse chronological order, by:

  • Matthew Tucker and Martin Dove (~2009)
  • Spencer Howells (~1989)
  • Jack Carpenter (prior to 1989)

A current state of the StoG program is kept in the fortran directory of this package.

This project was initially just a "sandbox" for taking the capabilities of StoG and migrating them over to the Mantid Framework. Yet, with more and more use cases, PyStoG was further developed as the stand-alone project it is now. Yet, migration to the Mantid Framework is still a goal since it feeds into the ADDIE project

Installation

Installation is available via pip:

pip install pystog

And conda:

conda install -c neutrons pystog

Getting started

Once installed, you can access the packages classes that perform the function manipulation.

import pystog
from pystog import Converter
from pystog import Transformer
from pystog import FourierFilter
from pystog import StoG

** WARNING: Testing of the CLI is still ongoing**

A CLI command is also included, which can be run with JSON input files. The script will be installed into the bin directory in your virtual environment directory. For example:

  • .pixi/envs/default/bin/
  • pystog/.venv/bin/
  • .../miniconda/envs/pystog/bin/

You can simply activate your virtual environment (pixi shell, . .venv/bin/activate, or conda activate pystog) and run pystog-cli:

pystog-cli --json <input json>

For a list of available options, run:

pystog-cli --help

An example JSON can be found here

Documentation

The official documentation is hosted on readthedocs.org: https://pystog.readthedocs.io/en/latest/

Also, a useful example reference is the PDFFourierTransform algorithm in the Mantid Framework that has similar yet limited capabilities.

Finally, tutorials in the form of Jupyter Notebooks can be launched via Binder by clicking the badge here Binder or at the top of the page.

Development

Pystog uses pixi to manage packaging and dependencies. To get started, install pixi, then install pystog by running:

cd pystog/
pixi install

Pixi will automatically create a virtual environment in pystog/.pixi/. A number of convenience "tasks" are available, and can be viewed within the pyproject.toml, or by running:

pixi task list

Testing

pytest is used to write and run the test suite.

To run the tests, simply run:

pixi run test

Any additional flags or options you desire may be passed, for example:

pixi run test some.specific:test
# or
pixi run test -vv

Formatting and Static analysis

pre-commit is used for style enforcement and static analysis. To install, after creating the environment run

pre-commit install

and it will run for every commit.

pre-commit run --all

will run it without committing.

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

pystog-0.6.1.tar.gz (21.8 MB view details)

Uploaded Source

Built Distribution

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

pystog-0.6.1-py3-none-any.whl (38.2 kB view details)

Uploaded Python 3

File details

Details for the file pystog-0.6.1.tar.gz.

File metadata

  • Download URL: pystog-0.6.1.tar.gz
  • Upload date:
  • Size: 21.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pystog-0.6.1.tar.gz
Algorithm Hash digest
SHA256 da32039b9f8ff6ece6f70a9cea5982b8fb93efe1d77da2b1e18fcd1e83a4a128
MD5 e8f9b69368651d419c3cd1d7ba507c4d
BLAKE2b-256 af30abbafeec9d15168fefc246b5bab25e909657c8c9152ffc83cb4f41df3ed8

See more details on using hashes here.

Provenance

The following attestation bundles were made for pystog-0.6.1.tar.gz:

Publisher: test_and_deploy.yml on neutrons/pystog

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

File details

Details for the file pystog-0.6.1-py3-none-any.whl.

File metadata

  • Download URL: pystog-0.6.1-py3-none-any.whl
  • Upload date:
  • Size: 38.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pystog-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a1f2ee8e88ccc86a05fb31d28ff0ad5516ca10ae4f18f0b778d5c344b4d13834
MD5 9f6d3405b8e40e41f0b3a9fa6574aeba
BLAKE2b-256 4dbff26e90f3c17cc5cd6676583f9d13faa0a1017249a09603a3ab4f63892845

See more details on using hashes here.

Provenance

The following attestation bundles were made for pystog-0.6.1-py3-none-any.whl:

Publisher: test_and_deploy.yml on neutrons/pystog

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