1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
import gras
import numpy
import serial
import time
from sbhs import *
from scan_machines import *
class gr_sbhs(gras.Block):
def __init__(self):
gras.Block.__init__(self,
name="gr_sbhs",
in_sig=[numpy.float32, numpy.float32],
out_sig=[numpy.float32])
# SBHS init
self.new_device = Sbhs()
self.new_device.connect(1)
self.new_device.connect_device(0)
def set_parameters(self,window):
self.n = window
# Check if value of window is integral of length of input source vector
# For cases like -> input = [3 , 4, 5 ,6] & window = 3
def isIntegralWin(self, input_item, window):
if (len(input_item) % window ):
raise Exception("Value of Window should be an integral value of length of input items")
def work(self, input_items, output_items):
# Assuming input_items[0] and input_items[1] have same LENGTH
for heat_items, fan_items in zip(input_items[0], input_items[1]):
print "HEAT WRITTEN", heat_items
# Set heat as 0 for negative values of heat
if heat_items < 0:
self.new_device.setHeat(0)
else:
self.new_device.setHeat(heat_items)
time.sleep(0.5)
self.new_device.setFan(fan_items)
time.sleep(0.5)
# For Zero Temperatures
if not self.new_device.getTemp():
raise Exception("Check SBHS connection, try re-plugging it and run scan_machines.py")
# Get temperature
output_items[0][:1] = self.new_device.getTemp()
print "Temperature: ",output_items[0][:1]
#Write a for loop for n_inputs
for i in range(len(input_items)):
self.consume(i,1) # Consume from port 0 input_items
self.produce(0,self.n) # Produce from port 0 output_items
|