-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDeviationCheckerThread.py
More file actions
120 lines (101 loc) · 4.89 KB
/
DeviationCheckerThread.py
File metadata and controls
120 lines (101 loc) · 4.89 KB
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
# -*-coding:utf8;-*-
# qpy:2
# ts=4:sw=4:expandtab
'''
Created on 01.07.2014
@author: rkoraschnigg
'''
from kivy.clock import Clock
from ThreadBase import StoppableThread
from Logger import Logger
class DeviationCheckerThread(StoppableThread, Logger):
def __init__(self, main_app, resume, cv_average_angle, cv_interrupt, average_angle_queue,
interruptqueue, av_bearing_value, cond, cond_ar, log_viewer):
StoppableThread.__init__(self)
Logger.__init__(self, self.__class__.__name__, log_viewer)
self.main_app = main_app
self.resume = resume
self.cv_average_angle = cv_average_angle
self.cv_interrupt = cv_interrupt
self.average_angle_queue = average_angle_queue
self.interruptqueue = interruptqueue
self.av_bearing_value = av_bearing_value
self.cond = cond
self.cond_ar = cond_ar
self.av_bearing = float(0.0)
self.av_bearing_current = 0
self.av_bearing_prev = 0
self.first_bearing_set_available = False
def run(self):
while not self.cond.terminate and not self.cond_ar.terminate:
if self.main_app.run_in_back_ground:
self.main_app.main_event.wait()
self.process()
self.average_angle_queue.clear_average_angle_data(self.cv_average_angle)
# Do not trigger termination of the calculator and speed camera warner thread in case it is
# AR related
if self.cond.terminate:
self.interruptqueue.produce(self.cv_interrupt, 'TERMINATE')
if self.cond_ar.terminate:
self.interruptqueue.clear_interruptqueue(self.cv_interrupt)
self.print_log_line(f"{self.__class__.__name__} terminating")
self.stop()
def cleanup(self):
self.first_bearing_set_available = False
self.average_angle_queue.clear_average_angle_data(self.cv_average_angle)
def process(self):
current_bearing_queue = self.average_angle_queue.get_average_angle_data(
self.cv_average_angle)
self.cv_average_angle.release()
self.calculate_average_bearing(current_bearing_queue)
def calculate_average_bearing(self, current_bearing_queue):
self.av_bearing = float(0.0)
if current_bearing_queue == 0.001:
if self.resume.isResumed():
self.update_average_bearing('---.-')
return
elif current_bearing_queue == 0.002:
self.print_log_line(' Deviation Checker Thread got a termination item')
return
elif current_bearing_queue == 0.0:
if self.resume.isResumed():
self.update_average_bearing('0')
return
elif current_bearing_queue == 'TERMINATE':
return
for entry in current_bearing_queue:
self.av_bearing += entry
if len(current_bearing_queue) > 0:
av_bearing_final = self.av_bearing / len(current_bearing_queue)
if self.resume.isResumed():
self.update_average_bearing(round(av_bearing_final, 1))
av_first_entry = current_bearing_queue[0]
first_av_entry_current = av_first_entry
if not self.first_bearing_set_available:
self.first_bearing_set_available = True
self.av_bearing_current = av_bearing_final
else:
self.av_bearing_prev = self.av_bearing_current
self.av_bearing_current = av_bearing_final
'''
Check first if we are inside a tolerance limit in degrees between
2 position pair lists consisting of 5 positions each.
If the difference between bearing of first position and average bearing
is less or equal than 13 degrees, ccp is considered stable.
'''
av_bearing_diff_position_pair_queues = self.av_bearing_current - self.av_bearing_prev
av_bearing_diff_current_queue = first_av_entry_current - self.av_bearing_current
if (-22 <= av_bearing_diff_position_pair_queues <= 22) \
and (-13 <= av_bearing_diff_current_queue <= 13):
self.interruptqueue.produce(self.cv_interrupt, 'STABLE')
self.print_log_line(' CCP is considered STABLE')
else:
self.interruptqueue.produce(self.cv_interrupt, 'UNSTABLE')
self.print_log_line(' Waiting for CCP to become STABLE again')
return
def update_average_bearing(self, av_bearing=None):
if av_bearing is not None:
if not isinstance(av_bearing, str):
av_bearing = str(av_bearing)
self.av_bearing_value.text = av_bearing + '°'
Clock.schedule_once(self.av_bearing_value.texture_update)