The main goal of this research was to develop a free, cross-platform tool for spectroscopic mapping and analysis, entitled Vespucci after the Renaissance cartographer Amerigo Vespucci. Vespucci offers several main advantages in comparison with other available instrument software and chemometrics packages such as Solo from Eigenvector Research, the scikit-spectra Python library, and the hyperSpec and chemoSpec R packages.
Licensing of commercial products. The restrictive licensing of numerous proprietary instrument software and chemometrics packages precludes the use of the software on devices owned by individual researchers without the purchase of an additional license. The expense and availability may make the implementation of advanced analysis techniques inaccessible to researchers. By releasing this software on the Internet at no cost, with no proprietary dependencies, barriers to use due to software licensing are removed .
Ease-of-use. Existing software packages for spectroscopic data analysis are generally written with advanced users in mind. These packages come as a library of functions, which must be called from a command-line interface. This interface affords a great deal of customization at the expense of ease-of-use for less advanced users. Vespucci is driven by a graphical user interface (GUI) that is intuitive to use even by beginners. No programming knowledge is necessary to use the software, but extensions written in Octave, which is mostly code-compatible with MATLAB©, and R may be used by more advanced users.
Vespucci is capable of several of the most common data pre-processing techniques in chemometrics, as described below.
Smoothing. Vespucci supports a number of smoothing methods including moving average filters, median filters, Savitzky-Golay smoothing and Whittaker smoothing.
Data selection. Individual spectra are easily viewed and manipulated. Spectra may be removed by threshold to reject clipped or poorly-focused spectra. Spectral data beyond a certain spatial range in a spectroscopic image may also be removed.
Normalisation. Vespucci supports min/max normalisation (subtraction of the minimum of each spectra followed by division by the maximum), unit area normalisation (dividing each spectra by its sum), standard normal variate normalisation, Z-score normalisation, normalization by the maximum intensity at a particular spectral abscissa range, scaling by a particular number, vector normalisation of each spectrum vector, and mean-centring.
Analysis and Imaging
Vespucci supports a variety of powerful and commonly-used methods for spectral data analysis, as illustrated below.
Univariate. Vespucci is capable of univariate analysis and imaging by peak intensity, peak area, and peak width (estimated full-width-at-half maximum), area ratio between two peaks, and intensity ratio between two peaks.
Multivariate. Vespucci is capable of classical principal component analysis (PCA), a widely-used method for dimension reduction, both using the singular value decomposition, and partial-least-squares (PLS) regression (Vespucci, like MATLAB, uses the SIMPLS algorithm for PLS regression ). Vespucci is capable of Vertex Component Analysis (VCA), an algorithm for dimension reduction and endmember extraction . This algorithm finds the spectra in the dataset that are responsible for the most variance. Images can be created from the component scores generated by both methods.
Peak detection. Vespucci uses a peak-finding method based on convolution with a Mexican hat kernel, mathematically identical to the continuous wavelet transform (CWT). This method was first developed by Du for analysing proteomic mass spectrometry data , and was then applied to Raman spectroscopy by Zhang . It uses a signal smoothed by Mexican hat kernels of varying width to determine the peak centres of the unsmoothed data. This facilitates the determination of the local extrema with smooth signals. A “chemical barcode” can then be constructed from these results, allowing the researcher to identify spectral signatures within the data and to determine which spectra contain which peaks of interest.
Imaging. Vespucci utilizes several colour scales for different purposes. The traditional, “rainbow” colour scale is implemented, along with a rainbow colour scale (“VespucciSpectral”) that runs from black to white. Vespucci implements modified versions of the ColorBrewer  colour scales, which are designed to increase linearly in perceived luminosity and overcome problems identified with the rainbow colour scales . Scale bars of arbitrary size can be added, and images can be saved in both vector (PDF, SVG) and raster (TIFF, BMP, PNG, GIF, JPEG) formats.
External Code Interface
Code written in R, Octave, and most code written in MATLAB© can be executed from Vespucci using the external code interface. This allows researchers to use existing codebases with the software. Vespucci depends on an installation of R to execute code on objects stored in shared memory. Vespucci is distributed with a copy of the Octave interpreter as a DLL file. All data objects associated with each dataset can be exposed to the interface at the discretion of the user.
Vespucci is designed so that a user with an understanding of basic GUI paradigms can easily utilize the software (Figure 1). The main window of the program consists of two panes. The left pane consists of a list of datasets on which operations can be performed. The right pane is a list of images created through the various available imaging techniques.
Vespucci supports the two most common ASCII (*.txt) formats: the “wide text” format in which each row of the file represents a spectrum, and the “long text” format in which spectra are concatenated sequentially. Data import is handled by a simple dialog. Because text files do not contain metadata about the abscissa or ordinate labels, the user can specify labels in the import dialog.
Vespucci is capable of handling a wide variety of spectroscopic data, including infrared spectroscopy, ultraviolet-visible spectroscopy and frequency-domain terahertz spectroscopy, with spatial or temporal metadata. The use of Vespucci for several tasks in the analysis of Raman and surface-enhanced Raman spectroscopic data has been demonstrated below.
Surface-Enhanced Raman Spectroscopy (SERS)
The utility of Vespucci for several SERS studies has been shown in unpublished works and several replications of previous works. SERS is a Raman spectroscopic technique that utilises plasmonic nanomaterials, such as silver and gold nanoparticles, to enhance the intensity of Raman signals for the qualitative and quantitative determination of analytes at trace concentrations .
Probing nanoparticle-virion interactions. Spectroscopic data analysis is primarily concerned with the extraction of chemical information based on the presence and profile of “peaks” in spectra. When a dataset is very large, manual peak finding and determination become time consuming and are prone to human error. Automatic evaluation of peaks in vibrational spectroscopy, with nonlinear baselines and substantially broadened peaks, can be difficult. A rigorous, baseline-independent method to determine peaks of varying widths is needed in these cases. The “CWT” method fits these criteria , but was previously only available as a command-line R package. Vespucci provides the first implementation of this algorithm with a graphical user interface.
Vespucci’s peak detection methods have been used to determine spectral regions of interest for subsequent analysis. The goal of this work is to use the chemical information found in the peaks to determine the chemical environment inhabited by AgNPs when interacting with virions. Dengue virus samples were incubated with AgNPs then inactivated and deposited on glass slides. All Raman signals were smoothed with a median filter of window size 7 (Figure 2) and normalized to the glass signal centred near 2600 cm–1 (Figure 3). Spectra of glass slides without sample were recorded as a control measurement. The average glass spectrum was fitted with a Voigt curve in Origin 8.0. The glass signal fit was subtracted from all samples, and those samples whose maximum signal intensity was less than one half the intensity of the glass spectrum were removed. The CWT-based peak finding method (Figure 4) was then applied to produce a “chemical barcode”, a bar graph plotting the total detected peak centres against wavenumber (Figure 5). The general peak regions corresponding to each peak were then determined by estimating the width of the peaks in the bar graph. Vespucci provides, for the first time, an automatic and reproducible system for determining potential spectral regions of interest for the interaction of AgNPs and virions. Pre-processing and subsequent analysis were completed with only a few clicks of the mouse. This approach may also be applicable for other nanobiological studies (e.g., cell-nanoparticle and biomatrix-nanoparticle interactions) when analyte concentrations are very low.
SERS substrate assessment. The univariate imaging features of Vespucci can be used to assess the SERS capabilities of silver nanorods (AgNRs). AgNRs were constructed by the vapour deposition of silver onto silicon platforms at two different temperatures (100 and 300 K). The resulting SERS substrates were then exposed to a solution of rhodamine-6G (R6G) as a test probe and imaged. In addition to determining the spatial distribution of SERS “hotspots” (areas where R6G may experience higher enhancement) on each substrate, the two samples could be easily compared by using a common colour scale between them. The data was processed with a median filter of window size 7, followed by standard normal variate normalization. Univariate images of the Riemann sum of the spectral region from 1625 to 1675 cm–1, corresponding to a xanthine breathing marker mode (Figure 6 and 8), were compared to determine differences in overall enhancement. The values were larger for the substrates synthesized at 100 K than for the substrates synthesized at 300 K (Figure 7), because the colder temperature provided favourable kinetics to produce denser and better-aligned AgNR surfaces .
Bone mineralisation. Bone consists of both organic (bone marrow, collagen) and inorganic (hydroxyapatite) components. While increase in inorganic components and subsequent crystallisation corresponds to bone strengthening, abnormal bone mineralisation interferes with vascularization, inhibiting growth. The intensity of spectral signatures corresponding to inorganic moieties can be used to assess the degree of mineralisation of biomaterials. A toxicological study was devised to examine the interaction between platinum group metal (PGM) salts and developing chick embryos . This work utilises the data processing and univariate analysis features of Vespucci to demonstrate how PGM salts interfere with the mineralisation process.
Raman spectral scans were performed on slices of chick embryo tibiotarsi. Embryos were exposed to PGM solutions in ova on the 7th and 11th day of incubation in order to study potential bone structural changes due to exposure to PGMs. Crystallisation was assessed and spatially determined by observing intensity near the ν1 band of phosphate (search range 946–976 cm–1). The crystalline structure can be observed (Figure 9) in multiple colour scales.
Use of C++ API
The Vespucci C++ API allows for the creation of specialty programs to perform the same task on multiple datasets. Here, a simple program to pre-process and perform VCA of all datasets in a particular folder is demonstrated in the Examples folder in the source tree. The procedural maths library, combined with a few Qt classes, was used to automate the data analysis and pre-processing workflow.
Implementation and architecture
In Vespucci, datasets are stored as VespucciDataset objects, which contain an Armadillo matrix containing the spectra as columns, metadata (including spatial or temporal coordinates and the spectral abscissa) and associated processing and analysis methods. Math functions are handled by the VespucciMath namespace, which contains basic algorithms for the analysis and processing methods (some simple processing methods are handled in the VespucciDataset class). Data import is handled by the TextImport and BinaryInput namespaces. VespucciMath can thus also be used as a procedural API for dealing with spectroscopic data files. The output of analysis methods are stored in AnalysisResults objects (or in MLPACKPCAData, PLSData, PrincipalComponentsData, UnivariateData or VCAData objects), which are heap allocated using smart pointers and accessed through the VespucciDataset parent object. The GUI form classes interact with datasets entirely through smart pointers to VespucciDataset objects, which are managed through a VespucciWorkspace object that contains information about the operating environment and the currently open datasets.
R integration is handled through the RInside library. A local instance of R is created, and the variables requested by the user to send to the environment are added. The code specified by the user is then executed, and the variables requested by the user are returned to Vespucci, either to the VespucciDataset object (in the case of spectral or abscissa data) or to a new AnalysisResult object.
Octave integration is handled through the Octave C++ API via a helper process, using the Boost Interprocess Communication library (this is due to the fact that Octave for Windows is distributed only as 32-bit binaries). A shared memory object consisting of copies of the variables requested by the user is created by Vespucci then accessed by the helper process, which creates Octave objects from the memory used by the Armadillo objects, writes an Octave function containing the code specified by the user, then calls the function. The variables requested by the user are then converted back into Armadillo objects and placed in a shared memory object that is accessed by Vespucci, which creates AnalysisResult objects or modifies members of the VespucciDataset object.
Vespucci’s output was compared to the output of existing packages for the included methods (MATLAB, R and Octave implementations), and found to be identical (with the exception of the VCA method, where initial endmembers are selected at random). Unit tests for the mathematics namespace are included in the source tree. Vespucci has been tested for ease-of-use and stability with favourable results.
Vespucci has been tested on Windows 7, Windows 8, Windows 10, and Ubuntu 15.04 (“Vivid Vervet”). The Windows binary distribution is only compatible with 64-bit versions of Windows. Vespucci depends only on cross-platform libraries, so compilation on other Unix-like operating systems, including Mac OS X, is possible.
Vespucci utilizes initialiser lists and lambda functions, and will compile on most C++11-compliant compilers. Vespucci has been compiled successfully on GCC 4.9.1 and Clang 3.6.0.
Additional system requirements
Proper performance requires an Intel Core 2 or better processor, and at least 4 GB of RAM. Since datasets are stored entirely in RAM, computers with more RAM are capable of dealing with larger numbers of larger datasets (A single spectrum with 4096 spatial points has a size of about 50 kB).
Vespucci for Windows is distributed with all necessary DLL files for normal operation. R integration requires R 3.1.3 or higher and the R packages RCpp, RCppArmadillo and RInside (which are also linked as C++ libraries). While the Windows binary distribution is compiled in x86_64 bytecode, Octave integration is handled by a helper process compiled in 32-bit x86 bytecode, because Octave for Windows is distributed as 32-bit binaries.
Compiling Vespucci from source requires MLPACK and its dependencies (Armadillo, HDF5, BLAS (or replacement), LAPACK (or replacement), ARPACK, and Boost (only the Program Options, Random, Math and Unit Test Framework must be compiled)), Qt 5.0 or higher, CMinpack, and a fork of QCustomPlot distributed with the Vespucci source.
List of contributors
The primary author of the Vespucci source code is Daniel P. Foose.
Vespucci integrates code from several other projects under the GPL license. The SIMPLS algorithm implementation was translated from the Octave Statistics package written by Fernando Damian Niewveldt. The VCA  and hySime algorithms were ported from code written by José Nascimento and José Bioucas Dias.
Vespucci is inspired by an unpublished MATLAB package written by Adam C. Stahler. User testing has been provided by M. Ali Akbar, Kevin A. O’Neil, Seth W. Brittle and Sesha A. Paluri.
Licence: GNU General Public License Version 3
Date published: 28/07/2015
(3) Reuse potential
Vespucci is useful to researchers in any field that involves spectroscopy, including chemistry, biochemistry, molecular and cellular biology, biomedical engineering, materials science and engineering, and physics. Vespucci is designed to be useful for both novices and advanced scientists.
The authors declare that they have no competing interests.