Abstract
We introduce ssNMRlib, a comprehensive suite of pulse sequences and jython scripts for user-friendly solid-state nuclear magnetic resonance (NMR) data acquisition, parameter optimization and storage on Bruker spectrometers. ssNMRlib allows the straightforward setup of even highly complex multi-dimensional solid-state NMR experiments with a few clicks from an intuitive graphical interface directly from the Bruker Topspin acquisition software. ssNMRlib allows the setup of experiments in a magnetic-field-independent manner and thus facilitates the workflow in a multi-spectrometer setting with a centralized library. Safety checks furthermore assist the user in experiment setup. Currently hosting more than 140 1D to 4D experiments, primarily for biomolecular solid-state NMR, the library can be easily customized and new experiments are readily added as new templates. ssNMRlib is part of the previously introduced NMRlib library, which comprises many solution-NMR pulse sequences and macros.
1. Introduction
Nuclear magnetic resonance (NMR) is arguably the most versatile spectroscopic technique, with applications ranging from studies of molecules in the solid, liquid or gas phases to complex materials and even entire organisms. The versatility of NMR spectroscopy is rooted in the countless opportunities to manipulate nuclear spins. Nowadays, the NMR spectroscopist can choose from a large number of highly specialized pulse sequences to obtain answers to specific questions related to molecular structure or dynamics. Most NMR experiments contain a number of building blocks used for transfer of coherence, for observation of chemical shifts in directly observed or incremented indirect dimensions and blocks monitoring spin evolution due to relaxation, or spin evolution under the action of (dipolar or chemical-shift anisotropy – CSA) recoupling sequences. The quality of NMR data critically depends on the precise setting of many parameters related to each of these building blocks. As a consequence, setting up an NMR experiment that yields the best possible data is often a complex time-consuming procedure even for specialists. Accordingly, valuable experiment time is often spent on optimizing parameters. Furthermore, keeping track of already optimized parameters in one experiment for use in another experiment that uses the same building blocks is an error-prone process. In facilities with multiple spectrometers, it is often a concern how the pulse sequences are centralized, how one can obtain a set of parameters that safely works for a given pulse sequence on a given spectrometer, or how to transfer an acquisition parameter set from one spectrometer to another.
Here, we introduce a library of pulse sequences, scripts and intuitive graphical-interface-based setup routines for solid-state NMR experiments on Bruker spectrometers, ssNMRlib. This library is built upon NMRlib, recently developed for biomolecular solution-state NMR , and has numerous solid-state NMR-specific features that greatly facilitate the key tasks of the experimentalist, from parameter optimization and storage of optimized parameters to rapid and easy setup of complex pulse sequences, centralization of pulse sequences and user-friendly storage of acquisition parameters for later use in publications or laboratory notebooks. ssNMRlib is open to many kinds of applications. We have included so far more than 140 pulse sequences for biomolecular MAS experiments, including heteronuclear multi-dimensional (1D–4D) correlation spectroscopy for resonance assignment, structure determination and dynamics studies, using , and detection; and detection is currently being added. The ssNMRlib concept is fully open to accommodating many kinds of pulse sequences and thus not limited to biological ssNMR. The possibility of the user including new experiments in the library – which then can also benefit from the automatic setup routines – is a central idea to ssNMRlib. The integration into NMRlib offers many additional scripts and macros e.g. for data processing or python-based fitting and printing. In this article we describe the key philosophy and concepts of the library and the workflow and exemplify its use with several applications.
Overview of the aims of ssNMRlib
The central design ideas behind ssNMRlib are summarized in Fig. a. We sought to create a tool that accesses a central library of scripts and pulse sequences, which allows setting up of experiments independently of the magnetic field strength and which takes into account the installed probe head. Parameters specific to a given machine and probe head (such as Larmor frequencies and radio-frequency (RF) power levels) are loaded by a centralized script that reads spectrometer- and probe-specific values.
Furthermore, as many pulse sequences use common building blocks, e.g. for coherence-transfer steps, an important aim of ssNMRlib is to allow the user to optimize the relevant parameters once, ideally in an automated manner. The optimized parameters are saved without the need for additional user interference (but with the possibility of editing all parameters). These optimized parameters are then automatically read into more complex experiments, where these building blocks are needed. To facilitate the setup further, ssNMRlib proposes reasonable starting values, e.g. for cross-polarization transfers, taking into account the (automatically retrieved) MAS frequency. The transfer of parameters between different experiments (e.g. the retrieval of cross-polarization (CP) parameters to be used in complex 2D/3D/4D experiments) is facilitated by a common nomenclature of parameters, as outlined in Table S1 in the Supplement.
Pulse sequences in ssNMRlib are written such that the power levels relevant for pulse sequence elements are entered as constants (cnst) in units of Hertz or kilohertz, rather than in Watt or dB. Field strength in kilohertz is the relevant quantity for essentially all transfer steps, e.g. for Hartmann–Hahn cross-polarization conditions , for many common recoupling schemes such as HORROR , DREAM , PAIN , DARR or MIRROR , as well as for decoupling. Handling power levels in kHz units rather than Watt/dB is, therefore, more convenient and intuitive. The conversion to Watt units is done internally within the pulse sequences, using the hard-pulse calibration. We find that, on temporary hardware with linearized amplifiers, one can calculate accurate power levels in Watt from a single 90 pulse calibration.
In all cases where selective pulses are used, e.g. in CO-CA INEPT transfers or homonuclear decoupling in indirect dimensions, the pulse power levels are calculated directly within the pulse sequences using the desired excitation bandwidth (in ppm); i.e. at each field strength the correct power level is calculated. The user does not need to take care of the power-level calibration of any shaped pulse.
An important further consideration when designing NMRlib is the possibility of adding new experiments to the library, which then are accessible as a button that performs the setup of the experiment. To include a novel experiment in ssNMRlib, buttons are available which create the template and setup scripts from an experiment that has been collected. The newly created setup routine is available as a button in the ssNMRlib browser window (see below). The organization of buttons within the NMRlib GUI tree structure is fully customizable.
We have, moreover, implemented a safety check routine, which verifies whether the chosen RF parameters (pulses, ramps, parameter optimizations, vdlist, delays, etc.) are within the probe-specific limits.
2. Implementation of ssNMRlib
NMRlib is an add-on in the Bruker Topspin software and has been tested currently on Topspin 3.5, 3.6 and 4, on Linux host computers, and on AVANCE III and NEO consoles. ssNMRlib is part of the NMRlib library and is installed at the same time as NMRlib. The NMRlib GUI window is launched directly from a button within the Topspin software (see Fig. a). NMRlib comprises a set of jython scripts, pulse sequences, selective-pulse and ramp shapes, and acquisition lists (vdlist, vclist, etc.), which can be saved either locally on one spectrometer or on a centrally mounted disk (which may be on one spectrometer) to which all spectrometers have access. The latter is very useful for ensuring that a whole facility uses the same experiments. The individual experiments (pulse programs, one jython script for acquisition, one for processing parameters and one for the security check) are organized in a directory tree structure and buttons in the GUI windows allow navigation through these directories. The organization of the experiments can be fully customized, and new experiments can be added to any location within the file structure. The library also contains all the shape files for selective pulses, amplitude ramps, etc., and decoupling sequences used by ssNMRlib, as well as a file required for safety checks (see below). On each spectrometer, the files with the correct routing need to be available, e.g. for , or detection experiments. The principal elements of the prosol table (power levels of the different channels) need to be up to date. These latter instrument-specific files, together with the general, non-instrument-specific scripts and the pulse sequence, contain everything needed to run ssNMRlib on a given instrument.
Part of the current ssNMRlib experiment file tree is shown in Fig. b. Example screenshots of the NMRlib windows are shown in Fig. a. Currently, the library is organized to have in the top level branches (buttons) for setup experiments (KBr, adamantane), a main branch containing -, - or -detected experiments, as well as buttons leading to scripts, including those that allow addition/removal of templates to/from the library, saving acquisition parameters or retrieving them from a previous session. In addition, the NMRlib window also contains an “Editor” button to navigate directly to the folder structure that contains the underlying scripts and pulse sequences pertaining to a given NMRlib window (“pp” – pulse sequences, “py” – jython scripts, and “vc” and “vd” – lists). Furthermore, a “Save” button allows an experiment to be saved in order to create a template from an experiment that has been acquired (see Sect. ).
The tasks performed by a typical script in ssNMRlib which sets up an experiment are shown in Fig. b. It starts by reading a file that contains the probe/amplifier routing. The further steps of the setup script load the pulse sequence, adjust the dimensionality, read the current MAS frequency, set pulse lengths (either from prosol or, if available, from a previous calibration), calculate acquisition parameters based on the MAS frequency and e.g. Hartmann–Hahn condition or automatically retrieve previously optimized parameters, calculate the decoupling power levels from kHz values and load processing parameters. Lastly, the script opens a GUI window that summarizes the most important parameters (Fig. , centre). The user may manually modify parameters at this step. Of course, all parameters can also be changed at any point in the AcquPars tab in Topspin. Another added value of the ssNMRlib software is that all the parameters of an experiment are automatically checked to ensure the probe safety before launching an experiment.
2.1. Workflow with ssNMRlib
The typical workflow with ssNMRlib can be described as follows. After setup of the sample spinning and probe tuning, possibly with adjustment of the magic angle and shims (templates for KBr acquisition and adamantane observation are included in ssNMRlib), the user typically wants to calibrate 90 pulses. A number of automated routines, described below, allow pulse calibration. The optimized values are stored and then used for the setup of all other experiments. In a similar manner, further calibration experiments e.g. for cross-polarization or scalar-coupling-based transfer are available with buttons in the calibration menu, and their optimized values (power levels, shape parameters, durations, etc.) are likewise stored by ssNMRlib. All optimized parameters of hard pulses and transfer parameters are stored in a dedicated text file. This file can also be re-imported into ssNMRlib at a later point; this feature is handy e.g. if one interrupts a measurement session and continues at a later time point, starting with the previously optimized acquisition parameters.
Once all the required transfers and pulses have been optimized, clicking a button for a specific experiment (e.g. a 2D, 3D or 4D correlation experiment) executes a script that automatically reads the optimized parameters used in all the transfer steps, calculates power levels and shapes, and sets up the particular experiment. These steps are described in the following sections.
2.1.1. Pulse calibration
A number of experiments for 90 pulse calibrations are available, e.g. a nutation experiment with a direct hard-pulse excitation or with CP or INEPT transfer schemes. Figure exemplifies a pulse calibration with a -detected hNH experiment, typically used for proteins at fast MAS. The underlying python script loads the instrument-specific parameter set (routing, power levels, pulse lengths, etc.) and pulse sequence and sets up a parameter optimization (popt in Bruker language) protocol using pre-defined spectral ranges to be observed (e.g. amide frequency range) and the range of values used for the parameter optimization, in this case pulse length. This range is based on typical values for the present probe, which are retrieved from the prosol table. At the end of the parameter optimization, the pulse duration is retrieved automatically (e.g. from finding the zero-crossing of the integrated spectral intensities). The value of the 90 pulse is stored, and can be inspected and modified within the NMRlib window any time (Fig. ).
2.1.2. Automatic calculation of power levels and shapes in ssNMRlib
With calibrated 90 pulse durations and power levels and a linearized amplifier, all power levels of decoupling and recoupling pulses and shapes as well as selective pulses can be calculated automatically. ssNMRlib does not require the user to do any calculation in Watt or dB units but wherever possible makes calculations from user-specified values in kilohertz units. Furthermore, selective pulses, e.g. REBURP, EBURP or ISNOB , are directly calibrated within the pulse sequence, based on the known characteristics of a given pulse shape, as well as the desired excitation bandwidth.
Figure shows pulse sequence snippets that illustrate how these calculations are done in practice. The calibrated 90 hard-pulse durations and power levels can be translated to the RF field strengths (assigned to variables cnst1, cnst2, cnst3, and cnst4 for , , and nuclei, respectively) that correspond to the power levels at which these pulses have been calibrated. Selective pulses are then calculated for a given shape, excitation bandwidth, spectrometer frequency and the hard-pulse calibration. The use of the spectrometer frequency ensures that the parameters are calculated correctly for any field strength. Possible frequency shifts from the carrier to the excitation band are calculated in a spectrometer-independent manner (in ppm).
The calculation of power levels for cross-polarization or other amplitude ramps is illustrated in Fig. c, d. The power level is specified by the user in kilohertz as constants (cnst) in Topspin and internally translated to Watt, using the 90 hard-pulse durations and power levels. The use of kHz values allows the user to immediately have a reasonable set of starting values, based on Hartmann–Hahn matching conditions for CPs, HORROR conditions, etc.
Currently, the shape files are not created on the fly (which might be done with Bruker's WaveMaker library), but they are stored locally. The user can change the CP ramp file to any desired shape in the AcquPars tab. Just like these recoupling sequence elements, the decoupling power levels are calculated from desired RF field strengths (in kHz).
2.1.3. Optimization of transfer elements
The calibration of transfer steps, based on e.g. cross-polarization, of other dipolar-based transfers such as RFDR, DREAM, BSH-CP, and INEPT-based transfers, follows a similar philosophy, exemplified in Fig. for the optimization of a CO-CA BSH-CP (left) and - CP transfer (right). Dedicated buttons for each of these transfers allow loading of calibration experiments, which use the previously optimized hard pulses. A ssNMRlib window summarizes the acquisition parameters, allows the ramp or the carrier position to be chosen and sets up a popt optimization protocol. The optimized parameters are stored for later use in other experiments in ssNMRlib and can be modified from the NMRlib GUI and saved to a file. In addition, a function termed “Load constants” allows retrieval at any point of a particular set of parameters, e.g. the cross-polarization power levels, shape and duration.
ssNMRlib is open to the use of different modes of detection ( , , ) within the same session and on the same probe. For example, one may want to collect a -detected experiment and a -detected one on the same sample and same probe. Accordingly, calibrations done in one detection mode (e.g. a N–C CP transfer optimized with a -detected experiment) are automatically retrieved for a -detected experiment that uses this transfer (e.g. a H–N–C correlation experiment).
Of note, ssNMRlib uses a uniform naming convention for acquisition parameters. For example, a common parameter name, such as cnst41, is used for the CP power level of in all occurrences of CPs, and it is different from e.g. the one used for the power in CPs. This clear naming convention (see Table S1) additionally helps the user to retrieve parameters – although ssNMRlib is made such that the user does not need to remember those names, due to the automatic parameter retrieval. It is recommended to use the same naming convention when adding new experiments. A consistent naming convention is also very useful for safety checks (see Sect. ).
2.2. Current content and organization of ssNMRlib
ssNMRlib can be fully customized, i.e. experiments can readily be added and deleted, and the organization can be modified, as described in Sect. . This section describes the current state of ssNMRlib, containing some 140 different pulse sequences, including a number of general homonuclear and heteronuclear correlation experiments and a large panel of proton-, carbon- and nitrogen-detected 1D, 2D, 3D and 4D experiments for resonance assignments, structure determination and measurements of molecular dynamics. The nomenclature used below to describe experiments employs upper-case letters for nuclei of which the chemical shift is edited and lower-case letters for nuclei which are not frequency-edited. The full list of experiments currently in ssNMRlib is shown in Listing S2 in the Supplement.
2.2.1. One- and two-dimensional experiments with or detection
- and -detected experiments are most useful for samples spinning at moderate MAS frequencies, typically using 3.2 mm rotors (the use of 4 and 1.9 mm rotors can be implemented in a straightforward manner). ssNMRlib contains -detected and -detected experiments with CP or INEPT transfer or direct excitation as well as 1D versions of double-CP hnCA and hnCO experiments. Experiments for measurement of longitudinal relaxation (saturation recovery) are useful for choosing an appropriate recycle delay; furthermore, and transverse ( ) relaxation rate constants provide a rapid view of the coherence lifetimes and may be useful for optimizing decoupling parameters.
Two-dimensional -detected experiments comprise homonuclear correlations with DARR , DREAM , ALFRESCO , RFDR and CHHC transfer. A -detected proton-driven spin diffusion (PDSD) experiment and a NHHC experiment are also available. Additionally, correlation experiments based on SPC5, S3 and various C and R sequences are under development. These pulse sequences are useful for a number of organic solids including biomolecules.
2.2.2. Carbon-detected resonance assignment experiments
Currently, a dozen -detected experiments are present in ssNMRlib for high-dimensional (3D, 4D) correlation spectra. The majority of the presently available experiments are intended for protein resonance assignment, including 3D hNCACB, hNCACX, hNCOCX, hCANCO, hCONcaCB, and hCOCACB and 4D hCANCOCX, hCONCACO and hCONCACB experiments, which use cross-polarization for H–X and N–C transfers. For transfers, we have implemented several options, including DREAM , DARR , RFDR and BSH-CP transfers. Figure shows one backbone pulse sequence from the library, a 3D h-CO-CA-CB experiment with BSH-CP and DREAM transfer steps, which, to our knowledge, has not been proposed before, and its application to a 50 kDa protein that assembles to tube-like structures .
2.2.3. Carbon-detected experiments for flexible systems
A suite of experiments has been implemented for application to flexible molecular systems, where CP-based transfers are inefficient, and scalar-coupling-based transfer is the better choice for correlation spectroscopy. This kind of experiment has been successfully applied, e.g. to bacterial peptidoglycan cell walls or flexible tails in proteins . We have implemented and HETCOR experiments, hNCA, hNCO, hNcoCA, hNcaCO and hCC correlation spectra, all based on INEPT transfer steps between H–N, H–C, C–C and N–C nuclei. An additional hCC experiment with an initial H–C CP transfer followed by a C–C INEPT transfer is particularly useful for systems with some degree of flexibility that still have sufficiently large dipolar H–C couplings to make the initial H–C CP the most efficient choice. We have furthermore experiments with direct excitation followed by C–C INEPT transfer.
2.2.4. Proton-detected protein resonance assignment experiments
The largest part of the current ssNMRlib implementation comprises -detected experiments, which are ideally used in combination with deuteration and reprotonation of e.g. amide, methyl or aromatic sites . When used at MAS frequencies above 60–100 kHz, fully protonated systems can also yield comparably good line widths . The 2D experiments comprise basic and correlations and simultaneous and 2D correlation experiments, with either INEPT or CP transfers.
ssNMRlib currently comprises more than 40 different experiments for protein resonance assignment with or detection (listed in Listing S2 in the Supplement). The 3D and 4D experiments for protein resonance assignment comprise all possible correlation spectra of the amide moiety with the , , and nuclei at both sides of the amide; 3D and 4D variants are implemented.
We have used the following general principles when designing these experiments.
-
-
Cross-polarization is used for all transfers between and either or as well as for the transfers between and (either direction). Additionally, for the case of the intra-residue and inter-residue experiments, the variants with N–C TEDOR transfers are implemented.
-
-
For or transfers, we have implemented different coherence-transfer elements: (i) refocused INEPT for unidirectional experiments such as hCACONH or INEPT for out-and-back transfers such as in hcoCAcoNH; (ii) additionally, experiments with band-selective cross-polarization (BSH-CP) have been implemented; this transfer, based on dipolar couplings, may outcompete INEPT-based experiments when fast coherence decay hampers the latter.
-
-
For transfers, we have implemented experiments based on scalar-coupling transfer, akin to solution-state HNCACB or HNcoCACB experiments; the setting of the transfer delay leaves the user the freedom to choose either full transfer to or only partial transfer, which results in both and signals.
-
-
In experiments with INEPT-based transfer and chemical-shift editing of one of the two involved carbons or both of them, the chemical-shift evolution is done in a constant-time (CT) manner. CT editing comes at no cost in terms of sensitivity; i.e. the FID along this dimension does not decay. CT editing requires that the maximum evolution time is kept within the INEPT transfer delay, which is typically of the order of 6–7 ms. Additional semi-constant-time versions which do not have these limitations are also implemented.
-
-
In experiments that involve a dipolar-coupling-based transfer, e.g. with BSH-CP, no constant-time editing is done, because unlike the INEPT case above, the chemical shift cannot be edited during the transfer.
-
-
We have systematically implemented homonuclear ( ) decoupling in all indirect dimensions, in particular CO decoupling during CA frequency editing (and vice versa), using a band-selective inversion pulse (ISNOB-2, ). This shape is advantageous because of its good compromise of pulse duration and cleanliness of the inversion profile. To correct the Bloch–Siegert shift, a second ISNOB-2 is applied to the decoupled band and a REBURP refocusing pulse to the nucleus which is monitored. This implementation is illustrated in Fig. a.
-
-
In all indirect dimensions, heteronuclear decoupling is applied; when monitoring frequencies, a pulse is applied, and vice versa. is decoupled with composite pulse decoupling (swfTPPM, , or WALTZ-16, ). During acquisition, composite-pulse decoupling is applied to and/or as appropriate (generally using the WALTZ-16 scheme, ).
As described above, all required band-selective decoupling pulses are calculated and set within the pulse sequence, and the correct shape(s) are called by ssNMRlib's python setup routines. The decoupling field strengths can be specified in kHz by the user, and the setup script proposes values and sets the duration of the unit element pulse accordingly.
-
-
For the majority of the assignment experiments, we have versions with additional deuterium decoupling. These experiments may be used with probes equipped for a channel. The deuterium decoupling may increase coherence lifetimes of carbons in deuterated proteins (see below).
Figure a shows one example pulse sequence, a 4D hCONCAHA experiment with detection of the protons, which, to our knowledge, has not been published elsewhere. Figure b shows exemplary sensitivity comparisons of different experiments for two different protein assemblies. The data are in good qualitative agreement with reported sensitivity comparisons presented elsewhere . It is interesting to compare e.g. INEPT vs. BSH-CP transfer variants in experiments involving CO-CA transfers. The availability of pulse sequences with different transfer types allows the user to evaluate which experiment provides better sensitivity for a particular sample, before launching the 3D or 4D versions of these experiments.
2.2.5. Distance measurements for structure determination
Proton-detected experiments that probe distances have been successful for determining structures of deuterated, partially reprotonated samples . When combined with and/or dimensions, such 3D or 4D experiments provide highly useful structural information. These experiments have been successful even for determining structures of very large proteins, up to kDa , and even fully protonated proteins . Recoupling the dipolar interaction has been achieved primarily with RFDR , DREAM and rotating-frame spin diffusion . It has been shown that distances can be measured simultaneously for protons bound to or using simultaneous and CP steps, yielding simultaneously the connections between , and distances .
We have implemented RFDR and band-selective spectral spin diffusion (BASS-SD; ) experiments, with versions yielding 3D experiments with either one or two dimensions and either two or one dimensions.
2.2.6. Experiments probing molecular dynamics
Solid-state NMR is ideally suited for investigating internal molecular motions without the limitations that arise in solution-state NMR due to the overall molecular tumbling . ssNMRlib contains a number of experiments that measure (i) dipolar couplings, which directly report on the order parameters of bonds, and (ii) longitudinal and transverse spin-relaxation parameters of and , which are sensitive to amplitudes and timescales of motion. (iii) Slower exchange dynamics can be probed by - or -edited exchange spectroscopy (EXSY, ) or a version with simultaneous and editing, which are implemented in ssNMRlib. We furthermore have implemented chemical-exchange saturation transfer (CEST, ) experiments to probe slow motions.
The dipolar-coupling measurements are based on a time-shifted REDOR experiment and are available with either CP or refocused-INEPT transfers. Figure shows a hNH CP REDOR pulse sequence and a series of 1D REDOR experiments. Both and relaxation experiments are available for with either 2D (hNH) or 3D (hCONH) readout and (with 3D hCONH readout) and (with 2D hCH readout).
Additionally, relaxation parameters can be measured with either - or -detected pulse sequences implemented in ssNMRlib (see also Sect. ). relaxation is generally challenging to interpret quantitatively , but the knowledge of longitudinal relaxation is useful for choosing the recycle delay that yields the highest signal-to-noise ratio per unit measurement time. Furthermore, knowing the apparent coherence lifetime is useful for setting up e.g. the maximum evolution time in indirect dimensions.
2.3. Probe security handling in ssNMRlib
Ensuring that the power deposited in the probe is tolerated by the hardware is an important part of any NMR data acquisition. Topspin has a Power-Check feature, which verifies the RF peak power sent to the probe (in Watt). If Power-Check is enabled, it does not allow acquisition if the power exceeds the limit on any channel. However, when applied for too long a time, even an RF field at lower power would destroy the probe, such that the built-in Power-Check is insufficient for avoiding hardware damage. Limiting the power to strictly exclude any possible probe damage is difficult, because hardware damage may arise as a complex function of deposited RF power, its duration and the duty cycle.
We have implemented power checks in ssNMRlib which verify peak power levels and durations of pulse sequence elements, e.g. CP elements, decoupling or hard pulses. The safety check is performed automatically by ssNMRlib whenever the user clicks on a button to load an experiment. In addition, a “Security” button in Topspin, right next to the button to launch NMRlib, as well as a button in the ssNMRlib window (see Fig. ), can be clicked at any time to control the user-modified parameters.
The safety checks in ssNMRlib access a table (which can be modified by the user) that lists the accepted durations and power levels (in kHz) for a given element. This table comes with ssNMRlib. We have decided to check RF power levels in kHz rather than in Watt, because probe specifications generally given by the manufacturer are in kHz; most spectroscopists also have a more intuitive understanding of what a probe can sustain, in kHz, rather than in Watt. In the Linux console from which Topspin was started, all the parameters that have been verified are listed, including whether they are within the limits of the probe (Fig. ). In case a parameter exceeds the specified power limits, a popup window warns the user, and the warning is written in the Linux terminal. The user can nonetheless start the experiment by typing zg, despite a security warning. We have made this choice as we think that responsible NMR users, once warned, can make informed decisions. In the calibration experiments, which are usually launched automatically, a security check is performed, and if it fails, the acquisition is not started. The safety checks also verify the maximum power reached in RF ramps and parameter optimization (popt) arrays. The safety check is probe-specific; i.e. a separate table of tolerated RF parameters is defined for each probe head.
The safety checks are currently bound to the naming convention and definitions used in a given experiment, as it will check, for example, the power level of the RF field for a H–N CP (cnst42). When a user adds new experiments (see below), care should be taken to keep this naming convention or to modify the security checks accordingly. The safety checks in ssNMRlib cannot exclude damage but serve as a useful guide. A more detailed description of the safety check is provided in the Supplement (Listing S4).
2.4. Adding new experiments to ssNMRlib
ssNMRlib allows an experiment to be integrated into the library. Once integrated, the experiment is available as a button in the GUI window, and hitting this button will launch a script that sets up the experiment (pulse sequence, calculation or setting of acquisition parameters, setting of processing parameters, etc., as described for the other experiments above). Integrating an experiment into ssNMRlib can be done by clicking the floppy disk icon in the GUI window. A popup window allows us to specify the important parameters and write a short manual for the experiment, which will appear when clicking the new button (Listing S5). The pulse program, one jython script for acquisition and one for processing parameters are automatically generated. Additional functionalities could be added inside the jython script for decoupling calculation, recall of constants or automatic security checks. By convention, we have set in the library
-
-
experiment.py: jython script containing experiment specific acquisition parameters.
-
-
p_experiment.py: jython script defining experiment specific processing parameters.
-
-
experiment_p.py: cogwheel symbol jython script used for non standard and experiment specific data analysis.
-
-
experiment_sec.py: experiment specific security jython script.
When programming new pulse sequences, we strongly advise using the naming conventions for pulses, shapes, decoupling, delays, etc., which are listed in Table S1. More information about adding new experiments is also provided in the Supplement (Listing S5).
2.5. Additional useful macros for processing and experiment setup
NMRlib comes with a number of additional useful macros and scripts for various tasks, including saving and reading acquisition parameters, processing (e.g. phasing 3D or 4D experiments or summing spectra or time-domain data) or plotting (in Matplotlib format). These tools are described in the following sections.
2.5.1. Store and retrieve acquisition parameters and pulse sequences
ssNMRlib contains many useful tools for optimizing parameters, keeping the parameters in memory, and using the optimized parameters of all the required pulse sequence blocks when setting up a complex experiment. ssNMRlib allows all the present parameters to be written in a user-friendly text file, the “recap file”. The file saves all currently stored parameters along with the date/time of their creation, which allows the user to see which parameters have been recently optimized. We have also implemented the possibility of removing all optimized parameters, thus starting “from scratch” and avoiding the use of old parameters.
The recap file contains, in addition to the optimized RF parameters, information about the identity of the installed probe, the cooling gas flow and temperature, MAS frequency, and the location where the NMR data are stored.
In our experience, the recap file is a very useful tool for keeping track of and retrieving all experimental parameters after the experiments have been concluded, in a format that is more convenient than the Bruker acquisition file (acqus).
An example recap file is shown in Listing S3.
The same button also allows us to read a previously stored “recap file”. In this way, optimizations saved during a previous NMR session can be automatically put back into the library. The user will thus be able to load any experiment from the library with the previously optimized parameters.
A “Save your pulse program” button allows us to save the current pulse program in the present acquisition directory. This button is very useful e.g. when programming/editing pulse sequences: the user can save the present state of a sequence along with the data. This allows us to more easily develop or debug pulse sequences and retrieve a previous state of a sequence.
2.5.2. Processing macros
General processing tools are part of NMRlib and have been introduced before . As ssNMRlib is part of this library, all previously proposed tools are also available for solid-state NMR experiments. Tools are available to add two multi-dimensional spectra (in time or frequency domain), to phase multi-dimensional (3D, 4D) spectra, or to remove (i.e. set to zero) corrupt FIDs from a multi-dimensional data set, which may arise for example as a consequence of arching in ssNMR experiments using python packages (numpy, , nmrglue, , and Matplotlib, ). Another macro allows us to correct FIDs for magnetic-field drift (i.e. shearing of the spectrum), which shall be particularly useful for solid-state NMR experiments, where it is generally not possible to use a deuterium lock to stabilize the field. Other routines described earlier allow nmrPipe processing scripts to be generated or a circular shift to be performed to correct for potential missettings of the carrier frequency. Further scripts, using python/nmrglue/numpy, allow extraction of intensities, plotting spectra in Matplotlib format or fit data, as discussed e.g. for solution-state NMR experiments (DOSY, TRACT, etc.), as described .
3. Conclusions and perspectives
We have presented herein ssNMRlib, a comprehensive library of pulse sequences and setup scripts which markedly facilitate solid-state NMR data acquisition, security checks, tracking of parameters and data handling. We developed the library in a multi-spectrometer facility, and the fact that pulse sequences are all centralized contributes greatly to keeping data acquisition simple and reproducible. While the current ssNMRlib version has its focus on pulse programs for biomolecular applications, the library can be extended in a straightforward manner to any kind of NMR data acquisition.
We are currently implementing more experiments, such as C- and R-type sequences, as well as and experiments. We foresee in future versions of ssNMRlib the use of the WaveMaker library, which allows us to create shape files (ramps, selective pulses, decoupling sequences) directly from within the pulse sequence on the fly. This would allow us to perform a parameter optimization for shape files (e.g. adiabaticity), which currently requires us to change the shape file name manually.
We encourage our colleagues in the field to add their pulse sequences and hope that the platform we created will be useful for a wide range of NMR applications. While a user may simply add her/his experiments to the own local library, it also facilitates the exchange of experiments between laboratories.
Supplement
Acknowledgements
This work used the NMR and isotope labeling platforms of the Grenoble Instruct Centre (ISBG; UMS 3518 CNRS-CEA-UJF-EMBL) with support from the Agence Nationale de la Recherche (ANR) within the Grenoble Partnership for Structural Biology (PSB). Paul Schanda acknowledges support from the European Research Council. We thank Johanna Becker-Baldus for testing ssNMRlib and for many useful suggestions for additional features. We thank Audrey Hessel, Charles-Adrien Arnaud and Cecile Breyton for providing samples used for testing and setup of ssNMRlib and Rasmus Linser, Sabine Hediger and Daniel Lee for discussions about pulse sequences.
Contributor Information
Alicia Vallet, Email: alicia.vallet@ibs.fr.
Paul Schanda, Email: paul.schanda@ist.ac.at.
Code availability
The ssNMRlib package is available from the authors upon request and at the following URL: http://www.ibs.fr/nmrlib (last access: 15 November 2020, Vallet et al., 2020).
Author contributions
AV and PS wrote the pulse sequences contained in ssNMRlib and designed the workflow of ssNMRlib and the organization of the library. AF adapted the NMRlib software structure for the integration of ssNMRlib. BB contributed calculations for selective pulses and other pulse-programming snippets. AV and PS prepared figures. PS wrote the manuscript with input from all the authors.
Competing interests
The authors declare that they have no conflict of interest.
Review statement
This paper was edited by Bernd Reif and reviewed by two anonymous referees.
References
- Agarwal V, Penzel S, Szekely K, Cadalbert R, Testori E, Oss A, Past J, Samoson A, Ernst M, Böckmann A, Meier BH. De novo 3D structure determination from sub-milligram protein samples by solid-state 100 kHz MAS NMR spectroscopy. Angew Chem Int Ed. 2014;53:12253–12256. doi: 10.1002/anie.201405730. [DOI] [PubMed] [Google Scholar]
- Andreas LB, Jaudzems K, Stanek J, Lalli D, Bertarello A, Le Marchand T, Cala-De Paepe D, Kotelovica S, Akopjana I, Knott B, Wegner S, Engelke F, Lesage A, Emsley L, Tars K, Herrmann T, Pintacuda G. Structure of fully protonated proteins by proton-detected magic-angle spinning NMR. P Natl Acad Sci USA. 2016;113:9187–9192. doi: 10.1073/pnas.1602248113. [DOI] [PMC free article] [PubMed] [Google Scholar]
- Barbet-Massin E, Pell AJ, Jaudzems K, Franks WT, Retel JS, Kotelovica S, Akopjana I, Tars K, Emsley L, Oschkinat H, Lesage A, Pintacuda G. Out-and-back C- C scalar transfers in protein resonance assignment by proton-detected solid-state NMR under ultra-fast MAS. J Biomol NMR. 2013;56:379–386. doi: 10.1007/s10858-013-9757-3. [DOI] [PubMed] [Google Scholar]
- Bennett AE, Griffin RG, Ok JH, Vega S. Chemical shift correlation spectroscopy in rotating solids: Radio frequency‐driven dipolar recoupling and longitudinal exchange. J Chem Phys. 1992;96:8624–8627. [Google Scholar]
- Chevelkov V, Giller K, Becker S, Lange A. Efficient CO-CA transfer in highly deuterated proteins by band-selective homonuclear cross-polarization. J Magn Reson. 2013;230:205–11. doi: 10.1016/j.jmr.2013.02.021. [DOI] [PubMed] [Google Scholar]
- Delaglio F, Grzesiek S, Vuister G, Zhu G, Pfeifer J, Bax A. NMRPIPE – a multidimensional spectral processing system based on Unix pipes. J Biomol NMR. 1995;6:277–293. doi: 10.1007/BF00197809. [DOI] [PubMed] [Google Scholar]
- Favier A, Brutscher B. NMRlib: user-friendly pulse sequence tools for Bruker NMR spectrometers. J Biomol NMR. 2019;73:199–211. doi: 10.1007/s10858-019-00249-1. [DOI] [PubMed] [Google Scholar]
- Fraga H, Arnaud C-A, Gauto D F, Audin M, Kurauskas V, Macek P, Krichel C, Guan J-Y, Boisbouvier J, Sprangers R, Breyton C, Schanda P. Solid-State NMR H-N-(C)-H and H-N-C-C 3D/4D Correlation Experiments for Resonance Assignment of Large Proteins. Chem Phys Chem. 2017;18:2697–2703. doi: 10.1002/cphc.201700572. [DOI] [PMC free article] [PubMed] [Google Scholar]
- Fricke P, Chevelkov V, Zinke M, Giller K, Becker S, Lange A. Backbone assignment of perdeuterated proteins by solid-state NMR using proton detection and ultrafast magic-Angle spinning. Nat Protoc. 2017;12:764–782. doi: 10.1038/nprot.2016.190. [DOI] [PubMed] [Google Scholar]
- Frye JS, Maciel GE. Setting the magic angle using a quadrupolar nuclide. J Magn Reson. 1982;48:125–131. [Google Scholar]
- Gao M, Nadaud PS, Bernier MW, North JA, Hammel PC, Poirier MG, Jaroniec CP. Histone H3 and H4 N-terminal tails in nucleosome arrays at cellular concentrations probed by magic angle spinning NMR spectroscopy. J Am Chem Soc. 2013;135:15278–15281. doi: 10.1021/ja407526s. [DOI] [PMC free article] [PubMed] [Google Scholar]
- Gauto DF, Estrozi LF, Schwieters CD, Effantin G, Macek P, Sounier R, Sivertsen AC, Schmidt E, Kerfah R, Mas G, Colletier J-P, Güntert P, Favier A, Schoehn G, Schanda P, Boisbouvier J. Integrated NMR and cryo-EM atomic-resolution structure determination of a half-megadalton enzyme complex. Nat Commun. 2019;10:2697. doi: 10.1038/s41467-019-10490-9. [DOI] [PMC free article] [PubMed] [Google Scholar]
- Geen H, Freeman R. Band-selective radiofrequency pulses. J Magn Reson. 1990;93:93–141. [Google Scholar]
- Gullion T, Schaefer J. Detection of weak heteronuclear dipolar coupling by rotational-echo double-resonance nuclear-magnetic-resonance. Adv Magn Reson. 1988;13:57–83. [Google Scholar]
- Haller JD, Schanda P. Amplitudes and time scales of picosecond-to-microsecond motion in proteins studied by solid-state NMR: a critical evaluation of experimental approaches and application to crystalline ubiquitin. J Biomol NMR. 2013;57:263–280. doi: 10.1007/s10858-013-9787-x. [DOI] [PMC free article] [PubMed] [Google Scholar]
- Hartmann SR, Hahn EL. Nuclear Double Resonance in the Rotating Frame. Phys Rev. 1962;128:2042–2053. [Google Scholar]
- Helmus JJ, Jaroniec CP. Nmrglue: An open source Python package for the analysis of multidimensional NMR data. J Biomol NMR. 2013;55:355–367. doi: 10.1007/s10858-013-9718-x. [DOI] [PMC free article] [PubMed] [Google Scholar]
- Huber M, Hiller S, Schanda P, Ernst M, Böckmann A, Verel R, Meier BH. A Proton-Detected 4D Solid-State NMR Experiment for Protein Structure Determination. Chem Phys Chem. 2011;12:915–918. doi: 10.1002/cphc.201100062. [DOI] [PubMed] [Google Scholar]
- Hunter JD. Matplotlib: A 2D graphics environment. Comput Sci Eng. 2007;9:90–95. [Google Scholar]
- Jain MG, Lalli D, Stanek J, Gowda C, Prakash S, Schwarzer TS, Schubeis T, Castiglione K, Andreas LB, Madhu PK, Pintacuda G, Agarwal V. Selective H- H Distance Restraints in Fully Protonated Proteins by Very Fast Magic-Angle Spinning Solid-State NMR. J Phys Chem Lett. 2017;8:2399–2405. doi: 10.1021/acs.jpclett.7b00983. [DOI] [PubMed] [Google Scholar]
- Kern T, Hediger S, Müller P. Toward the Characterization of Peptidoglycan Structure and Protein− Peptidoglycan Interactions by Solid-State NMR Spectroscopy. J Am Chem Soc. 2008;130:5618–5619. doi: 10.1021/ja7108135. [DOI] [PubMed] [Google Scholar]
- Knight MJ, Pell AJ, Bertini I, Felli IC, Gonnelli L, Pierattelli R, Herrmann T, Emsley L, Pintacuda G. Structure and backbone dynamics of a microcrystalline metalloprotein by solid-state NMR. P Natl Acad Sci USA. 2012;109:11095–11100. doi: 10.1073/pnas.1204515109. [DOI] [PMC free article] [PubMed] [Google Scholar]
- Krushelnitsky A, Reichert D. Solid-state NMR and protein dynamics. Prog Nucl Magn Reson Spectr. 2005;47:1–25. [Google Scholar]
- Kupce E, Boyd J, Campbell I. Short Selective Pulses for Biochemical Applications. J Magn Reson. 1995;106:300–303. doi: 10.1006/jmrb.1995.1049. [DOI] [PubMed] [Google Scholar]
- Lamley JM, Lewandowski JR. Relaxation-Based Magic-Angle Spinning NMR Approaches for Studying Protein Dynamics. eMagRes. 2016;5:1423–1434. [Google Scholar]
- Lange A, Seidel K, Verdier L, Luca S, Baldus M. Analysis of Proton−Proton Transfer Dynamics in Rotating Solids and Their Use for 3D Structure Determination. J Am Chem Soc. 2003;125:12640–12648. doi: 10.1021/ja034555g. [DOI] [PubMed] [Google Scholar]
- Levitt M. Symmetry-based pulse sequences in magic-angle spinning solid-state NMR. Encycl Nucl Magn Reson. 2002;9:165–196. [Google Scholar]
- Lewandowski JR, De Paëpe G, Griffin RG. Proton Assisted Insensitive Nuclei Cross Polarization. J Am Chem Soc. 2007;129:728–729. doi: 10.1021/ja0650394. [DOI] [PMC free article] [PubMed] [Google Scholar]
- Linser R, Fink U, Reif B. Narrow carbonyl resonances in proton-diluted proteins facilitate NMR assignments in the solid-state. J Biomol NMR. 2010;47:1–6. doi: 10.1007/s10858-010-9404-1. [DOI] [PubMed] [Google Scholar]
- Linser R, Bardiaux B, Higman V, Fink U, Reif B. Structure calculation from unambiguous long-range amide and methyl H- H distance restraints for a microcrystalline protein with MAS solid-state NMR spectroscopy. J Am Chem Soc. 2011;133:5905–5912. doi: 10.1021/ja110222h. [DOI] [PubMed] [Google Scholar]
- Meier BH, Ernst RR. Elucidation of chemical exchange networks by two-dimensional NMR spectroscopy: the heptamethylbenzenonium ion. J Am Chem Soc. 1979;101:6441–6442. [Google Scholar]
- Nielsen N, Bildsoe H, Jakobsen H, Levitt M. Double-quantum homonuclear rotary resonance: Efficient dipolar recovery in magic-angle spinning nuclear magnetic resonance. J Chem Phys. 1994;101:1805–1812. [Google Scholar]
- Rovó P. Recent advances in solid-state relaxation dispersion techniques. Solid State Nucl Magn Reson. 2020;108:101665. doi: 10.1016/j.ssnmr.2020.101665. [DOI] [PubMed] [Google Scholar]
- Rovó P, Linser R. Microsecond Timescale Protein Dynamics: a Combined Solid-State NMR Approach. Chem Phys Chem. 2018;19:34–39. doi: 10.1002/cphc.201701238. [DOI] [PubMed] [Google Scholar]
- Schanda P, Ernst M. Studying dynamics by magic-angle spinning solid-state NMR spectroscopy: Principles and applications to biomolecules. Prog Nucl Magn Reson Spectr. 2016;96:1–46. doi: 10.1016/j.pnmrs.2016.02.001. [DOI] [PMC free article] [PubMed] [Google Scholar]
- Schanda P, Meier BH, Ernst M. Quantitative Analysis of Protein Backbone Dynamics in Microcrystalline Ubiquitin by Solid-State NMR Spectroscopy. J Am Chem Soc. 2010;132:15957–15967. doi: 10.1021/ja100726a. [DOI] [PubMed] [Google Scholar]
- Scholz I, Huber M, Manolikas T, Meier BH, Ernst M. MIRROR recoupling and its application to spin diffusion under fast magic-angle spinning. Chem Phys Lett. 2008;460:278–283. [Google Scholar]
- Shaka AJ, Keeler J, Frenkiel T, Freeman R. An improved sequence for broadband decoupling: WALTZ-16. J Magn Reson. 1983;52:335–338. [Google Scholar]
- Stanek J, Andreas LB, Jaudzems K, Cala D, Lalli D, Bertarello A, Schubeis T, Akopjana I, Kotelovica S, Tars K, Pica A, Leone S, Picone D, Xu Z-Q, Dixon NE, Martinez D, Berbon M, El Mammeri N, Noubhani A, Saupe S, Habenstein B, Loquet A, Pintacuda G. NMR Spectroscopic Assignment of Backbone and Side-Chain Protons in Fully Protonated Proteins: Microcrystals, Sedimented Assemblies, and Amyloid Fibrils. Angew Chemie Int Ed. 2016;55:15504–15509. doi: 10.1002/anie.201607084. [DOI] [PubMed] [Google Scholar]
- Takegoshi K, Nakamura S, Terao T. C- H dipolar-assisted rotational resonance in magic-angle spinning NMR. Chem Phys Lett. 2001;344:631–637. doi: 10.1063/1.2364503. [DOI] [PubMed] [Google Scholar]
- Thakur RS, Kurur ND, Madhu PK. Swept-frequency two-pulse phase modulation for heteronuclear dipolar decoupling in solid-state NMR. Chem Phys Lett. 2006;426:459–463. [Google Scholar]
- Vallet A, Favier A, Brutscher B, Schanda P. [last access: 15 November 2020]. 2020. NMRlib 2.0: IBS pulse sequence tools for Bruker spectrometers. IBS (Institut de Biologie Structurale) available at: http://www.ibs.fr/nmrlib .
- Vallurupalli P, Bouvignies G, Kay LE. Studying “invisible” excited protein states in slow exchange with a major state conformation. J Am Chem Soc. 2012;134:8148–8161. doi: 10.1021/ja3001419. [DOI] [PubMed] [Google Scholar]
- Van Der Walt S, Colbert SC, Varoquaux G. The NumPy array: a structure for efficient numerical computation. Comput Sci Eng. 2011;13:22–30. [Google Scholar]
- Verel R, Baldus M, Ernst M, Meier BH. A homonuclear spin-pair filter for solid-state NMR based on adiabatic-passage techniques. Chem Phys Lett. 1998;287:421–428. [Google Scholar]
- Verel R, Ernst M, Meier BH. Adiabatic dipolar recoupling in solid-state NMR: the DREAM scheme. J Magn Reson. 2001;150:81–99. doi: 10.1006/jmre.2001.2310. [DOI] [PubMed] [Google Scholar]
- Wi S, Frydman L. An Efficient, Robust New Scheme for Establishing Broadband Homonuclear Correlations in Biomolecular Solid State NMR. Chem Phys Chem. 2020;21:284–294. doi: 10.1002/cphc.201901071. [DOI] [PubMed] [Google Scholar]
- Wittmann JJ, Agarwal V, Hellwagner J, Lends A, Cadalbert R, Meier BH, Ernst M. Accelerating proton spin diffusion in perdeuterated proteins at 100 kHz MAS. J Biomol NMR. 2016;66:233–242. doi: 10.1007/s10858-016-0071-8. [DOI] [PubMed] [Google Scholar]
- Xiang S, Grohe K, Rovó P, Vasa SK, Giller K, Becker S, Linser R. Sequential backbone assignment based on dipolar amide-to-amide correlation experiments. J Biomol NMR. 2015;62:303–311. doi: 10.1007/s10858-015-9945-4. [DOI] [PubMed] [Google Scholar]
- Zhou DH, Rienstra CM. High-performance solvent suppression for proton detected solid-state NMR. J Magn Reson. 2008;192:167–172. doi: 10.1016/j.jmr.2008.01.012. [DOI] [PMC free article] [PubMed] [Google Scholar]
- Zhou DH, Shea JJ, Nieuwkoop AJ, Franks WT, Wylie BJ, Mullen C, Sandoz D, Rienstra CM. Solid-State Protein-Structure Determination with Proton-Detected Triple-Resonance 3D Magic-Angle-Spinning NMR Spectroscopy. Angew Chem Int Ed. 2007;119:8532–8535. doi: 10.1002/anie.200702905. [DOI] [PMC free article] [PubMed] [Google Scholar]
Associated Data
This section collects any data citations, data availability statements, or supplementary materials included in this article.
Data Citations
- Vallet A, Favier A, Brutscher B, Schanda P. [last access: 15 November 2020]. 2020. NMRlib 2.0: IBS pulse sequence tools for Bruker spectrometers. IBS (Institut de Biologie Structurale) available at: http://www.ibs.fr/nmrlib .