This document is not meant to be a complete tutorial on GnuRadio, but to help you start to play around GnuRadio on Orbit Sandbox and to share my experiences on exploring this wonderful toy. == What do you need to know? == Before you jump into GnuRadio on Orbit, you should have a clear picture on what GnuRadio is. An excellent starting reading material is Eric Blossom’s Exploring GNU Radio:[http://www.gnu.org/software/gnuradio/doc/exploring-gnuradio.html]. Eric is the founder of the whole GNU Radio project. Make sure you understand the data flow paths, including the receive path and the transmit path, understand the role that the USRP plays. USRP is a flexible USB device that connects the PC to the RF world. USRP has one motherboard, which connected to the PC via USB 2.0 and can support up to four daughterboard. Each daughterboard has RF ends that can either transmit or receive waveform from the air. There are different types of daughterboard supporting a variety radio range, e.g. for example, Flex400 supports both transmit and receive in the frequency band 400MHz to 500 Mhz. You need to refresh your memory on the sample theory. To program GnuRadio, you need to build a radio by creating a graph (as in graph theory) where the vertices are signal processing blocks and the edges represent the data flow between them. The signal processing blocks are implemented in C++. The graphs are constructed and run in Python. If you are not familiar with C++ or Python, find a tutorial online and learn it. == What is on Orbit Sandbox5? == Sandbox5 consists of two nodes, i.e. node1-1 and node1-2. Each individual node is connected to one Gnuradio motherboard, and each motherboard in turn has two BasicRX and two BasicTX mounted on it, as show in the following picture. [[Image(Documentation/GNURadio:sandbox5.JPG)]] The frequency that the BasicTX operates on ranges from 2 MHz to 200 MHz, and the BasicRX can receive from 2 MHz to 300+ MHz. Since there is no way to put a matching antenna on BasicTX/BasicRX, the two BasicTX/BasicRX daughterboard are connected through two wires, which means the waveform transmitted from BasicTX to BasicRX doesn’t go through air but the two wires. For right now, the TX_B port of the BasicTX on node1-1is wired to the RX_B on the BasicRX on node1-2, and the the TX_A of the BasicTX on node1-1 is wired to the RX_B on the BasicRX mounted on node1-2. Therefore, make sure you have node1-1 as the transmitter and have node 1-2 be the receiver. {{{ Since there is NO sound card on each node, you cannot run the example, dial_tone.py. }}} == Make sandbox5 ready, step by step. == I assume you’ve read the tutorial about Orbit, and you know how to reserve a time slot, how to log into the nodes, and how to image the nodes. (Otherwise read [wiki:HowToGetStarted Getting Started].) To load the nodes with the right image: * Step 1: Login to the console {{{ ssh username@ console.sb5.orbit-lab.org }}} * Step 2: image the nodes {{{ imageNodes [1,1],[1,2] gnuradio-old.ndz }}} * Step 3: Power up node1-1 and node1-2 {{{ wget -O - -q 'http://cmc:5012/cmc/on?x=1&y=1' wget -O - -q 'http://cmc:5012/cmc/on?x=1&y=2' }}} * Step 4: Log onto the node {{{ ssh root@node1-1 ssh root@node1-2 }}} * Step 5: copy [http://www.orbit-lab.org/attachment/wiki/Documentation/GNURadio/usrp_siggen_multiple_sine.py usrp_siggen_multiple_sine.py] to node1-1 (transmitter) * Step 6: copy [http://www.orbit-lab.org/attachment/wiki/Documentation/GNURadio/usrp1_rx_cfile.py usrp1_rx_cfile.py] to node1-2 (receiver) * Step 7: Give your scripts permission to run. {{{ chmod +x filename }}} == Let’s start to run examples. == 1. '''Receiver only''' The transmitter doesn't send any thing, only the receiver receives. In this case, what the receiver receives is white noise. {{{ ./usrp1_rx_cfile.py -f 10e3 -N21000 -g 10 noise.dat }}} * '-f 10e3': tells the GnuRadio to listen to the frequency band 10kHz. * '-N21000': sample 21000 data points. * '-g 10': set the gain to 10. * 'noise.data': set the file name that will store the data samples. Using the matlab script [http://www.orbit-lab.org/attachment/wiki/Documentation/GNURadio/plotall.m plotall('noise.dat')], you can get the following figure: [[Image(Documentation/GNURadio:noise.dat.jpeg)]] 2. '''Transmitter and Receiver at 1MHz''' The transmitter sends out waveform at 1MHz, and the receiver receives at 1MHz as well. At the Transmitter node1-1: {{{ ./usrp_siggen_multiple_sine.py -f 1e6 -w 10k -a 1000 -m 1 --sine }}} * '-f 1e6': tells the GnuRadio to modulate the baseband waveform to 1MHz. * '--sine': the format of the waveform that will be sent out is a sine wave. * '-w 10k': set the original baseband frequency to 10k, * '-a 1000': set the amplitude to 1000. * '-m 1': only transmit one sine wave, instead of multiple sine waves. At the receiver node1-2: {{{ ./usrp1_rx_cfile.py -f 1e6 -N21000 -g 10 rx_1m.dat }}} * '-f 1e6': tells the GnuRadio to listen to the frequency band 1MHz. * '-N21000': sample 21000 data points. * '-g 10': set the gain to 10. * 'rx_1m.data': set the file name that will store the data samples. Using the matlab script [http://www.orbit-lab.org/attachment/wiki/Documentation/GNURadio/plotall.m plotall('rx_1m.dat')], you can get the following figure: [[Image(Documentation/GNURadio:rx_1m.dat.jpeg)]] What we observe in the above plot is not a perfect sine wave. There are some high frequency components around the 10KHz sine wave. This is because that we set the target frequency as 1MHz, which is out of the working range of BasicRX and BasicTX. Recall that the working range of BasicRX and BasicTX is from 2MHz to 200MHz+. Now let’s try to set the correct frequency. 3. '''Transmitter and Receiver at 10MHz''' The transmitter sends out waveform at 10MHz, and the receiver receives at 10MHz as well. At the Transmitter node1-1: {{{ ./usrp_siggen_multiple_sine.py -f 10e6 -w 10k -a 1000 -m 1 --sine }}} At the receiver node1-2: {{{ ./usrp1_rx_cfile.py -f 10e6 -N21000 -g 10 rx_1m.dat }}} The resulting plot is : [[Image(Documentation/GNURadio:rx_10m.dat.jpeg)]] This time the received sine wave is indeed a regular sine wave. '''Note: the first 1000 data in rxXXX should be discarded. Since the receiver is starting up, the first 1000 data points are not correct.''' == Troubleshooting: == * Have you picked the right node as the transmitter and receiver? * Have you run the correct Python script at the transmitter? * Have you tune the frequency within the Radio Front’s working range? * Have you matched the receiver’s frequency to the transmitter’s? * Have you set the gain properly? If you fail to set the gain correctly, chances are the device will run on the saturated mode, and the result will not be pretty. == Useful links: == * The official website: http://www.gnu.org/software/gnuradio/index.html * GNU Radio overview and evaluation: http://staff.washington.edu/~jon/gnuradio.html