Skip to main content

GNU Radio Waterfall and CW Filter

The following GNU radio application adds a waterfall spectrogram to the previous CW filter program. The plot show 4 CW signals in the audio band (lower sideband) at 7023 kHz. The 700Hz signal is filtered and output to the laptop headphones by the CW bandpass filter. The frequency display is shown after the script which is as follows:

#!/usr/bin/env python

from gnuradio import gr
from gnuradio import audio
from lpf_bpf_class import Bandpass
from gnuradio.qtgui import qtgui
from PyQt4 import QtGui
import sys, sip
 
 
class cw_filter(gr.top_block):
    def __init__(self):
        gr.top_block.__init__(self)
 
        sample_rate = 44100
        out_rate = 8000
        kaiser = Bandpass()
        cw_flr = gr.fir_filter_fff(1, kaiser.bpftaps)

        decimate = int(sample_rate/out_rate)
        Bandpass.cutoff1 = 3000       
        pre_decim = Bandpass()
        dec_flr = gr.fir_filter_fff(1, pre_decim.lpftaps)
        dec = gr.keep_one_in_n(gr.sizeof_float, decimate)

        # Make a local QtApp
        self.qapp = QtGui.QApplication(sys.argv)
        fftsize = 2048

        audio_mic = audio.source(sample_rate, "plughw:0,0")
        amp1 = gr.multiply_const_ff(2.0)
        amp2 = gr.multiply_const_ff(1.0)
        dst = audio.sink (sample_rate, "")

        self.connect (audio_mic, cw_flr, amp1, dst)

        self.thr = gr.throttle(gr.sizeof_float, 100*fftsize)
        self.snk = qtgui.sink_f(fftsize, gr.firdes.WIN_BLACKMAN_hARRIS,
                         0,
                         4000,
                        "CW Kaiser BPF Filter")
                        #True, True, False, True, False)

        self.connect(audio_mic, amp2, self.thr, dec, self.snk)

        self.pyobj = sip.wrapinstance(self.snk.pyqwidget(), QtGui.QWidget)
        self.pyobj.show()

def main():
    tb = cw_filter()
    tb.start()
    tb.qapp.exec_()


if __name__ == '__main__':
    try:
        main()
    except [[KeyboardInterrupt]]:
        pass

Comments

Popular posts from this blog

Digital Bandpass Filter FIR design - Python

The python code generates the Finite Impulse Response (FIR) filter coefficients for a lowpass filter (LPF) at 10 (Hz) cut off using firwin from scipy.  A highpass filter is then created by subtracting the lowpass filter output(s) from the output of an allpass filter. To do this the coefficients of the LPF are multiplied by -1 and 1 added to the centre tap (to create the allpass filter with subtraction). A second LPF is then created with a cutoff at 15 (Hz) and the bandpass filter formed by addition of the LPF and HPF coefficients. The program also generates a test sine wave of a given amplitude and power and to this noise from a Normal distribution is added.  The graph below shows the signal and nois, and the signal (green) after filtering. The input snr is approximately 3dB. The frequency response below shows the passband centered on 12.5 (Hz), the Nyquist frequency is 50 (Hz). from numpy import cos, sin, pi, absolute, arange from numpy.random import normal fr...

Norton Wideband HF pre-amp

The 20m vertical antenna looks good, VSWR < 1.3 : 1 but RX might be a bit deaf. RX details: 1dB antenna cable loss: + 14MHz to 144MHz SBL-1 mixer (straight 6dB loss) :+ IC 202 144MHz receiver (8dB NF). Hence total receive noise figure is at least 15dB. Built a Norton HF preamp (2n5109) to try and improve situation. (Is this necessary given the noise level at 14MHz? see following. Photo below shows the circuit and the measured cbe voltages resulting from a 13.9v supply. First audible results were however not particularly impressive. The dominant noise is the external noise? and this is in excess of any receiver contribution - even at 15dB noise fugure? But I will look into this and quantify the position. OK, this is a simple circuit and the 50 ohm output load is transformed by the broadband auto transformer to the collector load. The actual turns ratio used was 3 to the tap and then 11 to the collector. The turns ratio is then 14/3 or 4.6 which is the voltage transformation. ...