From 7490fb69973099b12e61f616736d5d6a100409c4 Mon Sep 17 00:00:00 2001 From: Oryx Desktop Computer Date: Thu, 7 Nov 2024 20:46:47 -0600 Subject: [PATCH] Fixed previous issue that caused the preplanner origin to be separated from the robot position. Might be a good idea to test for more edge cases. --- drivetrain/controlStrategies/autoDrive.py | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) diff --git a/drivetrain/controlStrategies/autoDrive.py b/drivetrain/controlStrategies/autoDrive.py index c6dfaa0..8ab8c20 100644 --- a/drivetrain/controlStrategies/autoDrive.py +++ b/drivetrain/controlStrategies/autoDrive.py @@ -28,10 +28,10 @@ def __init__(self): self._olCmd = DrivetrainCommand() self._prevCmd:DrivetrainCommand|None = None self._plannerDur:float = 0.0 - self.autoPrevEnabled = False #This name might be a wee bit confusing. It just keeps track if we were in auto last refresh. + self.autoSpeakerPrevEnabled = False #This name might be a wee bit confusing. It just keeps track if we were in auto targeting the speaker last refresh. + self.autoPickupPrevEnabled = False #This name might be a wee bit confusing. It just keeps track if we were in auto targeting the speaker last refresh. self.stuckTracker = 0 self.prevPose = Pose2d() - addLog("AutoDrive Proc Time", lambda:(self._plannerDur * 1000.0), "ms") @@ -40,12 +40,10 @@ def setRequest(self, toSpeaker, toPickup) -> None: self._toSpeaker = toSpeaker self._toPickup = toPickup #The following if statement is just logic to enable self.autoPrevEnabled when the driver enables an auto. - if self._toSpeaker == True or self._toPickup == True: - if self.autoPrevEnabled == False: - self.stuckTracker = 0 - self.autoPrevEnabled = True - if self._toSpeaker == False and self._toPickup == False: - self.autoPrevEnabled = False + if self.autoSpeakerPrevEnabled != self._toSpeaker or self.autoPickupPrevEnabled != self._toPickup: + self.stuckTracker = 0 + self.autoPickupPrevEnabled = self._toPickup + self.autoSpeakerPrevEnabled = self._toSpeaker def updateTelemetry(self) -> None: