def __init__(self, dictionary):
		for (k, v) in dictionary.items():
			setattr(self, k, v)
				
		self.controller = PMDController(self.activeChannels, 
										self.gainSettings,
										self.sampleRatePerChannel,
										self.scanDuration,
										self.vRange,
										self.trigger,
										self.trigType, 
										self.boardNum)
class PMDMediator(DeviceMediatorInterface):
	"""
	Mediator for PMDController specific to the QDG Framework
	""" 
	
	def __init__(self, dictionary):
		for (k, v) in dictionary.items():
			setattr(self, k, v)
				
		self.controller = PMDController(self.activeChannels, 
										self.gainSettings,
										self.sampleRatePerChannel,
										self.scanDuration,
										self.vRange,
										self.trigger,
										self.trigType, 
										self.boardNum)

	def start(self):
		print "Starting PMD data collection thread."
		self.controller.start()
		
	def stop(self):
		print "Waiting for PMD to finish collecting data."
		status = self.controller.stop()
		print "PMD Done"
		return status
		
	def save(self, pth):
		fname = path.join(pth, 'PMDData.csv')
		self.controller.saveData(fname)

	def processExpData(self, pth):
		fname = path.join(pth, 'PMDDataPlot.png')
		self.controller.plotData(fname)
		
	def saveState(self, pth):
		pass
		
	def restoreState(self, pth):
		pass