Skip to content

Commit

Permalink
Added a queue to the watchdog (#115)
Browse files Browse the repository at this point in the history
* Added a queue to the watchdog

Stores STEERING_INSTRUCTION_MAX_LEN last steering instructions, comparing them with the stepper steering and sending off an error if the minimum difference is too large

* Ensure no warnings when nothing has been reported

* 🚨Fix linting warning

standard import "collections.deque" should be placed before third party imports
  • Loading branch information
BruceMcRooster authored Nov 14, 2024
1 parent f9bdac1 commit 53707a3
Showing 1 changed file with 21 additions and 5 deletions.
26 changes: 21 additions & 5 deletions rb_ws/src/buggy/scripts/watchdog/watchdog.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,15 @@
#!/usr/bin/env python3

from collections import deque

import argparse

import rospy

from std_msgs.msg import Bool, Int8, Float64

STEERING_INSTRUCTION_MAX_LEN = 10

class Watchdog:

STEERING_DEVIANCE = 4 #deg
Expand All @@ -18,7 +22,8 @@ def __init__(self, self_name) -> None:
2 - ERROR
"""

self.commanded_steering = 0
self.steering_instructions = deque(maxlen=STEERING_INSTRUCTION_MAX_LEN)

self.inAutonSteer = False

rospy.Subscriber(
Expand All @@ -36,7 +41,7 @@ def __init__(self, self_name) -> None:

def set_input_steering(self, msg):
rospy.logdebug("Got input steering of: " + str(msg.data))
self.commanded_steering = msg.data
self.steering_instructions.append(msg.data)

def set_auton_steer(self, msg):
if (msg.data and not self.inAutonSteer):
Expand All @@ -49,16 +54,27 @@ def set_auton_steer(self, msg):
def check_stepper_steering(self, msg):
stepper_steer = msg.data
rospy.logdebug("Firmware's reported stepper degree: " + str(stepper_steer))
if (self.alarm < 2):
if self.alarm < 2:
self.alarm = 0
if abs(stepper_steer - self.commanded_steering) > Watchdog.STEERING_DEVIANCE:

steer_instruct_diff_min = 0
if len(self.steering_instructions) > 0:
# Finds the minimum difference between the stepper's reported angle and the last 10 steering instructions
steer_instruct_diff_min = min(
map(
lambda steer: abs(stepper_steer - steer),
self.steering_instructions
)
)

if steer_instruct_diff_min > Watchdog.STEERING_DEVIANCE:
if self.inAutonSteer:
self.alarm = 2 # ERROR
rospy.logerr("STEPPER DEVIANCE (DEGREES OFF): " + str(abs(stepper_steer - self.commanded_steering)))
else:
rospy.logdebug("(Non Auton) Stepper Deviance of: " + str(abs(stepper_steer - self.commanded_steering)))

elif abs(stepper_steer - self.commanded_steering) > Watchdog.STEERING_DEVIANCE//2:
elif steer_instruct_diff_min > Watchdog.STEERING_DEVIANCE // 2:
if self.inAutonSteer:
self.alarm = max(self.alarm, 1)
rospy.logwarn("STEPPER POSSIBILY DEVIATING (DEGREES OFF): " + str(abs(stepper_steer - self.commanded_steering)))
Expand Down

0 comments on commit 53707a3

Please sign in to comment.