data:image/s3,"s3://crabby-images/0dd1c/0dd1cb76315fb251bba0a60bb69e562873de0be4" alt=""
data:image/s3,"s3://crabby-images/0dd1c/0dd1cb76315fb251bba0a60bb69e562873de0be4" alt=""
Random Quote Board
Making a "Soft" Tuner & Receiver in Gnu Radio
When you look the spectrum from one of your SDR programs, you may see several signals at the same time.
data:image/s3,"s3://crabby-images/282ba/282ba3f2e8ec4ea6d064db6e36e521ab5b3d21b9" alt="Screenshot of the program GQRX showing the spectrum around 91.9 MHz, within the FM broadcast band. The top of the image shows a spectral trace with five signals present, and half of a sixth on the higher frequency end of the trace. The spectrogram shows the same signals over several seconds. Along the left edge are several controls."
In the days of analog receivers, you could only demodulate and listen (or view) the signal at the center. And just one signal. To understand why that is, you have to understand the general flow for receiving a signal. Tuning to that signal is just the first step. The signal also has to be filtered (to remove all other signals and the ever-present noise), then demodulated (to extract the actual information from the RF signal). With analog systems, this was all done in hardware. You literally needed components, typically in the form of transistors, resistors, capacitors and inductors, for the tuning, filtering and demodulation.
Fast forward to today. Maybe you've used GQRX, shown above, or one of the other programs, such as SDR#, SDRconsole, HDSDR, SDR++, or CubicSDR, and seen a similar spectrum. With these programs, you were able to literally click on any of the signals you see in the spectrum and, VIOLA! You heard audio. Have you ever wondered how these various programs were able to do that? How were they able to demodulate a signal that wasn't centered?
data:image/s3,"s3://crabby-images/63e46/63e46b7670aa6ee9ca0536fc99133f045f4709d9" alt="Screenshot of the program SDRsharp. The program shows a spectral trace and spectrogram of a portion of the FM broadcast band. The software also shows that the demodulator is tuned to a signal that is not centered on the spectrum, but is shifted slightly higher in the spectrum."
data:image/s3,"s3://crabby-images/88e30/88e3024d2369f24f727fa5d03019e55dd99b44b6" alt="Screenshot of the program HDSDR. The screenshot shows a spectrogram at the top, a spectral trace just below it, some controls in the lower, left, a demodulated spectogram in the lower, right, and a spectral trace just below the spectrogram. The screenshot also shows a software tuner tuned to a station near the upper frequency limit of the spectrum."
data:image/s3,"s3://crabby-images/0b0d3/0b0d3929392bd0dfbac1278b5377de3fd74e5e8a" alt="Screenshot of the freeware program SDR++. The screenshot shows a list of various controls along the left side, a spectral trace at the top, right, and a spectrogram taking up most of the screen just below the spectral trace. A software tuner is tuned near the lower frequency limit of the spectrum."
data:image/s3,"s3://crabby-images/0be63/0be63856d8d4b3517cbebaf904965f33116a1649" alt="Screenshot of the program CubicSDR. The left edge of the screen shows a set of various controls, such as the gain, demodulation type and a list of saved frequencies. Along the top of the screen are a spectral trace of the station being demodulated with a spectrogram just below it, and a time-domain trace of the demodulated output of the station at the top right of the screen. The center of the screen shows a spectral trace of the entire captured spectrum with a spectogram just below it."
The answer is software tuning. We use software to tune, filter and demodulate the signal. This means we're not hardware limited; we're only limited by what the software can do and the amount of processing available.
Why Do Software Tuning?
There are several reasons why we might want or need software tuning. Let's go through some of those reasons.
IQ Files
The first reason is based on the question, "What if we are playing back an IQ file? And the desired signal is not already centered?" If you have a file, you don't have a SDR to tune. You just have a file of samples. Much as a captured thermal image cannot change the "FORD" (focus, thermal range, distance), a collected IQ file cannot change the center frequency at which it was recorded nor the various settings of the SDR itself, such as the gain or filtered bandwidth. The only way in which you can tune in this way is with software tuning.
Networked Systems
This is similar to reading samples from an IQ file. But instead of the samples coming from a file, they come from the network. The software receivers cannot change the SDR hardware parameters, including the center frequency, so they have to use software to tune and process the samples.
Listen to Multiple Stations at Once
Another possibility is that you want to listen to two radio stations at one time, just as the singer Tom Waits does. If you didn't have two SDRs to run at the same time, then this, too, would require the use of a software tuner. This is demonstrated quite nicely by the Youtube channel "Ham Radio DX" in which he uses the software "SDRconsole" to receive multiple stations at the same time.
Avoiding the LO Feedthrough
Several SDRs, especially the less expensive ones, will have a spike at 0 Hz (DC). This is due (primarily) to the analog RF front end of these systems. The local oscillators and mixers together perform analog frequency tuning. The tuning process creates a large signal at DC, which then becomes part of the digitized spectrum. As complex signal processing is centered at DC, this could create problems for some signal processing. By offtuning from the signal being captured, the system can use software tuning to shift the signal back to DC for processing.
data:image/s3,"s3://crabby-images/1b905/1b9053d8e26376f5dd5d8af8a8c5fcfbcaa53103" alt="Spectral display of a HackRF SDR with nothing connected to the antenna. The display shows a spike at DC, which is due to the LO feedthrough."
Recover Baseband Subchannels
Many analog signals have subchannels, typically called "subcarriers", on them. For example, FM broadcast stations carry stereo, RDS and sometimes SCA signals. NOAA APT signals use a subcarrier to convey the video information. These, too, can use a software tuner to recover this information.
data:image/s3,"s3://crabby-images/b8043/b8043906120762e360cad5267ebe5b6d89ab1bec" alt="Spectral display showing the baseband composite signals from a FM broadcast station. This display shows the left and right channels combined from 0 - 15 kHz, a pilot tone at 19 kHz, and RBDS signal at 57 kHz, and a narrowband FM audio signal at 67 kHz."
We'll go through a couple of different methods to make software tuners using Gnu Radio Companion.
How Frequency Conversion Works
The gist is this. When you multiply (mix) a sinewave with another signal, the frequency of that signal is shifted by the frequency of the sinewave.
There are already a lot of different websites, especially Youtube videos, explaining how frequency conversion works. The gist is this. When you multiply (mix) a sinewave with another signal, the frequency of that signal is shifted by the frequency of the sinewave. In other words, the frequency of the sinewave is added to the frequency of the signal. This is where some confusion may occur. I said "frequencies add". But there's also a difference frequency, meaning that the sinewave's frequency is also subtracted from the signal frequency. Why is that?
All signals have both a negative and positive frequency component. Real signals (as opposed to complex signals) always have both a negative and positive frequency component. Certain complex signals, specifically analytic signals, have only a negative or positive frequency component. If we look at the double-sided spectrum of a sinusoid and a signal, we'll see both negative and positive components.
data:image/s3,"s3://crabby-images/e80d5/e80d5c9fa975f8076e63a98ee7a2ae2f805e63f2" alt="Gnu Radio Companion block diagram showing a block connecting a WAV file to a block that will upsample to 2 MHz. This is followed by a block that frequency modulates the WAV file, followed by a multiply block that will mix the FM signal with a sinusoid so that it is centered at 500 kHz. This 500 kHz signal is converted from complex to real, then input to a spectral display block. Also input to a second input on the spectral display block is a sinewave running at 200 kHz."
data:image/s3,"s3://crabby-images/97616/976169f817558449924c21d464d0ad0075456994" alt="Spectral display showing a double-sided spectrum. Four signals are present, a FM signal at +/-500 kHz and a sinewave at +/-200 kHz. Annotation at the top states that the left half of the spectrum is negative frequency, while the right half is positive frequency."
data:image/s3,"s3://crabby-images/4b183/4b183259d42a51b6c89338d883b141cfbc422a1d" alt="Block diagram of the Gnu Radio flowgraph that multiplies a FM audio signal at 500 kHz with a 200 kHz sinewave."
data:image/s3,"s3://crabby-images/6b536/6b5369d92209560dfa324eebb50f8ae0b3450ffe" alt="Double-sided spectrum of frequency-shifted FM audio signal. The original signal, which was real (vs complex), was multiplied (mixed) with a real sinusoid. Therefore, it has both a positive and negative frequency shift."
This is one of the key concepts for receiver operation. It's called heterodyning. The definition of "heterodyning" is to mix two signals together in a nonlinear device. I prefer to think of heterodyning as "mix two signals together". And by mixing, we're talking "multiply". Which works perfectly for digital signals. The two signals that are mixed are typically a modulated signal at some radio frequency (RF), while the other is a sinusoid called a "local oscillator" or "LO". The output will be the RF signal shifted by the frequency of the LO. You effectively shift the frequency of the signal by the frequency of the sinusoid. Combined with this concept is the concept of superheterodyning. Superheterodyning, or "superhet" for short, means to shift the frequency of a signal to a fixed, intermediate frequency or "IF". The purpose for shifting to this fixed frequency is so that all of the follow-on processing, such as filtering and demodulation, can be designed for one frequency. This makes designing and building such circuits much easier.
The Limits of Software Tuning
Software tuning will only work on signals within +/-1/2 of the sample rate of the SDR.
Software tuning has one limitation. It only works on those signals within the instantaneous bandwidth of the SDR. In other words, it will only work on signals within +/-1/2 of the sample rate of the SDR.
Using Complex Sinusoids
But now we can add something that is difficult to do in the analog world. We can use complex sinusoids. Such a signal can have only a positive component (an analytical signal) or only a negative component (whatever that is called). With Gnu Radio, there are several ways we can create such signals. The simplest is using a Signal Source block with the "Output Type" set to "complex" and the "Waveform" set to either "Cosine" (the default) or "Sine".
data:image/s3,"s3://crabby-images/9ae02/9ae021f8a5969489b0f85bbd0bada30eb332e30f" alt="Gnu Radio Companion block diagram showing a complex signal source block connected to a throttle, then to a frequency sink spectral display."
data:image/s3,"s3://crabby-images/52149/52149dd279433c18dafd8d8bf708382ef16bf32a" alt="Spectral display of a complex sinusoid. The signal only shows a single spectral line."
We can also create such sinusoids in one of two ways. The first way is to create a real cosine and a real sine and use them as the real and imaginary components of a complex sinusoid, respectively. The second way is to create a real sinusoid, then filter out the negative frequency component using the Hilbert transform.
data:image/s3,"s3://crabby-images/1fb47/1fb475b550c2323ff5462d02a0a6cc809bfdbce2" alt="Screenshot of a block diagram showing two sinewave generators, a cosine and a sine. Descriptive text below each block explains that the cosine is the real part of a complex sinusoid, while the sine is the imaginary part of a complex sinusoid. They both feed into a block that converts the two real signals into a single complex signal. This block multiplies the imaginary part by the imaginary operator, j. This block feeds into a spectral display."
data:image/s3,"s3://crabby-images/991a7/991a7799a4b809aa289608e2bbfac788ed9e8416" alt="Spectral display of a complex sinusoid. It shows a spectral line at only one frequency."
data:image/s3,"s3://crabby-images/3a3b6/3a3b690341aa5ab6d675353dda59393c4a2b94c3" alt="Screenshot of a block diagram for a Hilbert transform of a sinusoid. The first block creates a vector of an impulse (a bunch of zeros with one positive value) that is fed into the Hilbert transform block. The output of the transform feeds into a spectral display."
data:image/s3,"s3://crabby-images/dd2cc/dd2ccae818e953f12caf50a625f6d474bfd94635" alt="Spectral display showing the impulse response of the Hilbert transform. For these particular values, the entire negative frequency portion of the spectrum has been filtered out, while the positive frequency portion is unaffected."
data:image/s3,"s3://crabby-images/c5fda/c5fda24aa806879c3c71a2bcab21b74d170bcc2d" alt="Gnu Radio Companion block diagram showing a block that generates a real sinusoid going into a Hilbert transform. The output goes through a throttle block then into a spectral display (frequency sink)."
data:image/s3,"s3://crabby-images/79cf1/79cf15f28dcc5324419900cba56d8977baa20f7b" alt="Spectral display of complex sinusoid created using the Hilbert transform. The display only shows a component at the positive frequency; the negative frequency is empty."
The Complex Frequency Shift
Regardless of how the single-sided sinusoid is created, it's useful for one thing in particular. It can be used to shift the frequency of a complex signal by simply multiplying the signal with the complex sinusoid. It is the most straightforward method for software tuning in Gnu Radio Companion. Just combine a Multiply block with a Signal Source block, with both blocks set for "complex" samples. This is a straightforward frequency shifter. This is what we discussed in the previous section.
data:image/s3,"s3://crabby-images/f0fe7/f0fe78086c54e45ccacd01932c1506eca19bfc4f" alt="Gnu Radio Companion flowgraph showing a File Source block going into a Throttle block. The output of the Throttle block goes into a Multiply block. A Signal Source block feeds the second input of the Multiply block. The output of the Multiply block goes into a Frequency Sink block."
data:image/s3,"s3://crabby-images/d11c4/d11c4d1def5399147bd6b30ac33852f0bd097036" alt="Spectral display of a portion of the FM broadcast band. Several signals are present, with a roll-off at the ends due to filtering."
data:image/s3,"s3://crabby-images/527a0/527a00eb5ee64cfb98dcc884f5892052a6544c12" alt="Spectral display showing a portion of the FM broadcast band. The ends of the original spectrum were filtered, showing a steep rolloff. This spectrum has been shifted to the right, so that the rolled-off ends are now near the center of the spectrum. There are still five signals visible in this spectrum."
And that is how software tuning is performed, typically. Multiply by a complex sinusoid to shift the desired signal higher or lower in frequency until it is centered, then perform the processing.
An Example
This is a basic receiver for the United States NOAA Weather Radio system. It uses a RTL-SDR, but the SDR is set to a fixed frequency. The "tuning" is all done in software. With the SDR set to the center channel (162.475 MHz) and the channel spacing of 25 kHz, the system only needs ~170 kHz of bandwidth to cover all of the channels (to include the bandwidth of the end channels due to modulation). However, I've set the RTL-SDR sample rate to 1.2 MHz. The reason is that, based on my experience, the lower sample rates (225 kHz - 300 kHz) don't tend to work as well as the higher ones. This could just be the quantization noise, or something else. Regardless, I've set the sample rate to 1.2 MHz initially, then filtered and decimated afterwards. I've used a lowpass filter set to a bandwidth of 100 kHz to provide the spectrum for tuning. Further, I've used a relatively high transition width in order to keep the amount of required processing down. The "Signal Source" block provides the complex sinusoid to tune in the desired signal. The rest is the standard processing (filtering, demodulation, sample rate adjustment, audio output). I used a "QT GUI Chooser" block to select one of the seven available channels. The QT GUI Chooser selects a frequency offset (+/-75 kHz in 25 kHz steps), which controls the Signal Source block.
data:image/s3,"s3://crabby-images/08fdd/08fdd5bcda89e7f4d36f00659165da32f24dc4cb" alt="Gnu Radio Companion block diagram showing a block for a RTL-SDR going into blocks for filtering, frequency conversion, demodulation, resampling, and an audio output. Four blocks spread horizontally across the top of the block diagram set the sample rate, general options, the channel frequency, and display the tuned frequency."
data:image/s3,"s3://crabby-images/a1708/a1708e596ba9d9328e75e6467386c2734c357aca" alt="Box containing the options for a Gnu Radio Companion Signal Source. Several lines of windows show options for the type of samples (set to "e;complex"e;), sample rate, waveform type (set to "e;Cosine"e;), and frequency (set to the math function "e;channel*1000"e;). Follow-on lines set the amplitude, offset and initial phase."
data:image/s3,"s3://crabby-images/f3b18/f3b182ba6703553fd1ca7a4f6a84b785bb4ae4e0" alt="Box containing the options for the Gnu Radio Companion QT GUI Chooser. Several option windows show parameters such as the label, the sample type, the number of options, the options list, the labels list and the default option."
data:image/s3,"s3://crabby-images/d9215/d921514da8a8fbea36fae14250c0551dd5f661c6" alt="Spectral display showing a relatively low noise floor that is sloped at each end, but offset towards the left end. The spectum has several signals present, with a large signal on the left end of the noise floor centered on the spectrum."
data:image/s3,"s3://crabby-images/d4c43/d4c4375c609370ba96d0cf96a89dd615f1097184" alt="Spectral display showing a relatively low noise floor that is sloped at each end, but offset towards the left end. The spectum has several signals present, with a large signal on the left end of the noise floor centered on the spectrum."
Other Software Receivers
The Bandpass Filter with Complex Taps
Here's another method for creating a software receiver that doesn't really "tune". By "tune", I mean to perform frequency conversion. Instead, it uses complex filter taps to create a bandpass filter. Instead of shifting the signal to the filter, this shifts the filter to the signal.
A bandpass filter that uses complex taps can operate on signals either just positive or negative in frequency. A bandpass filter that uses real taps must work equally on the positive and negative frequencies. The use of a complex tap bandpass filter means that all but one signal can be filtered out. Further, because it is an FM signal, we can frequency demodulate the signal with a polar discriminator (the improperly-named "Quadrature Demod" block), except it will have a large DC offset. The DC offset can be calculated, then removed with a "Add Const" block. While this is an interesting, in my opinion, this requires more processing than the complex frequency shift flowgraph from above. This particular flowgraph is not much more processing than the one using the complex frequency shift. Based on the use of a "Null Source" block to replace the RTL-SDR, and a "Probe Rate" and "Message Debug" block to replace the "Audio Sink", the complex frequency shift provided a maximum of 10.0 MSps, while this flowgraph provided 9.5 MSps.
data:image/s3,"s3://crabby-images/3c69e/3c69e0821ee44bcef1839a8aee0e11e8487025e5" alt="Gnu Radio Companion block diagram. This shows a block controlling a RTL-SDR, followed by two filter blocks, a demodulator block, and blocks to process the samples for the system speakers or headphones."
data:image/s3,"s3://crabby-images/4d73a/4d73a93dea0ebd9eeec5ff3b5b22e9fddc3418f1" alt="Spectral display showing several signals, with a strong signal on the left highlighted in red."
data:image/s3,"s3://crabby-images/8a0f6/8a0f609baead08c958677e05afc01b90b6e8a34d" alt="Spectral display showing several signals, with a signal near the center highlighted in red."
Software Tuning with the Polyphase Channelizer
Here's yet another software tuner. The difference of this one is that it doesn't process just one signal; if done properly, it does them all. For this example, I've tuned a RTL-SDR to a portion of the FM broadcast band. This flowgraph makes use of the "Polyphase Channelizer" block. This makes use of a polyphase filter bank that both filters and frequency shifts the signal down to 0 Hz. Which means that every signal within the instantaneous bandwidth of the RTL-SDR can be filtered, frequency shifted, and output. The only question is "Now what?" Sure, you can demodulate and further process one station (or, again, two if you're Tom Waits), but what about the rest? One possibility is that each channel is output to a network, where other systems can process each station. Or record each station. Or record the information contained in the broadcast.
One part that must be understood in order for this to work is that the sample rate must be the channel spacing (200 kHz, in this example) multiplied by the number of channels (12). That is why the overall sample rate is set to 2.4 MHz. This could also work with other sample rates, so long as the sample rate is an integer multiple of the channel spacing.
data:image/s3,"s3://crabby-images/bd562/bd562b243215db66ce11fdadc248d2268c5556aa" alt="Gnu Radio Companion block diagram showing blocks needed to create a polyphase channelizer for a portion of the FM broadcast band. A block on the left controls a RTL-SDR, which is followed by the polyphase channelizer block, then a 12 port selector block to select one of 12 stations. After the selector block, one station is selected for demodulation and audio output."
data:image/s3,"s3://crabby-images/cddd0/cddd0164532e5f6d031ec73c95727e85c308310d" alt="Spectral displays for the full instantaneous bandwidth of the RTL-SDR and the output of the selected channel. They are stacked one on top of the other. There's a small dropdown arrow along the top to select the desired channel. The full spectrum shows several, available analog FM broadcast signals."
Software Tuning Baseband Signals
This is something I've already covered in several posts, most recently with my post on the best RDS demodulator and decoder circuit. Those flowgraphs show a complex frequency shift for the baseband spectrum in order to tune to the 57 kHz RDS / RBDS signal.
data:image/s3,"s3://crabby-images/b9ba0/b9ba0c0621f8e942e5a37134d1315ca4cc0e0e96" alt="Gnu Radio Companion block diagram of a FM broadcast demodulator and Radio Data System demodulator and decoder. The block diagram is complicated, with many blocks for filtering, frequency shifting, demodulating and decoding the signal."
If we were to put a "Frequency Sink" block both before and after the "Multiply" block, we would see the spectrum first unshifted (before) and shifted down by 57 kHz (after).
data:image/s3,"s3://crabby-images/8f0d9/8f0d9e71c17ddc4d6e767722600c2316c2e19cd6" alt="Spectral display of the demodulated output of a FM broadcast station. This spectral display shows all of the signals modulated onto a typical FM broadcast station. The spectrum also shows the mirror image (negative frequencies), and is centered on the 0 Hz."
data:image/s3,"s3://crabby-images/2614e/2614e8d900108ade06a51bf2dda6e3649b68bdd8" alt="Spectral display of the demodulated output of a FM broadcast station that has been shifted down in frequency by 57 kHz. This spectral display shows all of the signals modulated onto a typical FM broadcast station. The spectrum also shows the mirror image (negative frequencies), and is centered on the 57 kHz RDS signal."
Summary
This hopefully gives you an idea of the many different options for performing software tuning. There are several possible options for each of these, along with things I didn't have time to cover. For example, one thing I didn't cover was the use of a "Vector Source" block to replace the "Signal Source" block. This is possible when it's possible to calculate the values of the complex sinusoids beforehand. This will save on the processing required as the "Signal Source" block calculates its values on-the-fly. If they can be calculated before the flowgraph runs, this saves on the processing.
Til next time!