-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain.py
77 lines (70 loc) · 2.57 KB
/
main.py
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
CAMERA_ENABLED=False
import time
from controller.redis_controller import *
from actuator.PCA9685 import *
from actuator.hbridge_gpio import HBridgeGpio
if CAMERA_ENABLED:
from vision.unet import UNetWrapper, convert_keras_to_tf_lite
from sensor.picam import default_camera_sensor, PiCamSensor
import cv2
from planning.fishbrain import create_action
from redis_io import get_redis_instance, store_np_image
import asyncio
import numpy as np
def bgr_to_rgb(img):
return img[:, :, ::-1]
def overlay_image(img, mask):
img_overlay = img
img_overlay[:,:,1] = img[:,:,1]/2 + np.maximum(img[:,:,1], 255*mask)/2
return img_overlay
def main():
redis_inst = get_redis_instance()
controller = default_redis_controller(redis_inst)
if CAMERA_ENABLED:
unet = UNetWrapper(init_model=False)
#convert_keras_to_tf_lite('/home/pi/keras-model', '/home/pi/trained_model_pi_converted.tflite')
#unet.generate_model("/home/pi/tf14-best.h5")
#unet.load_tf_lite_model("/home/pi/mobile_net.tflite")
#unet.load_tf_lite_model("/home/pi/trained_model_10_09.tflite")
unet.load_tf_lite_model("/home/pi/trained_model_10_11.tflite")
# unet.save_keras_model()
picam = default_camera_sensor()
# Only run actuator if present
try:
actuator = HBridgeGpio()
except OSError as e:
actuator = None
# TODO: Make this asynchronous
i=0
img=None
img_small=None
mask=None
directon = DiscreteControls.STOP
while True:
start_time = time.time()
if CAMERA_ENABLED:
img = picam.sense()
img_small = cv2.resize(img, (128, 128))
print("time taken for picam.sense", time.time() - start_time)
mask = unet.predict(img_small)
print("time taken for mask", time.time() - start_time)
img_overlay = overlay_image(img_small, mask)
store_np_image(img_overlay, "img")
print("time taken to store image", time.time() - start_time)
if mask is not None:
direction = create_action(mask)
try:
controller_direction = controller.run()
# For always control:
if True:
direction = controller_direction
#if controller_direction == DiscreteControls.STOP:
# direction = controller_direction
if actuator:
actuator.run(direction)
except KeyError as e:
print(e)
print(direction)
print("Total time:", time.time() - start_time)
i+=1
main()