From d1a386caa11e1fab84a01494295c2d3afd3d3531 Mon Sep 17 00:00:00 2001 From: WillB97 Date: Sat, 17 Aug 2024 20:36:18 +0100 Subject: [PATCH] Add minimum motor power limit To warn competitors that low values will not work with their physical robots --- simulator/modules/sbot_interface/devices/motor.py | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/simulator/modules/sbot_interface/devices/motor.py b/simulator/modules/sbot_interface/devices/motor.py index 924f63d..7f11d87 100644 --- a/simulator/modules/sbot_interface/devices/motor.py +++ b/simulator/modules/sbot_interface/devices/motor.py @@ -4,6 +4,7 @@ The motor will apply a small amount of variation to the power setting to simulate inaccuracies in the motor. """ +import logging from abc import ABC, abstractmethod from sbot_interface.devices.util import ( @@ -110,9 +111,15 @@ def set_power(self, value: int) -> None: :param value: The power setting for the motor. A value between -1000 and 1000. """ if value != 0: - # Apply a small amount of variation to the power setting to simulate - # inaccuracies in the motor - value = int(add_jitter(value, (MIN_POWER, MAX_POWER))) + if abs(value) < 0.05: + logging.warning( + "Motor power is too low, values below 0.05 will not move the motor." + ) + value = 0 + else: + # Apply a small amount of variation to the power setting to simulate + # inaccuracies in the motor + value = int(add_jitter(value, (MIN_POWER, MAX_POWER))) self._device.setVelocity(map_to_range( value,