chickenhouse/source/gate/open.py

46 lines
1.1 KiB
Python
Raw Normal View History

2016-12-23 12:06:02 +00:00
'''
Created on Dec 23, 2016
@author: klaehn
'''
import sys
import time
2017-01-07 12:23:28 +00:00
from datetime import datetime as dt
2016-12-23 12:06:02 +00:00
from data_buffer import DataBuffer
from gate.gate_handler import GateHandler
from power_sensor import PowerSensor
POWER_SENSOR_I2C_BUS = 1
POWER_SENSOR_I2C_ADDRESS = 0x40
CONSECUTIVE_POWER_READS = 1000
MAX_ENGINE_POWER = {"up":330, "down":290}
def main(argv):
gate_handler = GateHandler()
power_sensor = PowerSensor(POWER_SENSOR_I2C_BUS, POWER_SENSOR_I2C_ADDRESS)
power_data = DataBuffer(CONSECUTIVE_POWER_READS)
gate_handler.open()
try:
while True:
rd = power_sensor.power_mw()
power_data.push(rd)
2016-12-23 12:06:02 +00:00
average = power_data.average()
print str(time.time()) + " " + str(rd)
2016-12-23 12:06:02 +00:00
if average != None:
if average > MAX_ENGINE_POWER["up"]:
gate_handler.stop()
# print "Gate successfully opened"
2016-12-23 12:06:02 +00:00
return 0
except KeyboardInterrupt:
2017-01-07 12:23:28 +00:00
gate_handler.stop()
2016-12-23 12:06:02 +00:00
print "Closing procedure interrupted."
return 1
if __name__ == "__main__":
sys.exit(main(sys.argv[1:]))