Python 如何编辑top_block.py,使频率在两个值之间不断随机设置?
我有一个简单的流程图: 生成此顶部块的:Python 如何编辑top_block.py,使频率在两个值之间不断随机设置?,python,python-3.x,signal-processing,gnuradio,gnuradio-companion,Python,Python 3.x,Signal Processing,Gnuradio,Gnuradio Companion,我有一个简单的流程图: 生成此顶部块的: #!/usr/bin/env python3 # -*- coding: utf-8 -*- # # SPDX-License-Identifier: GPL-3.0 # # GNU Radio Python Flow Graph # Title: Not titled yet # Author: alessandro # GNU Radio version: 3.8.1.0 from distutils.version import Strict
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
#
# SPDX-License-Identifier: GPL-3.0
#
# GNU Radio Python Flow Graph
# Title: Not titled yet
# Author: alessandro
# GNU Radio version: 3.8.1.0
from distutils.version import StrictVersion
if __name__ == '__main__':
import ctypes
import sys
if sys.platform.startswith('linux'):
try:
x11 = ctypes.cdll.LoadLibrary('libX11.so')
x11.XInitThreads()
except:
print("Warning: failed to XInitThreads()")
from gnuradio import analog
from gnuradio import gr
from gnuradio.filter import firdes
import sys
import signal
from PyQt5 import Qt
from argparse import ArgumentParser
from gnuradio.eng_arg import eng_float, intx
from gnuradio import eng_notation
import osmosdr
import time
from gnuradio import qtgui
class test(gr.top_block, Qt.QWidget):
def __init__(self):
gr.top_block.__init__(self, "Not titled yet")
Qt.QWidget.__init__(self)
self.setWindowTitle("Not titled yet")
qtgui.util.check_set_qss()
try:
self.setWindowIcon(Qt.QIcon.fromTheme('gnuradio-grc'))
except:
pass
self.top_scroll_layout = Qt.QVBoxLayout()
self.setLayout(self.top_scroll_layout)
self.top_scroll = Qt.QScrollArea()
self.top_scroll.setFrameStyle(Qt.QFrame.NoFrame)
self.top_scroll_layout.addWidget(self.top_scroll)
self.top_scroll.setWidgetResizable(True)
self.top_widget = Qt.QWidget()
self.top_scroll.setWidget(self.top_widget)
self.top_layout = Qt.QVBoxLayout(self.top_widget)
self.top_grid_layout = Qt.QGridLayout()
self.top_layout.addLayout(self.top_grid_layout)
self.settings = Qt.QSettings("GNU Radio", "test")
try:
if StrictVersion(Qt.qVersion()) < StrictVersion("5.0.0"):
self.restoreGeometry(self.settings.value("geometry").toByteArray())
else:
self.restoreGeometry(self.settings.value("geometry"))
except:
pass
##################################################
# Variables
##################################################
self.samp_rate = samp_rate = 2000000
##################################################
# Blocks
##################################################
self.osmosdr_sink_0 = osmosdr.sink(
args="numchan=" + str(1) + " " + ""
)
self.osmosdr_sink_0.set_time_unknown_pps(osmosdr.time_spec_t())
self.osmosdr_sink_0.set_sample_rate(samp_rate)
self.osmosdr_sink_0.set_center_freq(100e6, 0)
self.osmosdr_sink_0.set_freq_corr(0, 0)
self.osmosdr_sink_0.set_gain(10, 0)
self.osmosdr_sink_0.set_if_gain(20, 0)
self.osmosdr_sink_0.set_bb_gain(20, 0)
self.osmosdr_sink_0.set_antenna('', 0)
self.osmosdr_sink_0.set_bandwidth(0, 0)
self.analog_sig_source_x_0 = analog.sig_source_c(samp_rate, analog.GR_COS_WAVE, 1000, 1, 0, 0)
##################################################
# Connections
##################################################
self.connect((self.analog_sig_source_x_0, 0), (self.osmosdr_sink_0, 0))
def closeEvent(self, event):
self.settings = Qt.QSettings("GNU Radio", "test")
self.settings.setValue("geometry", self.saveGeometry())
event.accept()
def get_samp_rate(self):
return self.samp_rate
def set_samp_rate(self, samp_rate):
self.samp_rate = samp_rate
self.analog_sig_source_x_0.set_sampling_freq(self.samp_rate)
self.osmosdr_sink_0.set_sample_rate(self.samp_rate)
def main(top_block_cls=test, options=None):
if StrictVersion("4.5.0") <= StrictVersion(Qt.qVersion()) < StrictVersion("5.0.0"):
style = gr.prefs().get_string('qtgui', 'style', 'raster')
Qt.QApplication.setGraphicsSystem(style)
qapp = Qt.QApplication(sys.argv)
tb = top_block_cls()
tb.start()
tb.show()
def sig_handler(sig=None, frame=None):
Qt.QApplication.quit()
signal.signal(signal.SIGINT, sig_handler)
signal.signal(signal.SIGTERM, sig_handler)
timer = Qt.QTimer()
timer.start(500)
timer.timeout.connect(lambda: None)
def quitting():
tb.stop()
tb.wait()
qapp.aboutToQuit.connect(quitting)
qapp.exec_()
if __name__ == '__main__':
main()
看起来您想要的不是
random.choice
,而是random.randrange
(还有一些列表解压,以便您可以使用输入列表作为传递给函数的参数)random.randrange(x,y)
的工作原理与执行random.choice(range(x,y))
的工作原理相同,但效率更高。这是一个例子
如果要在最小值和最大值之间选择一个随机频率,那么代码应该如下所示:
freqs = [100000000,200000000]
while 1:
freq = random.choice(freqs)
# then osmocom transmits in "freq"
freqs = [100000000,200000000]
while True:
# Doing *freqs unpacks the list so you can use it as
# arguments to random.randrange
freq = random.randrange(*freqs)
# your other code stuff
我不知道为什么你把其他的代码放在那里,而随机化似乎是你唯一的问题。如果这与当前的问题有关,那么我将不得不请你澄清这个问题,因为现在的措辞似乎就是这样。似乎你想要的不是
random.choice
,而是random.randrange
(还有一些列表解压,以便您可以将输入列表用作传递给函数的参数)。random.randrange(x,y)
的工作原理与执行random.choice(range(x,y))
的工作原理相同,但效率更高。下面是一个示例
如果要在最小值和最大值之间选择一个随机频率,那么代码应该如下所示:
freqs = [100000000,200000000]
while 1:
freq = random.choice(freqs)
# then osmocom transmits in "freq"
freqs = [100000000,200000000]
while True:
# Doing *freqs unpacks the list so you can use it as
# arguments to random.randrange
freq = random.randrange(*freqs)
# your other code stuff
我不知道你为什么要在随机化似乎是你唯一的问题的时候把另一个代码放在那里。如果这与手头的问题有关,那么我将不得不请你澄清这个问题,因为按照现在的措辞,看起来就是这样。谢谢你的回答。实际上我的问题不是随机化。我不知道在哪里放置随机化部分代码以获得一个工作代码。啊,在这种情况下,我需要更多的澄清,确切地说你正在尝试做什么。如果你试图让它不断地选择一个随机频率,你应该将它放在
while
循环中;否则,如果你想做的是有一个随机频率ains常量,你会想在循环之外使用它。谢谢你的回答。事实上我的问题不是随机化。而是我不知道把随机化部分代码放在哪里才能有一个工作代码。啊,在这种情况下,我需要更多的澄清,确切地说你想做什么。如果你想让它不断地工作选择一个随机频率,你会把它放在while
循环中;否则,如果你想做的是让一个随机频率保持不变,你会想在循环之外使用它。