Skip to content

Latest commit

 

History

History
97 lines (65 loc) · 3.58 KB

README.rst

File metadata and controls

97 lines (65 loc) · 3.58 KB

temporary checkers logo Checkers

build_status Coveralls docs black

Checkers is a rudimentary python module for working with HEXRD data, specificially at the Cornell High Energy Synchrotron Source (CHESS).

The module includes, amongst other tools, a Virtual Diffractometer for both near and far field data. The Tutorials are intended to help walk new users though the information necessary to understand and process their synchrotron data as well, while Scripts includes some experimental example workflows.

Due to it's dependencies, checkers is released under the GPL v3 license. It is also VERY much in Alpha, so users beware, as functionality might break with little notice.

Motivation

"If CHESS seems hard, try learning CHECKERS first"

Checker's purpose is three-fold:

  1. Provide a well-documented open source Virtual Diffraction tool.
  2. Use as a testbed for prototyping new 3DXRD analysis tools.
  3. Sharing data processing pipelines between HEXRD users.

Notably, Checkers is NOT meant as a replacement for HEXRD, Midas, or other mature 3DXRD analysis suites. Consider this more of a "beginners version", for new users not already intimately familiar with diffaction techniques, terminology, and algorithms.

Installation

checkers can be installed from the github source using git and pip as follows:

git clone https://github.com/argerlt/checkers.git
cd checkers
pip install --editable .

Contributing

TODO: add contribution guidelines

Documentation

TODO: add contribution guidelines

Motivation, continued

It has been my experience that existing codebases (of which I am most familiar with HEXRD) are difficult both to learn from or contribute to for new users, due to a lack of well documented open source code. This is understandable, as many of these codes were rapidly developed alongside the techniques themselves by large teams of contributers, all racing to stay on the cutting edge.

However, as techniques become more standardized, it makes sense to take a more organized approach to building a stable (if somewhat basic) codebase for 3DXRD analysis. A lot of inpsiration for how to implement this is taken from ORIX, including the implementation of unittests, coverall, python black, sphinx, github workflows, and readthedocs. Big thanks to the pyxem team.