From 53707a32f392d117d5abb7fa5ddedca00a6451b2 Mon Sep 17 00:00:00 2001 From: Evan Date: Thu, 14 Nov 2024 14:36:30 -0500 Subject: [PATCH] Added a queue to the watchdog (#115) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * 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 --- rb_ws/src/buggy/scripts/watchdog/watchdog.py | 26 ++++++++++++++++---- 1 file changed, 21 insertions(+), 5 deletions(-) diff --git a/rb_ws/src/buggy/scripts/watchdog/watchdog.py b/rb_ws/src/buggy/scripts/watchdog/watchdog.py index 3375861..0012954 100755 --- a/rb_ws/src/buggy/scripts/watchdog/watchdog.py +++ b/rb_ws/src/buggy/scripts/watchdog/watchdog.py @@ -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 @@ -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( @@ -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): @@ -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)))