Align NMR Spectra

In example Load a 2D dnpdata object and calculate enhancements we calculated the ODNP enhancement for all protons in toluene, across the entire spectrum. However, the resolution of the spectrum is high enough to resolve the individual NMR peaks of the methyl group and the aromatic protons. This will allow us to calculate the enhancements for the individual peaks. However, as common in low-field NMR spectroscopy, we first have to correct spectra because of the field drift. While magnetic field drift is not an issue in high-field NMR systems using a superconducting magnet, this is not the case in low field systems that either use a electromagnet or a permanent magnet. Peaks will drift and simply averaging over a longer period of time will result in broadened peaks and therefore decreased resolution.

The align routine implemented in DNPLab overlays each individual scan by maximizing the FFT cross-correlation of each scan with a reference scan. This method shifts the spectra in discrete points and calculates the cross-correlation function between the two spectra for each step. The maximum correlation corresponds to the optimum overlap (maximum of the cross-correlation function) between the spectra. This method has successfully been used in ODNP Spectroscopy. For more information about alignment methods for NMR spectra check out the article by Vu et al..

Load NMR Spectral Data

Start with importing the NMR spectra from the previous example (Create a 2D dnpdata object from set of individual spectra).

import dnplab as dnp

file_name_path = "../../data/h5/PowerBuildUp.h5"
data = dnp.load(file_name_path)
data.attrs["experiment_type"] = "nmr_spectrum"

When plotting the data notice that the peaks are not aligned due, in this case, to magnetic field drift.

dnp.fancy_plot(data, xlim=[-10, 20], title="ODNP, 10 mM TEMPO in Toluene, Not Aligned")
dnp.plt.show()
ODNP, 10 mM TEMPO in Toluene, Not Aligned

Align Spectra

To align the NMR spectra call the align function dnp.ndalign(). This process may take a couple of seconds if the 2D NMR data set is large.

data_aligned = dnp.ndalign(data)

# # %%
# # Next, let's plot the aligned data. Note, that the spectrum is not referenced correctly.

dnp.fancy_plot(
    data_aligned, xlim=[-10, 20], title="ODNP, 10 mM TEMPO in Toluene, Aligned"
)
dnp.plt.show()
ODNP, 10 mM TEMPO in Toluene, Aligned

Save Aligned Spectra

The last step is to save the aligned spectra for further analysis. Similar to the previous example (Create a 2D dnpdata object from set of individual spectra) we will save the entire workspace in the h5 file format.

file_name_path = "../../data/h5/PowerBuildUpAligned.h5"
dnp.save(data_aligned, file_name_path, overwrite=True)

Total running time of the script: (0 minutes 1.866 seconds)

Gallery generated by Sphinx-Gallery