pid_vco.py 13.5 KB
#!/usr/bin/env python2
# -*- coding: utf-8 -*-
##################################################
# GNU Radio Python Flow Graph
# Title: Pid Vco
# Generated: Fri May  5 11:24:00 2017
##################################################

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 PyQt4 import Qt
from gnuradio import eng_notation
from gnuradio import gr
from gnuradio.eng_option import eng_option
from gnuradio.filter import firdes
from gnuradio.qtgui import Range, RangeWidget
from optparse import OptionParser
import redpitaya_gnuradio
import sys


class pid_vco(gr.top_block, Qt.QWidget):

	def __init__(self):
		gr.top_block.__init__(self, "Pid Vco")
		Qt.QWidget.__init__(self)
		self.setWindowTitle("Pid Vco")
		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", "pid_vco")
		self.restoreGeometry(self.settings.value("geometry").toByteArray())

		##################################################
		# Variables
		##################################################
		self.port = port = 1001
		self.pid_sign = pid_sign = 0
		self.pid_setpoint = pid_setpoint = 0
		self.pid_rst_int = pid_rst_int = 0
		self.pid_kp = pid_kp = 0
		self.pid_ki = pid_ki = 0
		self.pid_kd = pid_kd = 0
		self.dds_range = dds_range = 0
		self.dds_poff_sw = dds_poff_sw = 1
		self.dds_pinc_sw = dds_pinc_sw = 1
		self.dds_offset = dds_offset = 0
		self.dds_nco = dds_nco = 0
		self.dds_f0 = dds_f0 = 0
		self.dds_ampl = dds_ampl = 0
		self.dac1_offset = dac1_offset = 0
		self.addr = addr = "192.168.0.201"
		self.adc1_offset = adc1_offset = 0

		##################################################
		# Blocks
		##################################################
		_pid_sign_check_box = Qt.QCheckBox('pid_sign')
		self._pid_sign_choices = {True: 1, False: 0}
		self._pid_sign_choices_inv = dict((v,k) for k,v in self._pid_sign_choices.iteritems())
		self._pid_sign_callback = lambda i: Qt.QMetaObject.invokeMethod(_pid_sign_check_box, "setChecked", Qt.Q_ARG("bool", self._pid_sign_choices_inv[i]))
		self._pid_sign_callback(self.pid_sign)
		_pid_sign_check_box.stateChanged.connect(lambda i: self.set_pid_sign(self._pid_sign_choices[bool(i)]))
		self.top_grid_layout.addWidget(_pid_sign_check_box, 3, 2)
		self._pid_setpoint_range = Range(-2**13, 2**13-1, 1, 0, 200)
		self._pid_setpoint_win = RangeWidget(self._pid_setpoint_range, self.set_pid_setpoint, 'pid_setpoint', "counter_slider", int)
		self.top_grid_layout.addWidget(self._pid_setpoint_win, 2, 2)
		_pid_rst_int_push_button = Qt.QPushButton('pid_rst_int')
		self._pid_rst_int_choices = {'Pressed': 1, 'Released': 0}
		_pid_rst_int_push_button.pressed.connect(lambda: self.set_pid_rst_int(self._pid_rst_int_choices['Pressed']))
		_pid_rst_int_push_button.released.connect(lambda: self.set_pid_rst_int(self._pid_rst_int_choices['Released']))
		self.top_grid_layout.addWidget(_pid_rst_int_push_button, 4, 2)
		self._pid_kp_range = Range(0, 2**13-1, 1, 0, 200)
		self._pid_kp_win = RangeWidget(self._pid_kp_range, self.set_pid_kp, 'pid_kp', "counter_slider", int)
		self.top_grid_layout.addWidget(self._pid_kp_win, 2, 1)
		self._pid_ki_range = Range(0, 2**13-1, 1, 0, 200)
		self._pid_ki_win = RangeWidget(self._pid_ki_range, self.set_pid_ki, 'pid_ki', "counter_slider", int)
		self.top_grid_layout.addWidget(self._pid_ki_win, 3, 1)
		self._pid_kd_range = Range(0, 2**13-1, 1, 0, 200)
		self._pid_kd_win = RangeWidget(self._pid_kd_range, self.set_pid_kd, 'pid_kd', "counter_slider", int)
		self.top_grid_layout.addWidget(self._pid_kd_win, 4, 1)
		self._dds_range_range = Range(-2**13, 2**13-1, 1, 0, 200)
		self._dds_range_win = RangeWidget(self._dds_range_range, self.set_dds_range, 'dds_range', "counter_slider", int)
		self.top_grid_layout.addWidget(self._dds_range_win, 5, 3)
		_dds_poff_sw_check_box = Qt.QCheckBox('dds_poff_sw')
		self._dds_poff_sw_choices = {True: 1, False: 0}
		self._dds_poff_sw_choices_inv = dict((v,k) for k,v in self._dds_poff_sw_choices.iteritems())
		self._dds_poff_sw_callback = lambda i: Qt.QMetaObject.invokeMethod(_dds_poff_sw_check_box, "setChecked", Qt.Q_ARG("bool", self._dds_poff_sw_choices_inv[i]))
		self._dds_poff_sw_callback(self.dds_poff_sw)
		_dds_poff_sw_check_box.stateChanged.connect(lambda i: self.set_dds_poff_sw(self._dds_poff_sw_choices[bool(i)]))
		self.top_grid_layout.addWidget(_dds_poff_sw_check_box, 2, 4)
		_dds_pinc_sw_check_box = Qt.QCheckBox('dds_pinc_sw')
		self._dds_pinc_sw_choices = {True: 1, False: 0}
		self._dds_pinc_sw_choices_inv = dict((v,k) for k,v in self._dds_pinc_sw_choices.iteritems())
		self._dds_pinc_sw_callback = lambda i: Qt.QMetaObject.invokeMethod(_dds_pinc_sw_check_box, "setChecked", Qt.Q_ARG("bool", self._dds_pinc_sw_choices_inv[i]))
		self._dds_pinc_sw_callback(self.dds_pinc_sw)
		_dds_pinc_sw_check_box.stateChanged.connect(lambda i: self.set_dds_pinc_sw(self._dds_pinc_sw_choices[bool(i)]))
		self.top_grid_layout.addWidget(_dds_pinc_sw_check_box, 1, 4)
		self._dds_offset_range = Range(-2**13, 2**13-1, 1, 0, 200)
		self._dds_offset_win = RangeWidget(self._dds_offset_range, self.set_dds_offset, 'dds_offset', "counter_slider", int)
		self.top_grid_layout.addWidget(self._dds_offset_win, 3, 3)
		self._dds_nco_range = Range(0, 60000000, 1, 0, 200)
		self._dds_nco_win = RangeWidget(self._dds_nco_range, self.set_dds_nco, 'dds_nco', "counter_slider", int)
		self.top_grid_layout.addWidget(self._dds_nco_win, 2, 3)
		self._dds_f0_range = Range(0, 60000000, 1, 0, 200)
		self._dds_f0_win = RangeWidget(self._dds_f0_range, self.set_dds_f0, 'dds_f0', "counter_slider", int)
		self.top_grid_layout.addWidget(self._dds_f0_win, 4, 3)
		self._dds_ampl_range = Range(0, 2**13-1, 1, 0, 200)
		self._dds_ampl_win = RangeWidget(self._dds_ampl_range, self.set_dds_ampl, 'dds_ampl', "counter_slider", int)
		self.top_grid_layout.addWidget(self._dds_ampl_win, 1, 3)
		self._dac1_offset_range = Range(-2**13, 2**13-1, 1, 0, 200)
		self._dac1_offset_win = RangeWidget(self._dac1_offset_range, self.set_dac1_offset, 'dac1_offset', "counter_slider", int)
		self.top_grid_layout.addWidget(self._dac1_offset_win, 1, 2)
		self._adc1_offset_range = Range(-2**13, 2**13-1, 1, 0, 200)
		self._adc1_offset_win = RangeWidget(self._adc1_offset_range, self.set_adc1_offset, 'adc1_offset', "counter_slider", int)
		self.top_grid_layout.addWidget(self._adc1_offset_win, 1, 1)
		self.nco_counter_send_conf_0 = redpitaya_gnuradio.nco_counter_send_conf(
				addr=addr,
				port=port,
				device='/dev/dds_nco',
				freq_ref=125000000,
				freq_dds=dds_nco,
				acc_size=32,
				offset=0,
				pinc_sw=dds_pinc_sw,
				poff_sw=dds_poff_sw,
		)
		  
		self.add_const_set_offset_0_0_0_1_0_0_0_0_0 = redpitaya_gnuradio.add_const_set_offset(
				addr=addr,
				port=port,
				device='/dev/pid_rst_int',
				const=pid_rst_int,
		)
		  
		self.add_const_set_offset_0_0_0_1_0_0_0_0 = redpitaya_gnuradio.add_const_set_offset(
				addr=addr,
				port=port,
				device='/dev/pid_sign',
				const=pid_sign,
		)
		  
		self.add_const_set_offset_0_0_0_1_0_0_0 = redpitaya_gnuradio.add_const_set_offset(
				addr=addr,
				port=port,
				device='/dev/pid_kd',
				const=pid_kd,
		)
		  
		self.add_const_set_offset_0_0_0_1_0_0 = redpitaya_gnuradio.add_const_set_offset(
				addr=addr,
				port=port,
				device='/dev/pid_ki',
				const=pid_ki,
		)
		  
		self.add_const_set_offset_0_0_0_1_0 = redpitaya_gnuradio.add_const_set_offset(
				addr=addr,
				port=port,
				device='/dev/pid_kp',
				const=pid_kp,
		)
		  
		self.add_const_set_offset_0_0_0_1 = redpitaya_gnuradio.add_const_set_offset(
				addr=addr,
				port=port,
				device='/dev/pid_setpoint',
				const=pid_setpoint,
		)
		  
		self.add_const_set_offset_0_0_0_0_1_0_0 = redpitaya_gnuradio.add_const_set_offset(
				addr=addr,
				port=port,
				device='/dev/dds_range',
				const=dds_range,
		)
		  
		self.add_const_set_offset_0_0_0_0_1_0 = redpitaya_gnuradio.add_const_set_offset(
				addr=addr,
				port=port,
				device='/dev/dds_f0',
				const=int(dds_f0/(125e6/2**32)),
		)
		  
		self.add_const_set_offset_0_0_0_0_1 = redpitaya_gnuradio.add_const_set_offset(
				addr=addr,
				port=port,
				device='/dev/dds_offset',
				const=dds_offset,
		)
		  
		self.add_const_set_offset_0_0_0_0_0 = redpitaya_gnuradio.add_const_set_offset(
				addr=addr,
				port=port,
				device='/dev/dds_ampl',
				const=dds_ampl,
		)
		  
		self.add_const_set_offset_0_0_0_0 = redpitaya_gnuradio.add_const_set_offset(
				addr=addr,
				port=port,
				device='/dev/dac1_offset',
				const=dac1_offset,
		)
		  
		self.add_const_set_offset_0_0_0 = redpitaya_gnuradio.add_const_set_offset(
				addr=addr,
				port=port,
				device='/dev/adc1_offset',
				const=adc1_offset,
		)
		  

	def closeEvent(self, event):
		self.settings = Qt.QSettings("GNU Radio", "pid_vco")
		self.settings.setValue("geometry", self.saveGeometry())
		event.accept()

	def get_port(self):
		return self.port

	def set_port(self, port):
		self.port = port

	def get_pid_sign(self):
		return self.pid_sign

	def set_pid_sign(self, pid_sign):
		self.pid_sign = pid_sign
		self._pid_sign_callback(self.pid_sign)
		self.add_const_set_offset_0_0_0_1_0_0_0_0.set_const(device='/dev/pid_sign', const=self.pid_sign)

	def get_pid_setpoint(self):
		return self.pid_setpoint

	def set_pid_setpoint(self, pid_setpoint):
		self.pid_setpoint = pid_setpoint
		self.add_const_set_offset_0_0_0_1.set_const(device='/dev/pid_setpoint', const=self.pid_setpoint)

	def get_pid_rst_int(self):
		return self.pid_rst_int

	def set_pid_rst_int(self, pid_rst_int):
		self.pid_rst_int = pid_rst_int
		self.add_const_set_offset_0_0_0_1_0_0_0_0_0.set_const(device='/dev/pid_rst_int', const=self.pid_rst_int)

	def get_pid_kp(self):
		return self.pid_kp

	def set_pid_kp(self, pid_kp):
		self.pid_kp = pid_kp
		self.add_const_set_offset_0_0_0_1_0.set_const(device='/dev/pid_kp', const=self.pid_kp)

	def get_pid_ki(self):
		return self.pid_ki

	def set_pid_ki(self, pid_ki):
		self.pid_ki = pid_ki
		self.add_const_set_offset_0_0_0_1_0_0.set_const(device='/dev/pid_ki', const=self.pid_ki)

	def get_pid_kd(self):
		return self.pid_kd

	def set_pid_kd(self, pid_kd):
		self.pid_kd = pid_kd
		self.add_const_set_offset_0_0_0_1_0_0_0.set_const(device='/dev/pid_kd', const=self.pid_kd)

	def get_dds_range(self):
		return self.dds_range

	def set_dds_range(self, dds_range):
		self.dds_range = dds_range
		self.add_const_set_offset_0_0_0_0_1_0_0.set_const(device='/dev/dds_range', const=self.dds_range)

	def get_dds_poff_sw(self):
		return self.dds_poff_sw

	def set_dds_poff_sw(self, dds_poff_sw):
		self.dds_poff_sw = dds_poff_sw
		self._dds_poff_sw_callback(self.dds_poff_sw)
		self.nco_counter_send_conf_0.set_nco(device='/dev/dds_nco', freq_ref=125000000, freq_dds=self.dds_nco, acc_size=32, offset=0, pinc_sw=self.dds_pinc_sw, poff_sw=self.dds_poff_sw)

	def get_dds_pinc_sw(self):
		return self.dds_pinc_sw

	def set_dds_pinc_sw(self, dds_pinc_sw):
		self.dds_pinc_sw = dds_pinc_sw
		self._dds_pinc_sw_callback(self.dds_pinc_sw)
		self.nco_counter_send_conf_0.set_nco(device='/dev/dds_nco', freq_ref=125000000, freq_dds=self.dds_nco, acc_size=32, offset=0, pinc_sw=self.dds_pinc_sw, poff_sw=self.dds_poff_sw)

	def get_dds_offset(self):
		return self.dds_offset

	def set_dds_offset(self, dds_offset):
		self.dds_offset = dds_offset
		self.add_const_set_offset_0_0_0_0_1.set_const(device='/dev/dds_offset', const=self.dds_offset)

	def get_dds_nco(self):
		return self.dds_nco

	def set_dds_nco(self, dds_nco):
		self.dds_nco = dds_nco
		self.nco_counter_send_conf_0.set_nco(device='/dev/dds_nco', freq_ref=125000000, freq_dds=self.dds_nco, acc_size=32, offset=0, pinc_sw=self.dds_pinc_sw, poff_sw=self.dds_poff_sw)

	def get_dds_f0(self):
		return self.dds_f0

	def set_dds_f0(self, dds_f0):
		self.dds_f0 = dds_f0
		self.add_const_set_offset_0_0_0_0_1_0.set_const(device='/dev/dds_f0', const=int(self.dds_f0/(125e6/2**32)))

	def get_dds_ampl(self):
		return self.dds_ampl

	def set_dds_ampl(self, dds_ampl):
		self.dds_ampl = dds_ampl
		self.add_const_set_offset_0_0_0_0_0.set_const(device='/dev/dds_ampl', const=self.dds_ampl)

	def get_dac1_offset(self):
		return self.dac1_offset

	def set_dac1_offset(self, dac1_offset):
		self.dac1_offset = dac1_offset
		self.add_const_set_offset_0_0_0_0.set_const(device='/dev/dac1_offset', const=self.dac1_offset)

	def get_addr(self):
		return self.addr

	def set_addr(self, addr):
		self.addr = addr

	def get_adc1_offset(self):
		return self.adc1_offset

	def set_adc1_offset(self, adc1_offset):
		self.adc1_offset = adc1_offset
		self.add_const_set_offset_0_0_0.set_const(device='/dev/adc1_offset', const=self.adc1_offset)


def main(top_block_cls=pid_vco, options=None):

	from distutils.version import StrictVersion
	if StrictVersion(Qt.qVersion()) >= StrictVersion("4.5.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 quitting():
		tb.stop()
		tb.wait()
	qapp.connect(qapp, Qt.SIGNAL("aboutToQuit()"), quitting)
	qapp.exec_()


if __name__ == '__main__':
	main()