.. only:: html
.. note::
:class: sphx-glr-download-link-note
Click :ref:`here ` to download the full example code or to run this example in your browser via Binder
.. rst-class:: sphx-glr-example-title
.. _sphx_glr_examples_2D_simulation(crystalline)_plot_1_STMAS_RbNO3.py:
RbNO3, 87Rb (I=3/2) STMAS
^^^^^^^^^^^^^^^^^^^^^^^^^
87Rb (I=3/2) staellite-transition off magic-angle spinning simulation.
The following is an example of the STMAS simulation of :math:`\text{RbNO}_3`. The
:math:`^{87}\text{Rb}` tensor parameters were obtained from Massiot `et. al.` [#f1]_.
.. code-block:: python
import matplotlib as mpl
import matplotlib.pyplot as plt
import mrsimulator.signal_processing as sp
import mrsimulator.signal_processing.apodization as apo
from mrsimulator import Simulator, SpinSystem, Site
from mrsimulator.methods import ST1_VAS
# global plot configuration
font = {"size": 9}
mpl.rc("font", **font)
mpl.rcParams["figure.figsize"] = [4.25, 3.0]
Generate the site and spin system objects.
.. code-block:: python
Rb87_1 = Site(
isotope="87Rb",
isotropic_chemical_shift=-27.4, # in ppm
quadrupolar={"Cq": 1.68e6, "eta": 0.2}, # Cq is in Hz
)
Rb87_2 = Site(
isotope="87Rb",
isotropic_chemical_shift=-28.5, # in ppm
quadrupolar={"Cq": 1.94e6, "eta": 1.0}, # Cq is in Hz
)
Rb87_3 = Site(
isotope="87Rb",
isotropic_chemical_shift=-31.3, # in ppm
quadrupolar={"Cq": 1.72e6, "eta": 0.5}, # Cq is in Hz
)
sites = [Rb87_1, Rb87_2, Rb87_3] # all sites
spin_systems = [SpinSystem(sites=[s]) for s in sites]
**Step 2:** Select a satellite-transition variable-angle spinning method. The
following `ST1_VAS` method correlates the frequencies from the two inner-satellite
transitions to the central transition. Note, STMAS measurements are highly suspectable
to rotor angle mismatch. In the following, we show two methods, first set to
magic-angle and the second deliberately miss-sets by approximately 0.0059 degrees.
.. code-block:: python
angles = [54.7359, 54.73]
method = []
for angle in angles:
method.append(
ST1_VAS(
channels=["87Rb"],
magnetic_flux_density=7, # in T
rotor_angle=angle * 3.14159 / 180, # in rad (magic angle)
spectral_dimensions=[
{
"count": 256,
"spectral_width": 3e3, # in Hz
"reference_offset": -2.4e3, # in Hz
"label": "Isotropic dimension",
},
{
"count": 512,
"spectral_width": 5e3, # in Hz
"reference_offset": -4e3, # in Hz
"label": "MAS dimension",
},
],
)
)
Create the Simulator object, add the method and spin system objects, and
run the simulation.
.. code-block:: python
sim = Simulator()
sim.spin_systems = spin_systems # add the spin systems
sim.methods = method # add the methods.
sim.run()
The plot of the simulation.
.. code-block:: python
data = [sim.methods[0].simulation, sim.methods[1].simulation]
fig, ax = plt.subplots(1, 2, figsize=(8.5, 3), subplot_kw={"projection": "csdm"})
titles = ["STVAS @ magic-angle", "STVAS @ 0.0059 deg off magic-angle"]
for i, item in enumerate(data):
cb1 = ax[i].imshow(item / item.max(), aspect="auto", cmap="gist_ncar_r")
ax[i].set_title(titles[i])
plt.colorbar(cb1, ax=ax[i])
ax[i].invert_xaxis()
ax[i].invert_yaxis()
plt.tight_layout()
plt.show()
.. image:: /examples/2D_simulation(crystalline)/images/sphx_glr_plot_1_STMAS_RbNO3_001.png
:alt: STVAS @ magic-angle, STVAS @ 0.0059 deg off magic-angle
:class: sphx-glr-single-img
Add post-simulation signal processing.
.. code-block:: python
processor = sp.SignalProcessor(
operations=[
# Gaussian convolution along both dimensions.
sp.IFFT(dim_index=(0, 1)),
apo.Gaussian(FWHM="50 Hz", dim_index=0),
apo.Gaussian(FWHM="50 Hz", dim_index=1),
sp.FFT(dim_index=(0, 1)),
]
)
processed_data = []
for item in data:
processed_data.append(processor.apply_operations(data=item))
processed_data[-1] /= processed_data[-1].max()
The plot of the simulation after signal processing.
.. code-block:: python
ax = plt.subplot(projection="csdm")
cb = ax.imshow(processed_data[1].real, cmap="gist_ncar_r", aspect="auto")
plt.colorbar(cb)
ax.invert_xaxis()
ax.invert_yaxis()
plt.tight_layout()
plt.show()
.. image:: /examples/2D_simulation(crystalline)/images/sphx_glr_plot_1_STMAS_RbNO3_002.png
:alt: plot 1 STMAS RbNO3
:class: sphx-glr-single-img
.. [#f1] Massiot, D., Touzoa, B., Trumeaua, D., Coutures, J.P., Virlet, J., Florian,
P., Grandinetti, P.J. Two-dimensional magic-angle spinning isotropic
reconstruction sequences for quadrupolar nuclei, ssnmr, (1996), **6**, *1*,
73-83. `DOI: 10.1016/0926-2040(95)01210-9
`_
.. rst-class:: sphx-glr-timing
**Total running time of the script:** ( 0 minutes 0.913 seconds)
.. _sphx_glr_download_examples_2D_simulation(crystalline)_plot_1_STMAS_RbNO3.py:
.. only :: html
.. container:: sphx-glr-footer
:class: sphx-glr-footer-example
.. container:: binder-badge
.. image:: images/binder_badge_logo.svg
:target: https://mybinder.org/v2/gh/DeepanshS/mrsimulator/master?urlpath=lab/tree/docs/_build/html/../../notebooks/examples/2D_simulation(crystalline)/plot_1_STMAS_RbNO3.ipynb
:alt: Launch binder
:width: 150 px
.. container:: sphx-glr-download sphx-glr-download-python
:download:`Download Python source code: plot_1_STMAS_RbNO3.py `
.. container:: sphx-glr-download sphx-glr-download-jupyter
:download:`Download Jupyter notebook: plot_1_STMAS_RbNO3.ipynb `
.. only:: html
.. rst-class:: sphx-glr-signature
`Gallery generated by Sphinx-Gallery `_