You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
- `lerobot` version: 0.1.0
- Platform: Linux-5.15.0-122-generic-x86_64-with-glibc2.35
- Python version: 3.10.12
- Huggingface_hub version: 0.27.0
- Dataset version: 3.2.0
- Numpy version: 2.0.2
- PyTorch version (GPU?): 2.5.1+cu124 (False)
- Cuda version: 12040
I'm using a SO-100 arm that is almost 100% stock, with the exception that they sent me 12v motors which works just fine for me (or should).
Information
One of the scripts in the examples/ folder of LeRobot
My own task or dataset (give details below)
Reproduction
~/lerobot$ python3.10 lerobot/scripts/control_robot.py teleoperate --robot-path lerobot/configs/robot/so100.yaml
Connecting main follower arm.
Connecting main leader arm.
Activating torque on main follower arm.
/home/mbauer/lerobot/lerobot/common/robot_devices/motors/feetech.py:471: RuntimeWarning: divide by zero encountered in scalar divide
values[i] = (values[i] - start_pos) / (end_pos - start_pos) * 100
Wrong motor position range detected for gripper. Expected to be in nominal range of [0, 100] % (a full linear translation), with a maximum range of [-10, 110] % to account for some imprecision during calibration, but present value is inf %. This might be due to a cable connection issue creating an artificial jump in motor values. You need to recalibrate by running: `python lerobot/scripts/control_robot.py calibrate`
/home/mbauer/lerobot/lerobot/common/robot_devices/motors/feetech.py:543: RuntimeWarning: divide by zero encountered in scalar divide
calib_val = (values[i] - start_pos) / (end_pos - start_pos) * 100
Traceback (most recent call last):
File "/home/mbauer/lerobot/lerobot/common/robot_devices/motors/feetech.py", line 404, in apply_calibration_autocorrect
values = self.apply_calibration(values, motor_names)
File "/home/mbauer/lerobot/lerobot/common/robot_devices/motors/feetech.py", line 474, in apply_calibration
raise JointOutOfRangeError(
lerobot.common.robot_devices.motors.feetech.JointOutOfRangeError: Wrong motor position range detected for gripper. Expected to be in nominal range of [0, 100] % (a full linear translation), with a maximum range of [-10, 110] % to account for some imprecision during calibration, but present value is inf %. This might be due to a cable connection issue creating an artificial jump in motor values. You need to recalibrate by running: `python lerobot/scripts/control_robot.py calibrate`
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "/home/mbauer/lerobot/lerobot/scripts/control_robot.py", line 564, in <module>
teleoperate(robot, **kwargs)
File "/home/mbauer/lerobot/lerobot/common/robot_devices/utils.py", line 28, in wrapper
raise e
File "/home/mbauer/lerobot/lerobot/common/robot_devices/utils.py", line 24, in wrapper
return func(robot, *args, **kwargs)
File "/home/mbauer/lerobot/lerobot/scripts/control_robot.py", line 177, in teleoperate
control_loop(
File "/home/mbauer/lerobot/lerobot/common/datasets/image_writer.py", line 36, in wrapper
raise e
File "/home/mbauer/lerobot/lerobot/common/datasets/image_writer.py", line 29, in wrapper
return func(*args, **kwargs)
File "/home/mbauer/lerobot/lerobot/common/robot_devices/control_utils.py", line 242, in control_loop
robot.connect()
File "/home/mbauer/lerobot/lerobot/common/robot_devices/robots/manipulator.py", line 343, in connect
self.follower_arms[name].read("Present_Position")
File "/home/mbauer/lerobot/lerobot/common/robot_devices/motors/feetech.py", line 760, in read
values = self.apply_calibration_autocorrect(values, motor_names)
File "/home/mbauer/lerobot/lerobot/common/robot_devices/motors/feetech.py", line 407, in apply_calibration_autocorrect
self.autocorrect_calibration(values, motor_names)
File "/home/mbauer/lerobot/lerobot/common/robot_devices/motors/feetech.py", line 565, in autocorrect_calibration
raise ValueError(f"No integer found between bounds [{low_factor=}, {upp_factor=}]")
ValueError: No integer found between bounds [low_factor=np.float32(-0.0007324219), upp_factor=np.float32(-0.0007324219)]
It looks like all the calibration data is generated without issue.
I have the same setup as you do and was running into a similar issue with JointOutOfRangeError despite calibration. Turns out I had my motor IDs reversed when I was configuring the motors. A simple change in the lerobot/configs/robot/so100.yaml fixed it. My so100.yaml looks so this now
For me though the the error explicitly mentioned the "present position" to be -10.1667, which was a hint to it being out of range when it should not, unlike your infinity. So the error you are seeing might be because of something else, if not the motor IDs
System Info
Information
Reproduction
It looks like all the calibration data is generated without issue.
This also occurs when attempting to execute teleoperate or any other control mode.
Expected behavior
Execution without error.
If this is a 'me' issue, then apologies in advanced for not just throwing this on discord, but any help or guidance is appreciated.
The text was updated successfully, but these errors were encountered: