The brukeropusreader Python package enables reading the binary OPUS files generated by Bruker spectrometers.
read_file
parses OPUS file and returns OpusData
object:
from brukeropusreader import read_file
opus_data = read_file('opus_file.0')
OpusData
consists of three fields wave_nums
, spectrum
and meta
:
print(f'Dimension of data: '
f'{len(opus_data.wave_nums)}')
print(f'Spectrum range: ['
f'{min(opus_data.spectrum)}; '
f'{max(opus_data.spectrum)}]')
print(f'Metadata: '
f'{opus_data.meta}')
Spectrum can be plotted with matplotlib
library:
plt.plot(opus_data.wave_nums, opus_data.spectrum)
plt.show()
For full code see example.
OPUS files consist of several series of spectra. Each series is described by a few parameters:
- NPT (number of points)
- FXV (value of first wavelength)
- LXV (value of last wavelength)
- END (address of spectra series)
These parameters are found by searching for ASCII strings in the binary files. After finding a match with one of these parameters, we move the pointer a few bytes further to read the values. Unfortunately, there is no published open standard describing how much further the pointer should be moved. We empirically checked that this shift factor is 8 bytes for NPT, FXV, and LXV, and 12 bytes for END. In addition, each file contains some metadata about the hardware used for measurement.
As Bruker's OPUS file format is not described openly, we do not know its exact structure. One problem is, given only a few series, how to decide which are absorption spectra? Our solution, empirically developed, is as follows:
- Remove broken series (such as ones where FXV > LXV, missing NPT information, etc.)
- Remove interferograms. (See simplerspec.) Interferograms have a starting value of 0.
- If after these two steps we still have more than one series left, choose the one with highest average value. We empirically verified that other series are usually random noise with values near 0.
For developer issues, please start a ticket in Github. You can also write to the dev team directly at [email protected]. For other issues, please write to: [email protected]
Copyright (c) 2018 Quantitative Engineering Design. All rights reserved. This project is released under the terms of the AGPL license, which is included in LICENSE.txt.
-- QED | https://qed.ai