Red Pitaya Notes
Source Issues

Pulsed NMR system

This is a work in progress...

Some interesting links on pulsed nuclear magnetic resonance:

Short description

The system consists of two in-phase/quadrature (I/Q) digital down-converters (DDC), a pulse generator and a gate controller.

The gate controller includes pulse generation and data acquisition sequencers. The pulse generation sequencer manages all aspects of the generated pulses, such as their duration, level and phase. The data acquisition sequencer allows the selection of the I/Q samples required for data analysis.

The tunable frequency range covers from 0 Hz to 60 MHz.

The I/Q data rate is configurable from 20 to 1280 kSPS.

Hardware

The basic blocks of the system are shown in the following diagram:

Pulsed NMR

The projects/pulsed_nmr_122_88 directory contains three Tcl files: block_design.tcl, rx.tcl, tx.tcl. The code in these files instantiates, configures and interconnects all the needed IP cores.

The source code of the R script used to calculate the coefficients of the FIR filter can be found in projects/pulsed_nmr_122_88/filters/fir_0.r.

RF and GPIO connections

Application programming interface

The pulsed-nmr-notebooks repository contains libraries for Python, Julia and C#, as well as example Jupyter notebooks using these libraries to control all parameters of the signal processing modules and programming the pulse generator.

The commands implemented in these libraries can be classified into five groups.

Commands to manage the connection with the TCP server:

Commands to set frequencies, ADC sample rate and CIC decimation rate:

Commands to program a pulse sequence:

Command to start pulse sequence and receive data:

Commands to control external DAC, OUT2 signal level and GPIO pins:

Software

The projects/pulsed_nmr_122_88/server directory contains the source code of the TCP server (pulsed-nmr.c) that receives control commands and transmits the I/Q data streams (up to 4 x 32 bit x 1280 kSPS = 156 Mbit/s) to the control program running on a remote PC.

The projects/pulsed_nmr_122_88/client directory contains the source code of the control program (pulsed_nmr.py).

Pulsed NMR client

Getting started with GNU/Linux

sudo apt-get install python3-numpy python3-matplotlib python3-pyqt6
git clone https://github.com/pavel-demin/red-pitaya-notes
cd red-pitaya-notes/projects/pulsed_nmr_122_88/client
python3 pulsed_nmr.py

Building from source

The installation of the development machine is described at this link.

The structure of the source code and of the development chain is described at this link.

Setting up the Vitis and Vivado environment:

source /opt/Xilinx/2025.1/Vitis/settings64.sh

Cloning the source code repository:

git clone https://github.com/pavel-demin/red-pitaya-notes
cd red-pitaya-notes

Building pulsed_nmr_122_88.bit:

make NAME=pulsed_nmr_122_88 PART=xc7z020clg400-1 bit

Building SD card image zip file:

source helpers/build-all.sh