Skip to main content

Real robot interface and utilities for asynchronous real-time deployment.

Project description

RealRobot

Real robot interface and utilities for asynchronous real-time deployment.
Previously developed to connect with ManiSkill2.

Runs camera capturing and visualization as separate processes to make it closer to using ROS.

Installation

From PyPI

python3 -m pip install -U real_robot

For different functionalities, you can install the optional dependencies as follows:

  • real_robot: SharedObject support only, please only use submodule real_robot.utils.multiprocessing.
  • real_robot[vis]: support for most visualization, use submodule real_robot.utils.visualization.
  • real_robot[vis_all]: include support for URDF.
  • real_robot[all]: all optional dependencies (e.g., pyrealsense2, sapien, etc.).

If you need to install the optional xarm dependency, you must install from GitHub repo

python3 -m pip install -U real_robot[all,xarm]@git+https://github.com/KolinGuo/RealRobot.git

Run unittests with

python3 -m pip install -U pytest
python3 -m pytest [--collect-only]

Calibrated camera poses are stored in real_robot/assets/hec_camera_poses/ and loaded in real_robot/sensors/camera.py.

SharedObject Notes

  • When using real_robot.utils.multiprocessing.SharedObject, you might encounter the following UserWarning when Ctrl-C your program:

    /usr/lib/python3.12/multiprocessing/resource_tracker.py:254: UserWarning: resource_tracker: There appear to be 10 leaked shared_memory objects to clean up at shutdown
      warnings.warn('resource_tracker: There appear to be %d '
    

    This is because of the undefined order of processes (main and child processes) shutdown. You can safely ignore it as long as there's no any shared memory object that's created by you under /dev/shm left.

  • If you see warning log messages similar to the following

    Implicitly overwriting data of <SharedObject: name=start_rs_front_camera, data_type=<class 'bool'>, nbytes=10>
    

    this can mean one of the following:

    • the shared_memory objects created by previous processes are not properly cleaned up.
      Run
      find /dev/shm -user $USER -exec rm -v {} \;
      
      to clean them all up.
    • there's a bug in your usage of SharedObject.
      By design, SharedObject cannot mutate its data type (and data size) after created.
      So you should first create a new SharedObject in process A with SharedObject("test", data=np.ones(10)) to initialize it.
      Then in process B, you can create it with SharedObject("test") and then use the .fetch()/.assign() methods.
      The warning will appear if the order is reversed.
      To control the order, you can use the helper methods start_and_wait_for_process() and signal_process_ready() under real_robot.utils.multiprocessing to synchronize the processes.

Helpful Tools

  • Capture Color/Depth/IR images from RS camera, do
    python3 -m real_robot.tools.rs_capture
    
  • Get detailed device information of connected RealSense device (e.g., supported stream configs, sensor intrinsics, extrinsics between sensors), do
    python3 -m real_robot.tools.enumerate_rs_devices > info.log
    
  • Convert recorded ROS bag file and save rgb & depth images into .npz, do
    python3 -m real_robot.tools.convert_rosbag_to_frames <bag_path>
    

TODO

  • Add type support for SharedObject
    • complex
    • bytearray
    • tuple
    • list
    • set
    • dict
      • [Preliminary] Support only 1 np.ndarray as values
  • Add string length? A 8-bytes length of strings is 2**(8*8-1)-1 = 8 exa bytes, which should be enough.
  • Ensure compound data types works with recursive compound structure
  • Add prefixes for all SharedMemory created.
  • Proper clean up zombie SharedMemory before or after multiprocessing code

Notes

To fix an unindexed rosbag recorded from RSDevice, do

apt install -y python3-rosbag
rosbag reindex <bag_path>

Known Issue

  • When controlling xArm7 with motion_mode="cartesian_online" and wait=True, sometimes the robot will be stuck indefinitely in wait_move() due to get_state() returns wrong state (i.e., returns state=1 thinking it's still in motion). Simple solution can be just to control briefly via UFACTORY Studio to get it unstuck.

Changelog

0.1.0

New features

  • Added SharedObject to create/mount objects stored in SharedMemory
  • Enabled RSDevice to run as a separate process (now Camera will create RSDevice as a separate process)
  • Enabled RSDevice to record camera streams as a rosbag file
  • Enabled XArm7 to run as a separate process (for streaming robot states)
  • Enabled CV2Visualizer and O3DGUIVisualizer to run as separate processes (for visualization)
  • Added a default FileHandler to all Logger created through real_robot.utils.logger.get_logger
  • Allow enabling selected camera streams from RSDevice and sensors.camera.Camera
  • Added sensors.simsense_depth.SimsenseDepth class to generate depth image from stereo IR images

API changes

  • real_robot.agents.xarm
    • Change XArm7 parameters for clarity (safety_boundary => safety_boundary_mm, boundary_clip_eps => boundary_clip_mm)
    • Add get_gripper_position() to get gripper opening width in mm or m
    • Add gripper_speed parameter to set_action() to control gripper speed
  • real_robot.utils.visualization.visualizer
    • Rename Visualizer method show_observation() => show_obs()
  • real_robot.sensors.camera
    • CameraConfig now accepts a config parameter
    • Rename CameraConfig parameter parent_pose_fn => parent_pose_so_name
  • real_robot.utils.realsense
    • RSDevice now accepts device_sn instead of an rs.device
    • RSDevice now accepts config as parameter (width, height, fps) instead of rs.config

Other changes

  • Switch from gym to gymnasium
  • Rename all control_mode by removing pd_ prefix for clarity. No PD controller is used.
  • real_robot.agents.xarm
    • XArm7 will not clear "Safety Boundary Limit" error automatically in set_action()
    • For motion_mode == "position", switch from using set_tool_position() to set_position()
    • Enable gripper and set to maximum speed in reset()
  • Remove all Loggers created as global variables (they will be created at import, which might not be saved under REAL_ROBOT_LOG_DIR)
  • Bugfix in xArm-Python-SDK: enable wait=True for modes other than position mode

0.0.2

  • Added motion_mode to XArm7 agent
  • Added several control_mode: pd_ee_pos, pd_ee_pose_axangle, pd_ee_delta_pose_axangle, pd_ee_pose_quat, pd_ee_delta_pose_quat

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

real_robot-0.2.1.tar.gz (19.6 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

real_robot-0.2.1-py3-none-any.whl (19.6 MB view details)

Uploaded Python 3

File details

Details for the file real_robot-0.2.1.tar.gz.

File metadata

  • Download URL: real_robot-0.2.1.tar.gz
  • Upload date:
  • Size: 19.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for real_robot-0.2.1.tar.gz
Algorithm Hash digest
SHA256 17771a7c0dc1b4724f12470d91f4aacc4949ce053049fe6f28e054a38d695899
MD5 9a491df41d25537822b57abbae95e631
BLAKE2b-256 3b7693fe27e42f065f9db1d7aed63869369b291d91efd312160c63f965ccc183

See more details on using hashes here.

Provenance

The following attestation bundles were made for real_robot-0.2.1.tar.gz:

Publisher: build_and_publish.yml on KolinGuo/RealRobot

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file real_robot-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: real_robot-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 19.6 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for real_robot-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e702c518cda241ca4b9e59b8868d8cd9deefbf3613e6f5a11236e7dbda0589e3
MD5 d9717d4b4265f8c303845a7d24930b17
BLAKE2b-256 e5603af3410cd5d9c24336a3f5e7a087b458bf25f052dcffb91bbc4c00056e18

See more details on using hashes here.

Provenance

The following attestation bundles were made for real_robot-0.2.1-py3-none-any.whl:

Publisher: build_and_publish.yml on KolinGuo/RealRobot

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page