gnuradio-companion生成Python代码
首先我们用gnuradio-compaion搭建如下的框图,功能是显示麦克风采回来的声音的频谱。
注意,在这里我们把Options里的ID改为了audio_test。
然后点击运行按钮左边的Generate the flow graph按钮,就会在当前目录生成audio_test.py
#!/usr/bin/env python ################################################## # Gnuradio Python Flow Graph # Title: Audio Test # Generated: Wed Apr 9 12:01:49 2014 ################################################## from gnuradio import audio from gnuradio import eng_notation from gnuradio import gr from gnuradio import wxgui from gnuradio.eng_option import eng_option from gnuradio.fft import window from gnuradio.filter import firdes from gnuradio.wxgui import fftsink2 from grc_gnuradio import wxgui as grc_wxgui from optparse import OptionParser import wx class audio_test(grc_wxgui.top_block_gui): def __init__(self): grc_wxgui.top_block_gui.__init__(self, title="Audio Test") ################################################## # Variables ################################################## self.samp_rate = samp_rate = 32000 ################################################## # Blocks ################################################## self.wxgui_fftsink2_0 = fftsink2.fft_sink_f( self.GetWin(), baseband_freq=0, y_per_div=10, y_divs=10, ref_level=0, ref_scale=2.0, sample_rate=samp_rate, fft_size=1024, fft_rate=15, average=False, avg_alpha=None, title="FFT Plot", peak_hold=False, ) self.Add(self.wxgui_fftsink2_0.win) self.audio_source_0 = audio.source(samp_rate, "", True) ################################################## # Connections ################################################## self.connect((self.audio_source_0, 0), (self.wxgui_fftsink2_0, 0)) # QT sink close method reimplementation def get_samp_rate(self): return self.samp_rate def set_samp_rate(self, samp_rate): self.samp_rate = samp_rate self.wxgui_fftsink2_0.set_sample_rate(self.samp_rate) if __name__ == '__main__': import ctypes import os if os.name == 'posix': try: x11 = ctypes.cdll.LoadLibrary('libX11.so') x11.XInitThreads() except: print "Warning: failed to XInitThreads()" parser = OptionParser(option_class=eng_option, usage="%prog: [options]") (options, args) = parser.parse_args() tb = audio_test() tb.Start(True) tb.Wait()
代码很短,大致上做了以下几件事情:
- import许多依赖库
- 以grc_wxgui.top_block_gui为基类继承出audio_test类
- 该类描述了整个流图
- 创建了Audio Source和FFT Sink,并将二者Connect起来。
- 第65行开始,是程序的主流程。可以理解为C语言里的main函数
- 处理命令行参数
- 创建我们上述定义的audio_test类
- 调用它的Start方法,把流程图跑起来