XRDapp is a data visualisation tool that aims to streamline the workflow of X-ray diffraction (XRD) analysis. This project is developed for the Open University, School of Engineering and Innovation in collaboration with James Bowen and Matthew Kershaw.
- thanks to xylib, work with multiple common and obscure XRD file formats
- portable .exe file can be used on many lab and personal machines
- convert loaded files to .txt format so they can be opened and viewed elsewhere
- load temperature values as a separate file to go hand-in-hand with the current data set
- customise the viewing window (data points cursor, minor and major grids, change axis spacing values, change font size, etc.)
XRDapp uses the latest xylib version compiled from the official repository. In other words, it is at least one commit ahead of the pip and fytik xylib distribution. The key difference is that this locally compiled version partially supports RAW4.0 file format. Additionally, XRDapp has its own way of interpreting RAW4.0 files that are not recognised by xylib.
XRDapp works with the following formats (powered by xylib):
- plain text, delimiter-separated values (e.g. CSV)
- Crystallographic Information File for Powder Diffraction (pdCIF)
- Siemens/Bruker UXD
- Siemens/Bruker RAW ver. 1/2/3, RAW4.0 (experimental functionality, might not work perfectly)
- Philips UDF
- Philips PC-APD RD raw scan V3/V5
- PANalytical XRDML
- Rigaku DAT
- Sietronics Sieray CPI
- DBWS/DMPLOT data file
- Canberra CNF (from Genie-2000 software; aka CAM format)
- Canberra AccuSpec MCA
- XFIT/Koalariet XDD
- RIET7/LHPM/CSRIET/ILL_D1A5/PSI_DMC DAT
- Vamas ISO14976 (only experiment modes: SEM or MAPSV or MAPSVDP are supported; only REGULAR scan_mode is supported)
- Princeton Instruments WinSpec SPE (only 1-D data is supported)
- χPLOT CHI
- Ron Unwin's Spectra XPS format (VGX-900 compatible)
- Freiberg Instruments XSYG (from lexsyg)
- Bruker SPC/PAR
- Home: get back to the original view (matplotlib toolbar function)
- Import Data: when selected, navigate to the folder with data and select files to be loaded into XRDapp
- Load Temperatures: an optional feature which allows XRDapp to load a .txt file with temperatures that were used during the XRD run
- Fit Screen: fit the current curve into the screen
- Toggle Cursor: turns on or off a cursor that snaps to the closest data point
- Toggle File List: controls visibility of the loaded files list
- Toggle Grid: activates minor and major grids that spans vertically and horizontally. Each can be individually toggled on or off
- Set Ticks: set spacing between x or y axis divisions
- Set Font Size: set font size of each individual text element
- Previous View: go back to the previous view of the current curve (matplotlib toolbar function)
- Next View: go to the view you had before clicking "Previous view" (matplotlib toolbar function)
- Pan View: move the curve inside the viewing window (matplotlib toolbar function)
- Zoom: select an area to zoom into (matplotlib toolbar function)
- Edit Axis: edit min and max shown values, change the colour of the curve, change text entries for axes, change line style and choose markers (matplotlib toolbar function)
- Save Figure: take a screencap of the current view (matplotlib toolbar function)
- App Info: information regarding the current version, developers and contact details
- Convert Data: convert the loaded data into .txt file. XRD data viewer will create a new folder in the same directory as the loaded files and place converted files in it
- Clear Data: clear the loaded data cache
Start using XRDapp by pressing and loading the data. When the data is loaded, you can browse through XRD curves with a help of up and down arrow buttons on your keyboard or by clicking the filename in the loaded files list window. Use
to load a .txt file with temperature values, which will be displayed above the viewing window. To zoom in to an area of interest, use
. If the given curve has small intensity (y-axis value), press
to fit it to the screen. Pressing
automatically rescales everything back to the highest intensity among all loaded files. To convert loaded files into .txt file, press
, which will create a folder called "XRDapp converted" in the folder where the data was loaded from. Press either
to clear the data or
to load different files.
Examples folder contains an example of temperature file and RAW4.0 file.
Video demonstration of the basic XRDapp functionality:
High resolution video is available in .mp4 format.
The code provided in this repository can be modified. It is important to note that to ensure that the code can run smoothly on your machine, you need to install xylib. After that, to build your own executable file, use the following command:
pyinstaller --name XRDApp --onefile --windowed --icon=media\icon_main.ico --add-data "media;media" xrdapp.py
Many thanks to: