scanna.py 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. #!/usr/bin/env python
  2. ##################################################
  3. # Gnuradio Python Flow Graph
  4. # Title: Scanna
  5. # Generated: Sat Nov 12 11:39:05 2016
  6. ##################################################
  7. from gnuradio import analog
  8. from gnuradio import audio
  9. from gnuradio import blocks
  10. from gnuradio import eng_notation
  11. from gnuradio import filter
  12. from gnuradio import gr
  13. from gnuradio import wxgui
  14. from gnuradio.eng_option import eng_option
  15. from gnuradio.fft import window
  16. from gnuradio.filter import firdes
  17. from gnuradio.wxgui import fftsink2
  18. from gnuradio.wxgui import forms
  19. from grc_gnuradio import wxgui as grc_wxgui
  20. from optparse import OptionParser
  21. import osmosdr
  22. import wx
  23. class scanna(grc_wxgui.top_block_gui):
  24. def __init__(self):
  25. grc_wxgui.top_block_gui.__init__(self, title="Scanna")
  26. _icon_path = "/usr/share/icons/hicolor/32x32/apps/gnuradio-grc.png"
  27. self.SetIcon(wx.Icon(_icon_path, wx.BITMAP_TYPE_ANY))
  28. ##################################################
  29. # Variables
  30. ##################################################
  31. self.volume = volume = 1
  32. self.variable_0 = variable_0 = 0
  33. self.transition = transition = 8000
  34. self.squelch_0 = squelch_0 = 0
  35. self.samp_rate = samp_rate = 2000000
  36. self.freq_1 = freq_1 = 446000000
  37. self.cutoff = cutoff = 100e3
  38. ##################################################
  39. # Blocks
  40. ##################################################
  41. self._squelch_0_text_box = forms.text_box(
  42. parent=self.GetWin(),
  43. value=self.squelch_0,
  44. callback=self.set_squelch_0,
  45. label="Squelch (db)",
  46. converter=forms.int_converter(),
  47. )
  48. self.Add(self._squelch_0_text_box)
  49. _freq_1_sizer = wx.BoxSizer(wx.VERTICAL)
  50. self._freq_1_text_box = forms.text_box(
  51. parent=self.GetWin(),
  52. sizer=_freq_1_sizer,
  53. value=self.freq_1,
  54. callback=self.set_freq_1,
  55. label="Frequency",
  56. converter=forms.float_converter(),
  57. proportion=0,
  58. )
  59. self._freq_1_slider = forms.slider(
  60. parent=self.GetWin(),
  61. sizer=_freq_1_sizer,
  62. value=self.freq_1,
  63. callback=self.set_freq_1,
  64. minimum=445800000,
  65. maximum=446100000,
  66. num_steps=200,
  67. style=wx.SL_HORIZONTAL,
  68. cast=float,
  69. proportion=1,
  70. )
  71. self.Add(_freq_1_sizer)
  72. self.wxgui_fftsink2_0 = fftsink2.fft_sink_c(
  73. self.GetWin(),
  74. baseband_freq=freq_1,
  75. y_per_div=10,
  76. y_divs=10,
  77. ref_level=0,
  78. ref_scale=2,
  79. sample_rate=samp_rate,
  80. fft_size=1024,
  81. fft_rate=15,
  82. average=False,
  83. avg_alpha=None,
  84. title="FFT Plot",
  85. peak_hold=False,
  86. )
  87. self.Add(self.wxgui_fftsink2_0.win)
  88. self.rtlsdr_source_0 = osmosdr.source( args="numchan=" + str(1) + " " + "" )
  89. self.rtlsdr_source_0.set_sample_rate(samp_rate)
  90. self.rtlsdr_source_0.set_center_freq(freq_1, 0)
  91. self.rtlsdr_source_0.set_freq_corr(0, 0)
  92. self.rtlsdr_source_0.set_dc_offset_mode(0, 0)
  93. self.rtlsdr_source_0.set_iq_balance_mode(0, 0)
  94. self.rtlsdr_source_0.set_gain_mode(True, 0)
  95. self.rtlsdr_source_0.set_gain(10, 0)
  96. self.rtlsdr_source_0.set_if_gain(20, 0)
  97. self.rtlsdr_source_0.set_bb_gain(20, 0)
  98. self.rtlsdr_source_0.set_antenna("", 0)
  99. self.rtlsdr_source_0.set_bandwidth(0, 0)
  100. self.rational_resampler_xxx_1 = filter.rational_resampler_fff(
  101. interpolation=24,
  102. decimation=100,
  103. taps=None,
  104. fractional_bw=None,
  105. )
  106. self.rational_resampler_xxx_0 = filter.rational_resampler_ccc(
  107. interpolation=500000,
  108. decimation=2000000,
  109. taps=None,
  110. fractional_bw=None,
  111. )
  112. self.low_pass_filter_0 = filter.fir_filter_ccf(1, firdes.low_pass(
  113. 1, 500000, 100000, transition, firdes.WIN_HAMMING, 6.76))
  114. self.blocks_wavfile_sink_0 = blocks.wavfile_sink("./output.wav", 1, 24000, 8)
  115. self.audio_sink_0 = audio.sink(24000, "", True)
  116. self.analog_pwr_squelch_xx_0 = analog.pwr_squelch_ff(squelch_0, 1, 1, True)
  117. self.analog_nbfm_rx_0 = analog.nbfm_rx(
  118. audio_rate=100000,
  119. quad_rate=500000,
  120. tau=75e-6,
  121. max_dev=5e3,
  122. )
  123. ##################################################
  124. # Connections
  125. ##################################################
  126. self.connect((self.analog_pwr_squelch_xx_0, 0), (self.blocks_wavfile_sink_0, 0))
  127. self.connect((self.rational_resampler_xxx_1, 0), (self.analog_pwr_squelch_xx_0, 0))
  128. self.connect((self.analog_nbfm_rx_0, 0), (self.rational_resampler_xxx_1, 0))
  129. self.connect((self.low_pass_filter_0, 0), (self.analog_nbfm_rx_0, 0))
  130. self.connect((self.rational_resampler_xxx_0, 0), (self.low_pass_filter_0, 0))
  131. self.connect((self.analog_pwr_squelch_xx_0, 0), (self.audio_sink_0, 0))
  132. self.connect((self.rtlsdr_source_0, 0), (self.wxgui_fftsink2_0, 0))
  133. self.connect((self.rtlsdr_source_0, 0), (self.rational_resampler_xxx_0, 0))
  134. def get_volume(self):
  135. return self.volume
  136. def set_volume(self, volume):
  137. self.volume = volume
  138. def get_variable_0(self):
  139. return self.variable_0
  140. def set_variable_0(self, variable_0):
  141. self.variable_0 = variable_0
  142. def get_transition(self):
  143. return self.transition
  144. def set_transition(self, transition):
  145. self.transition = transition
  146. self.low_pass_filter_0.set_taps(firdes.low_pass(1, 500000, 100000, self.transition, firdes.WIN_HAMMING, 6.76))
  147. def get_squelch_0(self):
  148. return self.squelch_0
  149. def set_squelch_0(self, squelch_0):
  150. self.squelch_0 = squelch_0
  151. self.analog_pwr_squelch_xx_0.set_threshold(self.squelch_0)
  152. self._squelch_0_text_box.set_value(self.squelch_0)
  153. def get_samp_rate(self):
  154. return self.samp_rate
  155. def set_samp_rate(self, samp_rate):
  156. self.samp_rate = samp_rate
  157. self.wxgui_fftsink2_0.set_sample_rate(self.samp_rate)
  158. self.rtlsdr_source_0.set_sample_rate(self.samp_rate)
  159. def get_freq_1(self):
  160. return self.freq_1
  161. def set_freq_1(self, freq_1):
  162. self.freq_1 = freq_1
  163. self._freq_1_slider.set_value(self.freq_1)
  164. self._freq_1_text_box.set_value(self.freq_1)
  165. self.wxgui_fftsink2_0.set_baseband_freq(self.freq_1)
  166. self.rtlsdr_source_0.set_center_freq(self.freq_1, 0)
  167. def get_cutoff(self):
  168. return self.cutoff
  169. def set_cutoff(self, cutoff):
  170. self.cutoff = cutoff
  171. if __name__ == '__main__':
  172. import ctypes
  173. import sys
  174. if sys.platform.startswith('linux'):
  175. try:
  176. x11 = ctypes.cdll.LoadLibrary('libX11.so')
  177. x11.XInitThreads()
  178. except:
  179. print "Warning: failed to XInitThreads()"
  180. parser = OptionParser(option_class=eng_option, usage="%prog: [options]")
  181. (options, args) = parser.parse_args()
  182. tb = scanna()
  183. tb.Start(True)
  184. tb.Wait()