中断简单的GNUradio流程

时间:2016-06-29 12:25:09

标签: gnuradio

我正在尝试在python中编写GNUradio脚本。我最终的目标是有一个例程,定期将GNUradio进程中的浮点结果写入串口。作为第一步,我想简单地暂停一个简单的例程以下代码通过声卡播放1kHz的音调:

`#!/usr/bin/env python
##################################################
# Gnuradio Python Flow Graph
# Title: simpleTone
# Generated: Wed Jun 29 07:26:02 2016
##################################################

from gnuradio import analog
from gnuradio import audio
from gnuradio import blocks
from gnuradio import gr
import time

class simpleTone(gr.top_block):

    def __init__(self):
    gr.top_block.__init__(self)

        ##################################################
        # Variables
        ##################################################
        self.samp_rate = samp_rate = 32000

        ##################################################
        # Blocks
        ##################################################
        self.blocks_throttle_0 = blocks.throttle(gr.sizeof_float*1, samp_rate)
        self.audio_sink_0 = audio.sink(samp_rate, "", True)
        self.analog_sig_source_x_0 = analog.sig_source_f(samp_rate, analog.GR_COS_WAVE, 1000, 1, 0)

        ##################################################
        # Connections
        ##################################################
        self.connect((self.analog_sig_source_x_0, 0), (self.blocks_throttle_0, 0))
        self.connect((self.blocks_throttle_0, 0), (self.audio_sink_0, 0))


if __name__ == '__main__':
    simpleTone().run()`

上面的代码工作正常,除了一些溢出和点击音频。但是,如果我进行以下替换:

`        
if __name__ == '__main__':
    simpleTone().start()
    time.sleep(3)
    simpleTone().stop()`

结果是文件运行,并在3秒后结束,但没有产生音频。

我确定我错过了一些相当基本的东西,任何帮助都会受到赞赏。感谢。

-Ed

2 个答案:

答案 0 :(得分:0)

这个问题也在这里提出:

http://lists.gnu.org/archive/html/discuss-gnuradio

并得到了回答。如果有人遇到这个问题,我会在这里分享这个答案:

  

您的问题是您正在构建三个不相关的顶级块:   你有三个单独出现的" simpleTone()"。相反,你   需要创建一个并继续使用它,如下所示:

tb = simpleTone()
tb.start()
...
tb.stop()
     

你还有另一个问题,你会在修复之后找到   第一。 .wait()表示等待流程图完成所有操作   处理,您的流程图中没有任何元素可以完成   例如Head块,所以永远不会到达.stop()。

     

相反,你需要这样做:

tb = simpleTone()
tb.start()
# the flowgraph is now running independently
time.sleep(3)
tb.stop()
tb.wait()
     

在这种情况下,最终的.wait()实际上并不是必需的 - 它是什么   是等待流程图完成,这将很快发生   调用.stop()后,如果你以后希望启动相同的顶部   再次阻止,你必须在调用.start()之前调用.wait(),   所以总是有一组匹配的[开始,停止,等待]或[开始,   等等,停止]是很好的做法。

答案 1 :(得分:0)

这是你在python中创建对象的方式的问题。每次调用“SimpleTone()'”时,您实际上都在启动一个新对象。类simpleTone。我同意先前的答案,即创建一个对象将解决问题。