spectrai is an open-source deep learning framework designed to facilitate the training of neural networks on spectral data and enable comparison between different methods. Spectrai provides numerous built-in spectral data pre-processing and augmentation methods, neural networks for spectral data including spectral and spectral image denoising, spectral and spectral image classification, spectral image segmentation, and spectral image super-resolution.
Spectral acquisition and imaging play important roles across numerous fields such as machine vision, remote sensing, and biomedical imaging. While there is much potential for spectral deep learning applications, existing deep learning frameworks and models for computer vision are largely oriented towards RGB images. Spectral data differs substantially from RGB images, however, and poses numerous requirements for which standard neural network architectures, data augmentations, and hyperparameter defaults are often unsuitable. Application of existing deep learning models to spectral datasets thus requires careful modification and adaptation to make training on spectral data possible and effective. For example, while spectral augmentations (e.g., spectral flipping or shifting) may be applied, standard image augmentations (e.g., brightness or contrast changes) may introduce unwanted spectral distortions. Similarly, although 2D convolutional neural networks (CNNs) may be extended to multi-channel hyperspectral images, many spectral deep learning applications employ 1D or 3D CNNs, necessitating modification of existing 2D CNN architectures or the development of novel task-specific architectures. Lastly, the large size of spectral image hypercubes poses significant memory constraints which may require modification of network architectures and training hyperparameters (e.g., batch size, patch size, scaling, data augmentation) to enable effective single- or multi-GPU training.
We have thus developed spectrai, a deep learning framework designed specifically for spectral data. spectrai is built on the popular PyTorch library and includes baseline implementations of several networks for tasks including spectral calibration, spectral (image) classification, spectral denoising, spectral image segmentation, and spectral image super-resolution. In addition to a Python command line interface, spectrai provides a MATLAB graphical user interface (GUI) to guide non-expert users through deep learning training and inference procedures.
We demonstrate spectral image segmentation using the recently developed AeroRIT hyperspectral image dataset (dataset, paper).
AeroRIT Hyperspectral Image Semantic Segmentation.
We demonstrate spectral denoising using a dataset of Raman spectra of MDA-MB-231 human breast cancer cells (dataset, paper).
We demonstrate spectral image super-resolution using the HELICoiD dataset of intraoperative hyperspectral images of human brains (dataset, paper).
HELICoiD Hyperspectral Image 8x Spatial Super-Resolution.
spectrai is hosted on the Python Package Index (PyPI). The latest version of spectrai can be installed using:
pip install spectrai
Alternatively, the spectrai GitHub repo can be cloned directly as follows:
- git clone spectrai
git clone git@github.com:conor-horgan/spectrai.git
- cd to spectrai
cd spectrai
- pip install spectrai
pip install -e .
*Note: this will not include the spectrai.mlapp MATLAB application
If you would like to use the spectrai MATLAB GUI, please follow the following steps:
Note that we provide the spectrai MATLAB GUI as an editable MATLAB application (.mlapp) to enable further open-source development. If desired, this can be exported to create an executable file. See here for details.
-
Install MATLAB 2020b
-
Install Python 3.8
*Note: changes introduced in Python 3.9 are not compatible with MATLAB.
*Note: MATLAB will not work with Anaconda Python distributions.
-
In MATLAB, type the following to confirm the settings for MATLAB's Python interpreter (see here for details):
pyenv
-
Download spectrai.
-
In MATLAB, navigate the working directory to:
~/spectrai/spectrai
spectrai can be run from the command line by typing:
- To train a model from scratch:
spectrai_train
- To evaluate a pretrained model:
spectrai_evaluate
- To apply a pretrained model to a dataset:
spectrai_apply
The above commands will operate on a default config file provided in spectrai/spectrai/configs. To apply spectrai to new data, spectrai settings can be assigned in one of two ways:
- By default, settings are determined from .yml config files. Default config files are stored in spectrai/spectrai/configs. Users can develop custom config files, save them in the configs folder, and then specify them using the --config commandline flag, e.g.:
spectrai_train --config custom_config.yml --verbose
- Alternatively, users can start from a default config file and modify individual settings via the commandline as required, e.g.:
spectrai_train --activation PReLU --batch_size 16 --data_normalization "Max Value"
Suitable values for different parameters are listed in the default config files.
spectrai can alternatively be run from the MATLAB GUI. This GUI provides an easy-to-use interface that guides users through task selection, data loading, and data augmentation, as well as providing suggested initial default hyperparameter values. Additionally, the GUI provides visual feedback on losses and neural network outputs during training.
To run spectrai from the MATLAB GUI:
- Open MATLAB and navigate the working directory to:
~/spectrai/spectrai
- Type:
appdesigner
- Open spectrai.mlapp
- Click Run (green play button on top menu bar)
- Starting at Training/Inference do the following:
- In Training/Inference, select a training/inference option
- In Deep Learning Task, select a deep learning option
- Based on the option selected, unsuitable or irrelevant fields will be disabled (grayed out)
- In Data Manager:
- Select a data format
- Load input/target data as appropriate (by default assumes data is stored in a single directory as separate files unless the Data as Directory checkbox is unticked
- Select shuffle data, if desired
- Select split data and enter data splits, if desired
- In Training Hyperparameters, set training hyperparameters
- In Network Hyperparameters, set network hyperparameters
- In Data Augmentation, select any data augmentations desired
- In Preprocessing, set any data preprocessing required (example effects of preprocessing can be viewed by selecting Preview Spectra or Preview Images)
- Press Train, Evaluate, or Apply as appropriate
spectrai was implemented and tested in MATLAB R2020b and Python 3.8.8 using PyTorch 1.4.0 on a desktop computer with a Core i7-8700 CPU at 3.2 GHz (Intel), 32 GB of RAM, and a Titan V GPU (NVIDIA), running Windows 10 (Microsoft). spectrai has not yet been extensively tested in other environments (it's on our to do list).
If you find this code helpful in your work, please cite the following paper:
Conor C. Horgan and Mads S. Bergholt, "spectrai: a deep learning framework for spectral data.", arXiv preprint arXiv:2108.07595 (2021).