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方法,把流程图跑起来