-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
22b5a06
commit d113417
Showing
42 changed files
with
5,133 additions
and
0 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,294 @@ | ||
#!/usr/bin/env python3 | ||
# -*- coding: utf-8 -*- | ||
|
||
# | ||
# SPDX-License-Identifier: GPL-3.0 | ||
# | ||
# GNU Radio Python Flow Graph | ||
# Title: Not titled yet | ||
# GNU Radio version: 3.9.4.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 PyQt5 import Qt | ||
from gnuradio import qtgui | ||
from gnuradio.filter import firdes | ||
import sip | ||
from gnuradio import blocks | ||
import pmt | ||
from gnuradio import digital | ||
from gnuradio import gr | ||
from gnuradio.fft import window | ||
import sys | ||
import signal | ||
from argparse import ArgumentParser | ||
from gnuradio.eng_arg import eng_float, intx | ||
from gnuradio import eng_notation | ||
import satellites.components.datasinks | ||
import satellites.components.deframers | ||
|
||
|
||
|
||
from gnuradio import qtgui | ||
|
||
class ax100Wav_parser(gr.top_block, Qt.QWidget): | ||
|
||
def __init__(self): | ||
gr.top_block.__init__(self, "Not titled yet", catch_exceptions=True) | ||
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", "ax100Wav_parser") | ||
|
||
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 = 2.4e6 | ||
|
||
################################################## | ||
# Blocks | ||
################################################## | ||
self.satellites_telemetry_parser_0 = satellites.components.datasinks.telemetry_parser('gomx_1', file = '/home/jonathan/CommsSDR/output/output_AX100.txt', options="") | ||
self.satellites_ax100_deframer_0 = satellites.components.deframers.ax100_deframer(mode = "ASM", scrambler = "CCSDS", syncword_threshold = 0, options="") | ||
self.qtgui_waterfall_sink_x_0 = qtgui.waterfall_sink_c( | ||
1024, #size | ||
window.WIN_BLACKMAN_hARRIS, #wintype | ||
0, #fc | ||
samp_rate, #bw | ||
"", #name | ||
1, #number of inputs | ||
None # parent | ||
) | ||
self.qtgui_waterfall_sink_x_0.set_update_time(0.10) | ||
self.qtgui_waterfall_sink_x_0.enable_grid(False) | ||
self.qtgui_waterfall_sink_x_0.enable_axis_labels(True) | ||
|
||
|
||
|
||
labels = ['', '', '', '', '', | ||
'', '', '', '', ''] | ||
colors = [0, 0, 0, 0, 0, | ||
0, 0, 0, 0, 0] | ||
alphas = [1.0, 1.0, 1.0, 1.0, 1.0, | ||
1.0, 1.0, 1.0, 1.0, 1.0] | ||
|
||
for i in range(1): | ||
if len(labels[i]) == 0: | ||
self.qtgui_waterfall_sink_x_0.set_line_label(i, "Data {0}".format(i)) | ||
else: | ||
self.qtgui_waterfall_sink_x_0.set_line_label(i, labels[i]) | ||
self.qtgui_waterfall_sink_x_0.set_color_map(i, colors[i]) | ||
self.qtgui_waterfall_sink_x_0.set_line_alpha(i, alphas[i]) | ||
|
||
self.qtgui_waterfall_sink_x_0.set_intensity_range(-140, 10) | ||
|
||
self._qtgui_waterfall_sink_x_0_win = sip.wrapinstance(self.qtgui_waterfall_sink_x_0.qwidget(), Qt.QWidget) | ||
|
||
self.top_layout.addWidget(self._qtgui_waterfall_sink_x_0_win) | ||
self.qtgui_time_sink_x_0 = qtgui.time_sink_f( | ||
1024, #size | ||
samp_rate, #samp_rate | ||
"", #name | ||
1, #number of inputs | ||
None # parent | ||
) | ||
self.qtgui_time_sink_x_0.set_update_time(0.10) | ||
self.qtgui_time_sink_x_0.set_y_axis(-1, 1) | ||
|
||
self.qtgui_time_sink_x_0.set_y_label('Amplitude', "") | ||
|
||
self.qtgui_time_sink_x_0.enable_tags(True) | ||
self.qtgui_time_sink_x_0.set_trigger_mode(qtgui.TRIG_MODE_FREE, qtgui.TRIG_SLOPE_POS, 0.0, 0, 0, "") | ||
self.qtgui_time_sink_x_0.enable_autoscale(False) | ||
self.qtgui_time_sink_x_0.enable_grid(False) | ||
self.qtgui_time_sink_x_0.enable_axis_labels(True) | ||
self.qtgui_time_sink_x_0.enable_control_panel(False) | ||
self.qtgui_time_sink_x_0.enable_stem_plot(False) | ||
|
||
|
||
labels = ['Signal 1', 'Signal 2', 'Signal 3', 'Signal 4', 'Signal 5', | ||
'Signal 6', 'Signal 7', 'Signal 8', 'Signal 9', 'Signal 10'] | ||
widths = [1, 1, 1, 1, 1, | ||
1, 1, 1, 1, 1] | ||
colors = ['blue', 'red', 'green', 'black', 'cyan', | ||
'magenta', 'yellow', 'dark red', 'dark green', 'dark blue'] | ||
alphas = [1.0, 1.0, 1.0, 1.0, 1.0, | ||
1.0, 1.0, 1.0, 1.0, 1.0] | ||
styles = [1, 1, 1, 1, 1, | ||
1, 1, 1, 1, 1] | ||
markers = [-1, -1, -1, -1, -1, | ||
-1, -1, -1, -1, -1] | ||
|
||
|
||
for i in range(1): | ||
if len(labels[i]) == 0: | ||
self.qtgui_time_sink_x_0.set_line_label(i, "Data {0}".format(i)) | ||
else: | ||
self.qtgui_time_sink_x_0.set_line_label(i, labels[i]) | ||
self.qtgui_time_sink_x_0.set_line_width(i, widths[i]) | ||
self.qtgui_time_sink_x_0.set_line_color(i, colors[i]) | ||
self.qtgui_time_sink_x_0.set_line_style(i, styles[i]) | ||
self.qtgui_time_sink_x_0.set_line_marker(i, markers[i]) | ||
self.qtgui_time_sink_x_0.set_line_alpha(i, alphas[i]) | ||
|
||
self._qtgui_time_sink_x_0_win = sip.wrapinstance(self.qtgui_time_sink_x_0.qwidget(), Qt.QWidget) | ||
self.top_layout.addWidget(self._qtgui_time_sink_x_0_win) | ||
self.qtgui_freq_sink_x_0 = qtgui.freq_sink_c( | ||
1024, #size | ||
window.WIN_BLACKMAN_hARRIS, #wintype | ||
0, #fc | ||
samp_rate, #bw | ||
"", #name | ||
1, | ||
None # parent | ||
) | ||
self.qtgui_freq_sink_x_0.set_update_time(0.10) | ||
self.qtgui_freq_sink_x_0.set_y_axis(-140, 10) | ||
self.qtgui_freq_sink_x_0.set_y_label('Relative Gain', 'dB') | ||
self.qtgui_freq_sink_x_0.set_trigger_mode(qtgui.TRIG_MODE_FREE, 0.0, 0, "") | ||
self.qtgui_freq_sink_x_0.enable_autoscale(False) | ||
self.qtgui_freq_sink_x_0.enable_grid(False) | ||
self.qtgui_freq_sink_x_0.set_fft_average(1.0) | ||
self.qtgui_freq_sink_x_0.enable_axis_labels(True) | ||
self.qtgui_freq_sink_x_0.enable_control_panel(False) | ||
self.qtgui_freq_sink_x_0.set_fft_window_normalized(False) | ||
|
||
|
||
|
||
labels = ['', '', '', '', '', | ||
'', '', '', '', ''] | ||
widths = [1, 1, 1, 1, 1, | ||
1, 1, 1, 1, 1] | ||
colors = ["blue", "red", "green", "black", "cyan", | ||
"magenta", "yellow", "dark red", "dark green", "dark blue"] | ||
alphas = [1.0, 1.0, 1.0, 1.0, 1.0, | ||
1.0, 1.0, 1.0, 1.0, 1.0] | ||
|
||
for i in range(1): | ||
if len(labels[i]) == 0: | ||
self.qtgui_freq_sink_x_0.set_line_label(i, "Data {0}".format(i)) | ||
else: | ||
self.qtgui_freq_sink_x_0.set_line_label(i, labels[i]) | ||
self.qtgui_freq_sink_x_0.set_line_width(i, widths[i]) | ||
self.qtgui_freq_sink_x_0.set_line_color(i, colors[i]) | ||
self.qtgui_freq_sink_x_0.set_line_alpha(i, alphas[i]) | ||
|
||
self._qtgui_freq_sink_x_0_win = sip.wrapinstance(self.qtgui_freq_sink_x_0.qwidget(), Qt.QWidget) | ||
self.top_layout.addWidget(self._qtgui_freq_sink_x_0_win) | ||
self.digital_gfsk_demod_0 = digital.gfsk_demod( | ||
samples_per_symbol=2, | ||
sensitivity=1.0, | ||
gain_mu=0.175, | ||
mu=0.5, | ||
omega_relative_limit=0.005, | ||
freq_error=0.0, | ||
verbose=False, | ||
log=True) | ||
self.blocks_uchar_to_float_0 = blocks.uchar_to_float() | ||
self.blocks_throttle_0 = blocks.throttle(gr.sizeof_gr_complex*1, samp_rate,True) | ||
self.blocks_message_debug_0 = blocks.message_debug(True) | ||
self.blocks_file_source_0 = blocks.file_source(gr.sizeof_gr_complex*1, '/home/jonathan/CommsSDR/output/recordingASMGolay.wav', False, 0, 0) | ||
self.blocks_file_source_0.set_begin_tag(pmt.PMT_NIL) | ||
|
||
|
||
|
||
################################################## | ||
# Connections | ||
################################################## | ||
self.msg_connect((self.satellites_ax100_deframer_0, 'out'), (self.blocks_message_debug_0, 'print_pdu')) | ||
self.msg_connect((self.satellites_ax100_deframer_0, 'out'), (self.blocks_message_debug_0, 'print')) | ||
self.msg_connect((self.satellites_ax100_deframer_0, 'out'), (self.satellites_telemetry_parser_0, 'in')) | ||
self.connect((self.blocks_file_source_0, 0), (self.blocks_throttle_0, 0)) | ||
self.connect((self.blocks_throttle_0, 0), (self.digital_gfsk_demod_0, 0)) | ||
self.connect((self.blocks_throttle_0, 0), (self.qtgui_freq_sink_x_0, 0)) | ||
self.connect((self.blocks_throttle_0, 0), (self.qtgui_waterfall_sink_x_0, 0)) | ||
self.connect((self.blocks_uchar_to_float_0, 0), (self.qtgui_time_sink_x_0, 0)) | ||
self.connect((self.blocks_uchar_to_float_0, 0), (self.satellites_ax100_deframer_0, 0)) | ||
self.connect((self.digital_gfsk_demod_0, 0), (self.blocks_uchar_to_float_0, 0)) | ||
|
||
|
||
def closeEvent(self, event): | ||
self.settings = Qt.QSettings("GNU Radio", "ax100Wav_parser") | ||
self.settings.setValue("geometry", self.saveGeometry()) | ||
self.stop() | ||
self.wait() | ||
|
||
event.accept() | ||
|
||
def get_samp_rate(self): | ||
return self.samp_rate | ||
|
||
def set_samp_rate(self, samp_rate): | ||
self.samp_rate = samp_rate | ||
self.blocks_throttle_0.set_sample_rate(self.samp_rate) | ||
self.qtgui_freq_sink_x_0.set_frequency_range(0, self.samp_rate) | ||
self.qtgui_time_sink_x_0.set_samp_rate(self.samp_rate) | ||
self.qtgui_waterfall_sink_x_0.set_frequency_range(0, self.samp_rate) | ||
|
||
|
||
|
||
|
||
def main(top_block_cls=ax100Wav_parser, 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): | ||
tb.stop() | ||
tb.wait() | ||
|
||
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) | ||
|
||
qapp.exec_() | ||
|
||
if __name__ == '__main__': | ||
main() |
Oops, something went wrong.