Skip to content

GNU Radio on the AIR-T

GNU Radio Logo

The following instructions apply to AirStack version <2.0 only. For AirStack 2.0+ and below, see this tutorial.

GNU Radio is a widely used free and open-source modular toolkit for developing and executing signal processing applications on software defined radio platforms, including the Deepwave Digital AIR-T. Prior to AirStack 0.5, GNU Radio ran natively under Python on the AIR-T; the versions of GNU Radio supported by this environment, however, were limited to 3.7 and older. With the release of AirStack 0.5, GNU Radio runs under the package and environment management system, Conda, which ensures that all the dependencies needed to run GNU Radio are installed in the execution environment. This approach also supports the newer and more capable GNU Radio 3.9.

Defining and Creating a GNU Radio Conda Environment

Before a Conda environment can be launched, it must be defined in a YAML file that includes the selection of the version of Python to be used in the environment. GNU Radio may be run with Python versions 3.6-3.9; your selection will depend on the specific version needed to support the other packages required for your application.

Note - NVIDIA provides binary builds for PyTorch and TensorRT that are compiled for Python 3.6; therefore, if you wish to use these packages, you will be limited to Python 3.6.

Following is sample content that you can copy to a YAML file you create, named gnuradio.yml for example, on your AIR-T; note that in this example the environment is named gnuradio and that Python 3.9 has been specified:

name: gnuradio
channels:
  - conda-forge
  - nvidia
  - defaults
  - file://opt/deepwave/conda-channels/airstack-conda

dependencies:
  - python=3.9
  - scipy
  - numpy<1.24
  - matplotlib
  - pip
  - soapysdr-module-airt
  - gnuradio=3.9.8

The environment can now be created by executing the following command from the same folder containing the YAML file:

conda env create -f gnuradio.yml

This can take up to 5 minutes to complete

Activating the Conda Environment and Launching GNU Radio

Now that a Conda environment has been defined and created, it can be activated using the following command:

  • Activate the gnuradio conda environment:
conda activate gnuradio

Now your Python environment has GNU Radio installed. You may validate the version by running:

(gnuradio) $ gnuradio-config-info --version

3.9.2.0

The final step is to launch GNU Radio as follows:

  • Launch GNU Radio Companion:
gnuradio-companion

This command should launch the GNU Radio Companion GUI on your AIR-T.

Run the Example Code

There are multiple examples provided in AirStack located in /home/<username>/Desktop/AIR-T_QuickStart_Apps/gnuradio. You can open these examples by selecting File -> Open and navigate to one of the two files in the AIR-T_QuickStart_Apps file on the Desktop:

Receiver Demo

Use the airstack_rx_demo.grc file for a simple demonstration on how to receive signals on the AIR-T using GNU Radio. The Soapy AIR-T Source block should be used receiving signals using GNU Radio.

Transmitter Demo

Use the airstack_tx_demo.grc file for a simple demonstration on how to transmit signals on the AIR-T using GNU Radio. The Soapy AIR-T Sink block should be used for transmitting signals using GNU Radio.

Modify the Example Code

Next you may modify the either of these example for your needs. Note that the AIR-T_QuickStart_Apps folder links to a read-only directory. If you wish to modify the one of these files, you must save it to a different location.