\(\newcommand{\AA}{\unicode{x212B}}\)
Larch¶
Larch is a open-source library and set of applications for processing and analyzing X-ray absorption and fluorescence spectroscopy data and X-ray fluorescence and diffraction image data from synchrotron beamlines. Larch provides a comprehensive set fo analysis tools for X-ray absorption fine-structure spectroscopy (XAFS), including both X-ray absorption near-edge spectroscopy (XANES) and extended X-ray absorption fine-structure spectroscopy (EXAFS). Larch also provides visualization and analysis tools for X-ray fluorescence (XRF) spectra and XRF and X-ray diffraction (XRD) images as collected at scanning X-ray microprobe beamlines.
Larch is written in Python and relies on the excellent scientific python libraries including numpy, scipy, h5py, matplotlib. In turn, Larch provides a comprehensive Python library for processing and analyzing X-ray spectroscopy and imaging data. Several Python libraries - xraydb, larixite, lmfit, asteval, wxmplot, and pyshortcuts - were originally built for or as a part of Larch and then spun-off as separate libraries that can be used by the broader X-ray and scientific programming communities.
Larch includes a few GUI applications that provide user-friendly and interactive data visualization for many common X-ray analysis tasks. The most notable of these are Larix (was XAS Viewer), GSE Map Viewer, and Larch XRF (formerly XRF Viewer).
Larch also provides a Python-like macro language - the “Larch language” - for interactive and batch processing. This macro language is an isolated, restricted “mini-Python” (from asteval), intended to be both easy to use and complete enough to automate data processing and analysis available as an interactive command-line interface. This command-line interface is available either from the larch or Larch GUI. This macro language is not recommended for serious programming, but it is an important part of the Larch package and can be viewed as the bridge between using the GUIs for fully interactive, non-coding analysis, and writing batch-processing analysis scripts.
Most of the GUIs (notably, Larix) work by generating and executing this “Larch code”, with all of the real work done through this macro language. This allows for self-documented and reproducible analysis sessions, and facilitates transitioning from GUI-only analyses to scripting, batch processing, and programmatic analysis of larger data sets. That is, with a few simple changes and added boilerplate code, the Larch macro code saved from a GUI session becomes a Python program. This macro language also allows Larch to be run as a background service so that other processes can use Larch as the analysis engine - this was the original motivation and is still an important consideration. The popular Demeter XAFS application suite can use Larch in this way, though the Larix now contains almost all of the features of Demeter and is much more actively being developed and maintained.
Larch is distribute under an open-source license that is nearly identical to the MIT or 2-clause BSD license. It is under active and open development centered at the GeoScoilEnviroCARS sector of Center for Advanced Radiation Sources at the University of Chicago. Support has come from the US National Science Foundation Earth Sciences Division, currently through SEES: Synchrotron Earth and Environmental Science (EAR-222327), and previously from NSF Earth Sciences Division (EAR-1128799), and Department of Energy GeoSciences (DE-FG02-94ER14466). Funding specifically for Larch was granted by the National Science Foundation - Advanced CyberInfrastructure (ACI-1450468).
Table of Larch Applications
These applications installed with Larch, in addition to a basic Python library. Here, GUI = Graphical User Interface, CLI = Command Line Interface, and beta indicates a work in progress. The Feff6L and Feff8L codes are the open-source versions of Feff6 and Feff8, written by the Feff Project, and included with Larch by permission and with license to redistribute.
Application Name |
GUI/CLI |
Description |
---|---|---|
Larix (was XAS Viewer) |
GUI |
XAFS Processing and Analysis: XANES pre-edge peak fitting, linear analysis, PCA/LASSO, EXAFS background subtraction, running Feff, EXAFS Feff-fitting |
CLI |
simple shell command-line interface |
|
GUI |
enhanced command-line interface with data browser |
|
GUI |
XRF Map Viewer for GSECARS X-ray microprobe data. |
|
GUI |
Display and Analyze XRF Spectra. |
|
GUI |
Display and work with 1-D XRD patterns |
|
CLI |
Feff 6 EXAFS calculations |
|
CLI |
Feff 8 EXAFS calculations (no XANES) |
|
qtrixs |
GUI beta |
Display RIXS planes, take profiles |
Table of Contents¶
- 1. Downloading and Installation
- 1.1. Installing from a Binary installers
- 1.2. Installing with the GetLarch.sh and GetLarch.bat scripts
- 1.3. Installing into an existing Anaconda Python environment
- 1.4. Installing with pip into an existing Python environment
- 1.5. Updating a previous installation
- 1.6. Installing the development version
- 1.7. Making Desktop shortcuts to Link to the Applications
- 1.8. Larch for developers (source installation)
- 1.9. Getting Help
- 1.10. Docs and Examples
- 1.11. Citing Larch
- 1.12. Funding and Support
- 1.13. Acknowledgements
- 1.14. License
- 2. Getting Started with Larch
- 3. Larch: Motivation and Overview
- 4. Other Larch GUIs
- 5. Larix (was XAS Viewer)
- 5.1. Larix Overview
- 5.2. Reading and Saving Data into Larix
- 5.3. Pre-edge subtraction and Normalization
- 5.4. Common XAS Processing Dialogs
- 5.5. Pre-edge peak fitting
- 5.6. Linear Combination Analysis
- 5.7. Principal Component and Non-negative Factor Analysis
- 5.8. Linear Regression with LASSO and PLS to predict external variable
- 5.9. EXAFS Processing: Background Subtraction
- 5.10. EXAFS Processing: Fourier Transforms
- 5.11. Fitting EXAFS data to Feff Paths
- 6. XRFMap Viewr
- 7. Larch XRD1D Viewer
- 8. QtRIXS
- 9. Programming with Larch from Python
- 10. Larch Macro Language Tutorial
- 10.1. Getting Started
- 10.2. Basic and Complex Data Types
- 10.3. Basic Array Manipulation
- 10.4. Conditional Execution and Flow Control
- 10.5. Dealing With Errors
- 10.6. Writing Functions or Procedures
- 10.7. Running Larch Scripts, and Modules
- 10.8. Builtin Functions
- 10.9. Differences between Larch and Python
- 11. Reading and Writing Data
- 11.1. Simple Plaintext (ASCII or UTF-8) Column Files
- 11.2. Reading XAFS Data Interchange (XDI) Files
- 11.3. Athena Project Files
- 11.4. Reading HDF5 Files
- 11.5. Reading NetCDF Files
- 11.6. Reading TIFF Images
- 11.7. Working with Epics Channel Access
- 11.8. Reading Scan Data from APS Beamlines
- 11.9. Reading Spec/BLISS files via silx.io.open
- 11.10. Reading FDMNES output files
- 11.11. Saving and Loading Larch Session Files: .larix Files
- 12. Plotting and Displaying Data
- 13. Fitting and Modeling Data
- 14. XAFS Analysis
- 14.1. XAFS Functions: Overview and Naming Conventions
- 14.2. XAFS: Pre-edge Subtraction, Normalization, and data treatment
- 14.3. XANES Analysis: Linear Methods, Pre-edge Peak Fitting
- 14.4. XAFS: Post-edge Background Subtraction
- 14.5. XAFS: Fourier Transforms for XAFS
- 14.6. XAFS: Wavelet Transforms for XAFS
- 14.7. XAFS: Reading and using Feff Paths
- 14.8. XAFS: Fitting XAFS to Feff Paths
- 14.9. XAFS: Computing anomalous scattering factors from XAFS data
- 15. X-ray Databases
- 16. X-ray Fluorescence Analysis
- 17. References