1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148
|
#!/usr/bin/env python
from gnuradio import gr, gru
from gnuradio import usrp
from gnuradio.eng_option import eng_option
from optparse import OptionParser
from gnuradio.wxgui import stdgui, slider
import wx
class flex_siggen (stdgui.gui_flow_graph):
__slots__ = ['interp', 'waveform_type', 'waveform_ampl',
'waveform_freq', 'waveform_offset', 'fg', 'usrp',
'siggen', 'noisegen', 'src', 'file_sink' ]
def __init__ (self,frame,panel,vbox,argv):
stdgui.gui_flow_graph.__init__ (self, frame, panel, vbox, argv)
self.frame = frame
self.panel = panel
parser = OptionParser (option_class=eng_option)
parser.add_option ("-a", "--amplitude", type="int", default=32000,
help="amplitude")
parser.add_option ("-i", "--interp", type="int", default=64,
help="set fpga interpolation rate to INTERP")
parser.add_option ("-n", "--nchannels", type="int", default=1,
help="set number of output channels to NCHANNELS")
(options, args) = parser.parse_args ()
self.waveform_type = gr.GR_CONST_WAVE
self.waveform_ampl = options.amplitude
self.waveform_freq = 100.12345e3
self.waveform_offset = 0
self.interp = options.interp
self._instantiate_blocks ()
self.usrp.set_nchannels (options.nchannels)
self.dboard=self.usrp.db[0][0]
self.set_waveform_type (self.waveform_type)
vbox.Add(slider.slider(panel, 390, 510, self.set_rf_freq), 1, wx.EXPAND|wx.ALIGN_CENTER)
vbox.Add(slider.slider(panel, -45000, +45000, self.set_if_freq), 1, wx.EXPAND|wx.ALIGN_CENTER)
#vbox.Add(slider.slider(panel, 0, 4095, self.set_gain), 1, wx.EXPAND|wx.ALIGN_CENTER)
def usb_freq (self):
return self.usrp.dac_freq() / self.interp
def usb_throughput (self):
return self.usb_freq () * 4
def set_waveform_type (self, type):
'''
valid waveform types are: gr.GR_SIN_WAVE, gr.GR_CONST_WAVE,
gr.GR_UNIFORM and gr.GR_GAUSSIAN
'''
self._configure_graph (type)
self.waveform_type = type
def set_waveform_ampl (self, ampl):
self.waveform_ampl = ampl
self.siggen.set_amplitude (ampl)
self.noisegen.set_amplitude (ampl)
def set_waveform_freq (self, freq):
self.waveform_freq = freq
self.siggen.set_frequency (freq)
def set_if_freq (self, freq):
self.if_freq = freq
self.usrp.set_tx_freq (0,freq*1e3)
def set_rf_freq (self, freq):
self.rf_freq = freq
(success,actual_freq) = self.dboard.set_freq (freq*1e6)
if not success:
print "Failed on ", freq
def set_waveform_offset (self, offset):
self.waveform_offset = offset
self.siggen.set_offset (offset)
def set_interpolator (self, interp):
self.interp = interp
self.siggen.set_sampling_freq (self.usb_freq ())
self.usrp.set_interp_rate (interp)
def set_duc_freq (self, freq):
self.usrp.set_tx_freq (0, freq)
def _instantiate_blocks (self):
self.src = None
self.usrp = usrp.sink_c (0, self.interp)
self.siggen = gr.sig_source_c (self.usb_freq (),
gr.GR_SIN_WAVE,
self.waveform_freq,
self.waveform_ampl,
self.waveform_offset)
self.noisegen = gr.noise_source_c (gr.GR_UNIFORM,
self.waveform_ampl)
print "done"
def _configure_graph (self, type):
was_running = self.is_running ()
if was_running:
self.stop ()
self.disconnect_all ()
if type == gr.GR_SIN_WAVE or type == gr.GR_CONST_WAVE:
self.connect (self.siggen, self.usrp)
self.siggen.set_waveform (type)
self.src = self.siggen
elif type == gr.GR_UNIFORM or type == gr.GR_GAUSSIAN:
self.connect (self.noisegen, self.usrp)
self.noisegen.set_type (type)
self.src = self.noisegen
else:
raise ValueError, type
if was_running:
self.start ()
if __name__ == '__main__':
parser = OptionParser (option_class=eng_option)
parser.add_option ("--sine", dest="type", action="store_const", const=gr.GR_SIN_WAVE,
help="generate a complex sinusoid [default]", default=gr.GR_SIN_WAVE)
parser.add_option ("--const", dest="type", action="store_const", const=gr.GR_CONST_WAVE,
help="generate a constant output")
parser.add_option ("--gaussian", dest="type", action="store_const", const=gr.GR_GAUSSIAN,
help="generate Gaussian random output")
parser.add_option ("--uniform", dest="type", action="store_const", const=gr.GR_UNIFORM,
help="generate Uniform random output")
parser.add_option ("-f", "--freq", type="eng_float", default=100e3,
help="set waveform frequency to FREQ")
parser.add_option ("-r", "--rf-freq", type="eng_float", default=910e6,
help="set waveform frequency to FREQ")
parser.add_option ("-a", "--amplitude", type="eng_float", default=16e3,
help="set waveform amplitude to AMPLITUDE", metavar="AMPL")
parser.add_option ("-o", "--offset", type="eng_float", default=0,
help="set waveform offset to OFFSET")
parser.add_option ("-c", "--duc-freq", type="eng_float", default=0,
help="set Tx DUC frequency to FREQ", metavar="FREQ")
parser.add_option ("-m", "--mux", type="intx", default=0x98,
help="set output mux register")
app = stdgui.stdapp (flex_siggen, "USRP FlexRF Siggen")
app.MainLoop ()
|