Skip to main content

A program for visualising diffraction data in pdCIF format.

Project description

A program for the visualisation of diffraction data in pdCIF format.

Crystallographic Information Framework (CIF; https://www.iucr.org/resources/cif) files are a way of storing crystallographic information in a standard human- and machine-readable format. This particular program is focussed on visualising powder diffraction data stored in CIF format, and, in particular, serial or in situ/operando data.

  • Free software: Apache Software License 2.0

Pre-installation

If you are on Windows, you must read this step. If you are on Linux, you can continue.

pdCIFplotter requires PyCifRW == 4.4.3. If you install PyCifRW from PyPI via pip, then you will also need to compile the included C modules. To do so requires Microsoft Visual C++ 14.0 or greater. If you don’t have this installed, or do not wish to install it, precompiled wheel files are available. You must download the wheel file corresponding to your Python installation.

To obtain information about your Python installation, run the command:

python -VV

An example output is Python 3.9.4 (tags/v3.9.4:1f2e308, Apr 6 2021, 13:40:21) [MSC v.1928 64 bit (AMD64)], showing that this is 64 bit Python 3.9.

Using pip version 19.2 or newer, install your downloaded wheel file as:

pip install c:\path\to\file\name_of_file.whl

This should install PyCifRW, and you can move on to the next step. If you encounter any issues in the installation, please lodge an issue.

Installation

To install the release version of pdCIFplotter from PyPI:

pip install pdCIFplotter

You can also install the in-development version from GitHub with:

pip install https://github.com/rowlesmr/pdCIFplotter/archive/master.zip

Quick usage

To run pdCIFplotter as a standalone program:

pdcifplotter

When you first open pdCIFplotter, you are met with an empty window

https://raw.githubusercontent.com/rowlesmr/pdCIFplotter/master/docs/empty.png?sanitize=true

Clicking “Load file”, and choosing a CIF file to open will automatically present you with a single plot. You can then alter how that plot is presented, or visualise all diffraction data in the CIF with the Stack and Surface tabs.

https://raw.githubusercontent.com/rowlesmr/pdCIFplotter/master/docs/single.png?sanitize=true

Documentation

https://pdCIFplotter.readthedocs.io/en/latest/

Changelog

0.1.3 (2022-09-18)

  • Adding package to conda-forge

0.1.2 (2022-07-14)

  • Misc. bug fixes

0.1.1 (2022-06-30)

  • More features!

  • Added the ability to alter font details on the plots

  • Added the ability to alter relative plot widths on the surface plot when showing QPA/temperatures…

0.1.0 (2022-03-14)

  • Submitting final version of manuscript for publication - feature freeze!

0.0.11 (2022-01-24)

  • Created a program icon.

  • Fixed bug in quantitative phase analysis parsing to enable reading of data-only CIFs.

  • Correctly reads an empty file.

0.0.10 (2021-12-31)

  • Updated type hints to maintain compatibility with Python <=v3.8.

0.0.9 (2021-12-31)

  • Single plot - subtitle now shows the datetime, temperature, pressure, Rwp, and GoF, if available in the CIF file. Rwp and GoF is also calculated and displayed in brackets if possible. Gof calculation uses N, and not N-P, so it is only an approximation.

  • Stack plot - Hovertext now shows the datetime, temperature, pressure, Rwp, and GoF, if available in the CIF file.

  • Surface plot - Can now plot temperature, pressure, quantitative phase analysis (QPA), Rwp, and GoF (if available in the CIF file) next to the surface plot. QPA phases are linked together by their _pd_phase_name, so it is important that the same string is used to denote the same phases in different patterns.

0.0.8 (2021-12-20)

  • Updated some of the zoom behaviour

  • Can now use arrow buttons to move between consecutive diffraction patterns in the single plot

0.0.7 (2021-12-18)

  • Zoom persists in single plots when changing between diffraction patterns or altering the view in some way.

0.0.6 (2021-12-09)

  • Can normalise intensities to counts from provided weights or errors; possible in single, stack, and surface

  • hkl ticks labelled by phase name, if present, else, phase id: now including surface plot.

  • (ongoing) Refactoring of plot_cif

0.0.5 (2021-11-16)

  • Better hkl checkbox checking

  • Doesn’t crash if CIF with no diffraction pattern is loaded

  • Gracefully handles NANs in data when calculating hkl tick offsets

  • Datablock names replaced with block_id values on single plot title and dropdown data box

  • hkl ticks labelled by phase name, if present, else, phase id.

  • Large refactoring of parse_cif

0.0.4 (2021-11-11)

  • Added hkl ticks to stack plot

  • Enabled hkl ticks to be plotted above the diffraction patterns

0.0.3 (2021-11-10)

  • Separated GUI and plotting code

  • Fixed crash on changing to surface tab before opening CIF

0.0.2 (2021-11-07)

  • Update install requirements - mplcursors 0.5 is now available, rather than installing from git.

  • Can now launch from command line with just > pdcifplotter

0.0.1 (2021-11-06)

  • Update install requirements and provided prompting to user on installing packages not available on PyPi.

0.0.0 (2021-11-05)

  • First release on PyPI.

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

pdCIFplotter-0.1.3.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

pdCIFplotter-0.1.3-py2.py3-none-any.whl (56.0 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file pdCIFplotter-0.1.3.tar.gz.

File metadata

  • Download URL: pdCIFplotter-0.1.3.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.8.1 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.4

File hashes

Hashes for pdCIFplotter-0.1.3.tar.gz
Algorithm Hash digest
SHA256 abd309406ae15a837ab0ab1a00d8e35ee2afbdc349690e3b7a93cfc40744826c
MD5 bb9419435472ab7bcf90282359bf924d
BLAKE2b-256 2ce5c96d7204152c08bae43d986df31889fc01788752295eec4818bbf22262a9

See more details on using hashes here.

File details

Details for the file pdCIFplotter-0.1.3-py2.py3-none-any.whl.

File metadata

  • Download URL: pdCIFplotter-0.1.3-py2.py3-none-any.whl
  • Upload date:
  • Size: 56.0 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.8.1 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.4

File hashes

Hashes for pdCIFplotter-0.1.3-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 23e057541c0a68667939f4d44ca137513241bd5a121196f478a02fe75e759455
MD5 94345b5020e3949d807f10b6264d1e5d
BLAKE2b-256 cfeae1dab1e37da49a5e912d910f29b8d1a9544750d9a4ddd342928da3aae1c2

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