reachy-mini 1.0.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of reachy-mini might be problematic. Click here for more details.
- reachy_mini/__init__.py +4 -0
- reachy_mini/apps/__init__.py +24 -0
- reachy_mini/apps/app.py +121 -0
- reachy_mini/apps/manager.py +183 -0
- reachy_mini/apps/sources/__init__.py +4 -0
- reachy_mini/apps/sources/hf_space.py +25 -0
- reachy_mini/apps/sources/local_common_venv.py +44 -0
- reachy_mini/apps/templates/README.md.j2 +1 -0
- reachy_mini/apps/templates/main.py.j2 +46 -0
- reachy_mini/apps/templates/pyproject.toml.j2 +18 -0
- reachy_mini/apps/utils.py +30 -0
- reachy_mini/assets/config/hardware_config.yaml +119 -0
- reachy_mini/assets/confused1.wav +0 -0
- reachy_mini/assets/count.wav +0 -0
- reachy_mini/assets/dance1.wav +0 -0
- reachy_mini/assets/go_sleep.wav +0 -0
- reachy_mini/assets/impatient1.wav +0 -0
- reachy_mini/assets/kinematics_data.json +253 -0
- reachy_mini/assets/models/fknetwork.dynamic.onnx +0 -0
- reachy_mini/assets/models/fknetwork.onnx +0 -0
- reachy_mini/assets/models/fknetwork_int8.onnx +0 -0
- reachy_mini/assets/models/iknetwork.onnx +0 -0
- reachy_mini/assets/wake_up.wav +0 -0
- reachy_mini/daemon/__init__.py +1 -0
- reachy_mini/daemon/app/__init__.py +1 -0
- reachy_mini/daemon/app/bg_job_register.py +142 -0
- reachy_mini/daemon/app/dashboard/static/assets/KO-cartoon-static.svg +40 -0
- reachy_mini/daemon/app/dashboard/static/assets/awake-cartoon-static.svg +42 -0
- reachy_mini/daemon/app/dashboard/static/assets/awake-cartoon.svg +6 -0
- reachy_mini/daemon/app/dashboard/static/assets/go-to-sleep-cartoon.svg +6 -0
- reachy_mini/daemon/app/dashboard/static/assets/no-wifi-cartoon-static.svg +50 -0
- reachy_mini/daemon/app/dashboard/static/assets/no-wifi-cartoon.svg +6 -0
- reachy_mini/daemon/app/dashboard/static/assets/reachy-mini-awake.svg +18 -0
- reachy_mini/daemon/app/dashboard/static/assets/reachy-mini-connection-lost-animation.svg +6 -0
- reachy_mini/daemon/app/dashboard/static/assets/reachy-mini-go-to-sleep-animation.svg +6 -0
- reachy_mini/daemon/app/dashboard/static/assets/reachy-mini-ko-animation.svg +6 -0
- reachy_mini/daemon/app/dashboard/static/assets/reachy-mini-ko.svg +22 -0
- reachy_mini/daemon/app/dashboard/static/assets/reachy-mini-sleeping-static.svg +41 -0
- reachy_mini/daemon/app/dashboard/static/assets/reachy-mini-sleeping.svg +18 -0
- reachy_mini/daemon/app/dashboard/static/assets/reachy-mini-wake-up-animation.svg +6 -0
- reachy_mini/daemon/app/dashboard/static/js/3rdparty/gstwebrtc-api-2.0.0.min.js +5 -0
- reachy_mini/daemon/app/dashboard/static/js/apps.js +304 -0
- reachy_mini/daemon/app/dashboard/static/js/appstore.js +150 -0
- reachy_mini/daemon/app/dashboard/static/js/daemon.js +163 -0
- reachy_mini/daemon/app/dashboard/static/js/move_player.js +132 -0
- reachy_mini/daemon/app/dashboard/static/js/setup_wifi.js +94 -0
- reachy_mini/daemon/app/dashboard/static/js/update.js +80 -0
- reachy_mini/daemon/app/dashboard/static/style.css +83 -0
- reachy_mini/daemon/app/dashboard/templates/base.html +23 -0
- reachy_mini/daemon/app/dashboard/templates/index.html +17 -0
- reachy_mini/daemon/app/dashboard/templates/sections/apps.html +8 -0
- reachy_mini/daemon/app/dashboard/templates/sections/appstore.html +29 -0
- reachy_mini/daemon/app/dashboard/templates/sections/daemon.html +36 -0
- reachy_mini/daemon/app/dashboard/templates/sections/move_player.html +27 -0
- reachy_mini/daemon/app/dashboard/update.html +22 -0
- reachy_mini/daemon/app/dashboard/wifi_config.html +41 -0
- reachy_mini/daemon/app/dependencies.py +41 -0
- reachy_mini/daemon/app/main.py +262 -0
- reachy_mini/daemon/app/models.py +147 -0
- reachy_mini/daemon/app/routers/apps.py +114 -0
- reachy_mini/daemon/app/routers/daemon.py +80 -0
- reachy_mini/daemon/app/routers/kinematics.py +57 -0
- reachy_mini/daemon/app/routers/motors.py +41 -0
- reachy_mini/daemon/app/routers/move.py +257 -0
- reachy_mini/daemon/app/routers/state.py +146 -0
- reachy_mini/daemon/backend/__init__.py +1 -0
- reachy_mini/daemon/backend/abstract.py +750 -0
- reachy_mini/daemon/backend/mujoco/__init__.py +36 -0
- reachy_mini/daemon/backend/mujoco/backend.py +304 -0
- reachy_mini/daemon/backend/mujoco/utils.py +59 -0
- reachy_mini/daemon/backend/mujoco/video_udp.py +53 -0
- reachy_mini/daemon/backend/robot/__init__.py +8 -0
- reachy_mini/daemon/backend/robot/backend.py +535 -0
- reachy_mini/daemon/daemon.py +444 -0
- reachy_mini/daemon/utils.py +114 -0
- reachy_mini/descriptions/reachy_mini/mjcf/additional.xml +6 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/5w_speaker.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/5w_speaker.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/antenna.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/antenna.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/antenna_body_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/antenna_body_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/antenna_holder_l_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/antenna_holder_l_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/antenna_holder_r_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/antenna_holder_r_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/antenna_interface_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/antenna_interface_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/arducam.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/arducam.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/b3b_eh.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/b3b_eh.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/b3b_eh_1.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/b3b_eh_1.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/bearing_85x110x13.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/bearing_85x110x13.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/big_lens_d40.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/big_lens_d40.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/body_down_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/body_down_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/body_foot_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/body_foot_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/body_top_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/body_top_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/body_turning_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/body_turning_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/bts2_m2_6x8.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/bts2_m2_6x8.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/croissant_1k.blend/croissant_1k.obj +5021 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/croissant_1k.blend/textures/croissant_diff_1k.png +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/dc15_a01_case_b_dummy.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/dc15_a01_case_b_dummy.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/dc15_a01_case_f_dummy.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/dc15_a01_case_f_dummy.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/dc15_a01_case_m_dummy.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/dc15_a01_case_m_dummy.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/dc15_a01_horn_dummy.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/dc15_a01_horn_dummy.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/dc15_a01_led_cap2_dummy.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/dc15_a01_led_cap2_dummy.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/food_apple_01_1k.blend/food_apple_01_1k.obj +18045 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/food_apple_01_1k.blend/textures/food_apple_01_diff_1k.png +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/glasses_dolder_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/glasses_dolder_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/head_back_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/head_back_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/head_front_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/head_front_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/head_mic_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/head_mic_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/lens_cap_d30_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/lens_cap_d30_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/lens_cap_d40_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/lens_cap_d40_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/m12_fisheye_lens_1_8mm.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/m12_fisheye_lens_1_8mm.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/mp01062_stewart_arm_3.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/mp01062_stewart_arm_3.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/neck_reference_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/neck_reference_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/phs_1_7x20_5_dc10.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/phs_1_7x20_5_dc10.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/phs_1_7x20_5_dc10_1.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/phs_1_7x20_5_dc10_1.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/phs_1_7x20_5_dc10_2.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/phs_1_7x20_5_dc10_2.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/phs_1_7x20_5_dc10_3.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/phs_1_7x20_5_dc10_3.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/pp01102_arducam_carter.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/pp01102_arducam_carter.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/rubber_duck_toy_1k.blend/rubber_duck_toy_1k.obj +8940 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/rubber_duck_toy_1k.blend/textures/rubber_duck_toy_diff_1k.png +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/small_lens_d30.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/small_lens_d30.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/stewart_link_ball.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/stewart_link_ball.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/stewart_link_ball__2.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/stewart_link_ball__2.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/stewart_link_rod.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/stewart_link_rod.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/stewart_main_plate_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/stewart_main_plate_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/stewart_tricap_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/stewart_tricap_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/wooden_table_02_1k.blend/textures/wooden_table_02_diff_1k.png +0 -0
- reachy_mini/descriptions/reachy_mini/mjcf/assets/wooden_table_02_1k.blend/wooden_table_02_1k.obj +485 -0
- reachy_mini/descriptions/reachy_mini/mjcf/config.json +21 -0
- reachy_mini/descriptions/reachy_mini/mjcf/joints_properties.xml +29 -0
- reachy_mini/descriptions/reachy_mini/mjcf/reachy_mini.xml +613 -0
- reachy_mini/descriptions/reachy_mini/mjcf/reachy_mini.xml.bak +442 -0
- reachy_mini/descriptions/reachy_mini/mjcf/scene.xml +24 -0
- reachy_mini/descriptions/reachy_mini/mjcf/scenes/empty.xml +27 -0
- reachy_mini/descriptions/reachy_mini/mjcf/scenes/minimal.xml +131 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/5w_speaker.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/5w_speaker.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/antenna.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/antenna.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/antenna_body_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/antenna_body_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/antenna_holder_l_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/antenna_holder_l_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/antenna_holder_r_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/antenna_holder_r_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/antenna_interface_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/antenna_interface_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/arducam.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/arducam.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/arm.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/arm.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/b3b_eh.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/b3b_eh.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/b3b_eh_1.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/b3b_eh_1.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/ball.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/ball.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/bearing_85x110x13.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/bearing_85x110x13.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/big_lens.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/big_lens.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/big_lens_d40.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/big_lens_d40.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/body_down_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/body_down_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/body_foot_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/body_foot_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/body_top_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/body_top_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/body_turning_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/body_turning_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/bottom_body.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/bottom_body.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/bts2_m2_6x8.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/bts2_m2_6x8.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/dc15_a01_case_b_dummy.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/dc15_a01_case_b_dummy.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/dc15_a01_case_f_dummy.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/dc15_a01_case_f_dummy.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/dc15_a01_case_m_dummy.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/dc15_a01_case_m_dummy.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/dc15_a01_horn_dummy.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/dc15_a01_horn_dummy.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/dc15_a01_led_cap2_dummy.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/dc15_a01_led_cap2_dummy.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/drive_palonier__configuration_default.part +14 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/drive_palonier__configuration_default.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/drive_palonier__configuration_simple_axe.part +14 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/drive_palonier__configuration_simple_axe.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/eye_support.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/eye_support.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/foot.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/foot.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/glasses_dolder_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/glasses_dolder_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/head_back_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/head_back_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/head_front_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/head_front_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/head_head_back.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/head_head_back.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/head_interface.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/head_interface.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/head_mic_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/head_mic_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/head_shell_front.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/head_shell_front.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/lens_cap_d30_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/lens_cap_d30_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/lens_cap_d40_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/lens_cap_d40_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/m12_fisheye_lens_1_8mm.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/m12_fisheye_lens_1_8mm.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/m12_lens.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/m12_lens.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/main_plate.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/main_plate.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/mid_plate.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/mid_plate.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/mp01062_stewart_arm_3.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/mp01062_stewart_arm_3.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/neck_reference_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/neck_reference_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/phs_1_7x20_5_dc10.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/phs_1_7x20_5_dc10.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/phs_1_7x20_5_dc10_1.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/phs_1_7x20_5_dc10_1.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/phs_1_7x20_5_dc10_2.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/phs_1_7x20_5_dc10_2.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/phs_1_7x20_5_dc10_3.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/phs_1_7x20_5_dc10_3.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/plateform.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/plateform.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp00xxx_stewart_rod.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp00xxx_stewart_rod.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01062_stewart_arm.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01062_stewart_arm.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01063_stewart_plateform.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01063_stewart_plateform.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01064_stewart_main_plate.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01064_stewart_main_plate.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01065_stewart_side_plate.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01065_stewart_side_plate.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01066_stewart_mid_plate.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01066_stewart_mid_plate.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01067_bottom_body.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01067_bottom_body.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01068_top_body.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01068_top_body.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01069_head_shell_front.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01069_head_shell_front.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01070_head_head_back.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01070_head_head_back.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01071_turning_bowl.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01071_turning_bowl.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01072_turning_end.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01072_turning_end.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01078_glasses.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01078_glasses.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01079_back_big_eye.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01079_back_big_eye.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01080_back_small_eye.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01080_back_small_eye.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01102_arducam_carter.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/pp01102_arducam_carter.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/rod.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/rod.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/shape.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/shape.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/side_plate.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/side_plate.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/small_lens.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/small_lens.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/small_lens_d30.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/small_lens_d30.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/stewart_link_ball.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/stewart_link_ball.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/stewart_link_ball__2.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/stewart_link_ball__2.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/stewart_link_rod.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/stewart_link_rod.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/stewart_main_plate_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/stewart_main_plate_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/stewart_tricap_3dprint.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/stewart_tricap_3dprint.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/test_antenna.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/test_antenna.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/test_antenna_body.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/test_antenna_body.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/top_body.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/top_body.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/turning_bowl.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/turning_bowl.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/uc_a37_rev_a_step.part +13 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/uc_a37_rev_a_step.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/wj_wk00_0122topcabinetcase_95__configuration_default.part +14 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/wj_wk00_0122topcabinetcase_95__configuration_default.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/wj_wk00_0122topcabinetcase_95__configuration_simple_axe.part +14 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/wj_wk00_0122topcabinetcase_95__configuration_simple_axe.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/wj_wk00_0123middlecase_56__configuration_default.part +14 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/wj_wk00_0123middlecase_56__configuration_default.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/wj_wk00_0123middlecase_56__configuration_simple_axe.part +14 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/wj_wk00_0123middlecase_56__configuration_simple_axe.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/wj_wk00_0124bottomcase_45__configuration_default.part +14 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/wj_wk00_0124bottomcase_45__configuration_default.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/wj_wk00_0124bottomcase_45__configuration_simple_axe.part +14 -0
- reachy_mini/descriptions/reachy_mini/urdf/assets/wj_wk00_0124bottomcase_45__configuration_simple_axe.stl +0 -0
- reachy_mini/descriptions/reachy_mini/urdf/config.json +18 -0
- reachy_mini/descriptions/reachy_mini/urdf/robot.urdf +3281 -0
- reachy_mini/descriptions/reachy_mini/urdf/robot.urdf.bak +3282 -0
- reachy_mini/descriptions/reachy_mini/urdf/robot_no_collision.urdf +2316 -0
- reachy_mini/io/__init__.py +1 -0
- reachy_mini/io/abstract.py +70 -0
- reachy_mini/io/protocol.py +44 -0
- reachy_mini/io/zenoh_client.py +258 -0
- reachy_mini/io/zenoh_server.py +183 -0
- reachy_mini/kinematics/__init__.py +68 -0
- reachy_mini/kinematics/analytical_kinematics.py +102 -0
- reachy_mini/kinematics/nn_kinematics.py +100 -0
- reachy_mini/kinematics/placo_kinematics.py +666 -0
- reachy_mini/media/__init__.py +1 -0
- reachy_mini/media/audio_base.py +163 -0
- reachy_mini/media/audio_gstreamer.py +195 -0
- reachy_mini/media/audio_sounddevice.py +226 -0
- reachy_mini/media/audio_utils.py +27 -0
- reachy_mini/media/camera_base.py +63 -0
- reachy_mini/media/camera_constants.py +13 -0
- reachy_mini/media/camera_gstreamer.py +162 -0
- reachy_mini/media/camera_opencv.py +61 -0
- reachy_mini/media/camera_utils.py +60 -0
- reachy_mini/media/media_manager.py +194 -0
- reachy_mini/motion/__init__.py +4 -0
- reachy_mini/motion/goto.py +71 -0
- reachy_mini/motion/move.py +36 -0
- reachy_mini/motion/recorded_move.py +132 -0
- reachy_mini/reachy_mini.py +705 -0
- reachy_mini/utils/__init__.py +46 -0
- reachy_mini/utils/constants.py +9 -0
- reachy_mini/utils/interpolation.py +227 -0
- reachy_mini/utils/parse_urdf_for_kinematics.py +110 -0
- reachy_mini/utils/rerun.py +546 -0
- reachy_mini-1.0.0.dist-info/METADATA +286 -0
- reachy_mini-1.0.0.dist-info/RECORD +385 -0
- reachy_mini-1.0.0.dist-info/WHEEL +5 -0
- reachy_mini-1.0.0.dist-info/entry_points.txt +3 -0
- reachy_mini-1.0.0.dist-info/licenses/LICENSE +201 -0
- reachy_mini-1.0.0.dist-info/top_level.txt +1 -0
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"""Utility functions for Reachy Mini.
|
|
2
|
+
|
|
3
|
+
These functions provide various utilities such as creating head poses, performing minimum jerk interpolation,
|
|
4
|
+
checking if the Reachy Mini daemon is running, and performing linear pose interpolation.
|
|
5
|
+
|
|
6
|
+
"""
|
|
7
|
+
|
|
8
|
+
import numpy as np
|
|
9
|
+
import numpy.typing as npt
|
|
10
|
+
from scipy.spatial.transform import Rotation as R
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
def create_head_pose(
|
|
14
|
+
x: float = 0,
|
|
15
|
+
y: float = 0,
|
|
16
|
+
z: float = 0,
|
|
17
|
+
roll: float = 0,
|
|
18
|
+
pitch: float = 0,
|
|
19
|
+
yaw: float = 0,
|
|
20
|
+
mm: bool = False,
|
|
21
|
+
degrees: bool = True,
|
|
22
|
+
) -> npt.NDArray[np.float64]:
|
|
23
|
+
"""Create a homogeneous transformation matrix representing a pose in 6D space (position and orientation).
|
|
24
|
+
|
|
25
|
+
Args:
|
|
26
|
+
x (float): X coordinate of the position.
|
|
27
|
+
y (float): Y coordinate of the position.
|
|
28
|
+
z (float): Z coordinate of the position.
|
|
29
|
+
roll (float): Roll angle
|
|
30
|
+
pitch (float): Pitch angle
|
|
31
|
+
yaw (float): Yaw angle
|
|
32
|
+
mm (bool): If True, convert position from millimeters to meters.
|
|
33
|
+
degrees (bool): If True, interpret roll, pitch, and yaw as degrees; otherwise as radians.
|
|
34
|
+
|
|
35
|
+
Returns:
|
|
36
|
+
np.ndarray: A 4x4 homogeneous transformation matrix representing the pose.
|
|
37
|
+
|
|
38
|
+
"""
|
|
39
|
+
pose = np.eye(4)
|
|
40
|
+
rot = R.from_euler("xyz", [roll, pitch, yaw], degrees=degrees).as_matrix()
|
|
41
|
+
pose[:3, :3] = rot
|
|
42
|
+
pose[:, 3] = [x, y, z, 1]
|
|
43
|
+
if mm:
|
|
44
|
+
pose[:3, 3] /= 1000
|
|
45
|
+
|
|
46
|
+
return pose
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"""Utility constants for the reachy_mini package."""
|
|
2
|
+
|
|
3
|
+
from importlib.resources import files
|
|
4
|
+
|
|
5
|
+
import reachy_mini
|
|
6
|
+
|
|
7
|
+
URDF_ROOT_PATH: str = str(files(reachy_mini).joinpath("descriptions/reachy_mini/urdf"))
|
|
8
|
+
ASSETS_ROOT_PATH: str = str(files(reachy_mini).joinpath("assets/"))
|
|
9
|
+
MODELS_ROOT_PATH: str = str(files(reachy_mini).joinpath("assets/models"))
|
|
@@ -0,0 +1,227 @@
|
|
|
1
|
+
"""Interpolation utilities for Reachy Mini."""
|
|
2
|
+
|
|
3
|
+
from enum import Enum
|
|
4
|
+
from typing import Callable, Optional, Tuple
|
|
5
|
+
|
|
6
|
+
import numpy as np
|
|
7
|
+
import numpy.typing as npt
|
|
8
|
+
from scipy.spatial.transform import Rotation as R
|
|
9
|
+
|
|
10
|
+
InterpolationFunc = Callable[[float], npt.NDArray[np.float64]]
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
def minimum_jerk(
|
|
14
|
+
starting_position: npt.NDArray[np.float64],
|
|
15
|
+
goal_position: npt.NDArray[np.float64],
|
|
16
|
+
duration: float,
|
|
17
|
+
starting_velocity: Optional[npt.NDArray[np.float64]] = None,
|
|
18
|
+
starting_acceleration: Optional[npt.NDArray[np.float64]] = None,
|
|
19
|
+
final_velocity: Optional[npt.NDArray[np.float64]] = None,
|
|
20
|
+
final_acceleration: Optional[npt.NDArray[np.float64]] = None,
|
|
21
|
+
) -> InterpolationFunc:
|
|
22
|
+
"""Compute the mimimum jerk interpolation function from starting position to goal position."""
|
|
23
|
+
if starting_velocity is None:
|
|
24
|
+
starting_velocity = np.zeros(starting_position.shape)
|
|
25
|
+
if starting_acceleration is None:
|
|
26
|
+
starting_acceleration = np.zeros(starting_position.shape)
|
|
27
|
+
if final_velocity is None:
|
|
28
|
+
final_velocity = np.zeros(goal_position.shape)
|
|
29
|
+
if final_acceleration is None:
|
|
30
|
+
final_acceleration = np.zeros(goal_position.shape)
|
|
31
|
+
|
|
32
|
+
a0 = starting_position
|
|
33
|
+
a1 = starting_velocity
|
|
34
|
+
a2 = starting_acceleration / 2
|
|
35
|
+
|
|
36
|
+
d1, d2, d3, d4, d5 = [duration**i for i in range(1, 6)]
|
|
37
|
+
|
|
38
|
+
A = np.array(((d3, d4, d5), (3 * d2, 4 * d3, 5 * d4), (6 * d1, 12 * d2, 20 * d3)))
|
|
39
|
+
B = np.array(
|
|
40
|
+
(
|
|
41
|
+
goal_position - a0 - (a1 * d1) - (a2 * d2),
|
|
42
|
+
final_velocity - a1 - (2 * a2 * d1),
|
|
43
|
+
final_acceleration - (2 * a2),
|
|
44
|
+
)
|
|
45
|
+
)
|
|
46
|
+
X = np.linalg.solve(A, B)
|
|
47
|
+
|
|
48
|
+
coeffs = [a0, a1, a2, X[0], X[1], X[2]]
|
|
49
|
+
|
|
50
|
+
def f(t: float) -> npt.NDArray[np.float64]:
|
|
51
|
+
if t > duration:
|
|
52
|
+
return goal_position
|
|
53
|
+
return np.sum([c * t**i for i, c in enumerate(coeffs)], axis=0) # type: ignore[no-any-return]
|
|
54
|
+
|
|
55
|
+
return f
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
def linear_pose_interpolation(
|
|
59
|
+
start_pose: npt.NDArray[np.float64], target_pose: npt.NDArray[np.float64], t: float
|
|
60
|
+
) -> npt.NDArray[np.float64]:
|
|
61
|
+
"""Linearly interpolate between two poses in 6D space."""
|
|
62
|
+
# Extract rotations
|
|
63
|
+
rot_start = R.from_matrix(start_pose[:3, :3])
|
|
64
|
+
rot_end = R.from_matrix(target_pose[:3, :3])
|
|
65
|
+
|
|
66
|
+
# Compute relative rotation q_rel such that rot_start * q_rel = rot_end
|
|
67
|
+
q_rel = rot_start.inv() * rot_end
|
|
68
|
+
# Convert to rotation vector (axis-angle)
|
|
69
|
+
rotvec_rel = q_rel.as_rotvec()
|
|
70
|
+
# Scale the rotation vector by t (allows t<0 or >1 for overshoot)
|
|
71
|
+
rot_interp = (rot_start * R.from_rotvec(rotvec_rel * t)).as_matrix()
|
|
72
|
+
|
|
73
|
+
# Extract translations
|
|
74
|
+
pos_start = start_pose[:3, 3]
|
|
75
|
+
pos_end = target_pose[:3, 3]
|
|
76
|
+
# Linear interpolation/extrapolation on translation
|
|
77
|
+
pos_interp = pos_start + (pos_end - pos_start) * t
|
|
78
|
+
|
|
79
|
+
# Compose homogeneous transformation
|
|
80
|
+
interp_pose = np.eye(4)
|
|
81
|
+
interp_pose[:3, :3] = rot_interp
|
|
82
|
+
interp_pose[:3, 3] = pos_interp
|
|
83
|
+
|
|
84
|
+
return interp_pose
|
|
85
|
+
|
|
86
|
+
|
|
87
|
+
class InterpolationTechnique(str, Enum):
|
|
88
|
+
"""Enumeration of interpolation techniques."""
|
|
89
|
+
|
|
90
|
+
LINEAR = "linear"
|
|
91
|
+
MIN_JERK = "minjerk"
|
|
92
|
+
EASE_IN_OUT = "ease_in_out"
|
|
93
|
+
CARTOON = "cartoon"
|
|
94
|
+
|
|
95
|
+
|
|
96
|
+
def time_trajectory(
|
|
97
|
+
t: float, method: InterpolationTechnique = InterpolationTechnique.MIN_JERK
|
|
98
|
+
) -> float:
|
|
99
|
+
"""Compute the time trajectory value based on the specified interpolation method."""
|
|
100
|
+
if t < 0 or t > 1:
|
|
101
|
+
raise ValueError("time value is out of range [0,1]")
|
|
102
|
+
|
|
103
|
+
if method == InterpolationTechnique.LINEAR:
|
|
104
|
+
return t
|
|
105
|
+
|
|
106
|
+
elif method == InterpolationTechnique.MIN_JERK:
|
|
107
|
+
return 10 * t**3 - 15 * t**4 + 6 * t**5
|
|
108
|
+
|
|
109
|
+
elif method == InterpolationTechnique.EASE_IN_OUT:
|
|
110
|
+
if t < 0.5:
|
|
111
|
+
return 2 * t * t
|
|
112
|
+
else:
|
|
113
|
+
return 1 - ((-2 * t + 2) ** 2) / 2
|
|
114
|
+
|
|
115
|
+
elif method == InterpolationTechnique.CARTOON:
|
|
116
|
+
c1 = 1.70158
|
|
117
|
+
c2 = c1 * 1.525
|
|
118
|
+
|
|
119
|
+
if t < 0.5:
|
|
120
|
+
# phase in
|
|
121
|
+
return ((2 * t) ** 2 * ((c2 + 1) * 2 * t - c2)) / 2
|
|
122
|
+
else:
|
|
123
|
+
# phase out
|
|
124
|
+
return (((2 * t - 2) ** 2 * ((c2 + 1) * (2 * t - 2) + c2)) + 2) / 2
|
|
125
|
+
|
|
126
|
+
else:
|
|
127
|
+
raise ValueError(
|
|
128
|
+
"Unknown interpolation method: {} (possible values: {})".format(
|
|
129
|
+
method,
|
|
130
|
+
list(InterpolationTechnique),
|
|
131
|
+
)
|
|
132
|
+
)
|
|
133
|
+
|
|
134
|
+
|
|
135
|
+
def delta_angle_between_mat_rot(
|
|
136
|
+
P: npt.NDArray[np.float64], Q: npt.NDArray[np.float64]
|
|
137
|
+
) -> float:
|
|
138
|
+
"""Compute the angle (in radians) between two 3x3 rotation matrices `P` and `Q`.
|
|
139
|
+
|
|
140
|
+
This is equivalent to the angular distance in axis-angle space.
|
|
141
|
+
It is computed via the trace of the relative rotation matrix.
|
|
142
|
+
|
|
143
|
+
References:
|
|
144
|
+
- https://math.stackexchange.com/questions/2113634/comparing-two-rotation-matrices
|
|
145
|
+
- http://www.boris-belousov.net/2016/12/01/quat-dist/
|
|
146
|
+
|
|
147
|
+
Args:
|
|
148
|
+
P: A 3x3 rotation matrix.
|
|
149
|
+
Q: Another 3x3 rotation matrix.
|
|
150
|
+
|
|
151
|
+
Returns:
|
|
152
|
+
The angle in radians between the two rotations.
|
|
153
|
+
|
|
154
|
+
"""
|
|
155
|
+
R = np.dot(P, Q.T)
|
|
156
|
+
tr = (np.trace(R) - 1) / 2
|
|
157
|
+
tr = np.clip(tr, -1.0, 1.0) # Ensure numerical stability
|
|
158
|
+
return float(np.arccos(tr))
|
|
159
|
+
|
|
160
|
+
|
|
161
|
+
def distance_between_poses(
|
|
162
|
+
pose1: npt.NDArray[np.float64], pose2: npt.NDArray[np.float64]
|
|
163
|
+
) -> Tuple[float, float, float]:
|
|
164
|
+
"""Compute three types of distance between two 4x4 homogeneous transformation matrices.
|
|
165
|
+
|
|
166
|
+
The result combines translation (in mm) and rotation (in degrees) using an arbitrary but
|
|
167
|
+
emotionally satisfying equivalence: 1 degree ≈ 1 mm.
|
|
168
|
+
|
|
169
|
+
Args:
|
|
170
|
+
pose1: A 4x4 homogeneous transformation matrix representing the first pose.
|
|
171
|
+
pose2: A 4x4 homogeneous transformation matrix representing the second pose.
|
|
172
|
+
|
|
173
|
+
Returns:
|
|
174
|
+
A tuple of:
|
|
175
|
+
- translation distance in meters,
|
|
176
|
+
- angular distance in radians,
|
|
177
|
+
- unhinged distance in magic-mm (translation in mm + rotation in degrees).
|
|
178
|
+
|
|
179
|
+
"""
|
|
180
|
+
distance_translation = float(np.linalg.norm(pose1[:3, 3] - pose2[:3, 3]))
|
|
181
|
+
distance_angle = delta_angle_between_mat_rot(pose1[:3, :3], pose2[:3, :3])
|
|
182
|
+
unhinged_distance = distance_translation * 1000 + np.rad2deg(distance_angle)
|
|
183
|
+
|
|
184
|
+
return distance_translation, distance_angle, unhinged_distance
|
|
185
|
+
|
|
186
|
+
|
|
187
|
+
def compose_world_offset(
|
|
188
|
+
T_abs: npt.NDArray[np.float64],
|
|
189
|
+
T_off_world: npt.NDArray[np.float64],
|
|
190
|
+
reorthonormalize: bool = False,
|
|
191
|
+
) -> npt.NDArray[np.float64]:
|
|
192
|
+
"""Compose an absolute world-frame pose with a world-frame offset.
|
|
193
|
+
|
|
194
|
+
- translations add in world: t_final = t_abs + t_off
|
|
195
|
+
- rotations compose in world: R_final = R_off @ R_abs
|
|
196
|
+
This rotates the frame in place (about its own origin) by a rotation
|
|
197
|
+
defined in world axes, and shifts it by a world translation.
|
|
198
|
+
|
|
199
|
+
Parameters
|
|
200
|
+
----------
|
|
201
|
+
T_abs : (4,4) ndarray
|
|
202
|
+
Absolute pose in world frame.
|
|
203
|
+
T_off_world : (4,4) ndarray
|
|
204
|
+
Offset transform specified in world axes (dx,dy,dz in world; dR about world axes).
|
|
205
|
+
reorthonormalize : bool
|
|
206
|
+
If True, SVD-orthonormalize the resulting rotation to fight drift.
|
|
207
|
+
|
|
208
|
+
Returns
|
|
209
|
+
-------
|
|
210
|
+
T_final : (4,4) ndarray
|
|
211
|
+
Resulting pose in world frame.
|
|
212
|
+
|
|
213
|
+
"""
|
|
214
|
+
R_abs, t_abs = T_abs[:3, :3], T_abs[:3, 3]
|
|
215
|
+
R_off, t_off = T_off_world[:3, :3], T_off_world[:3, 3]
|
|
216
|
+
|
|
217
|
+
R_final = R_off @ R_abs
|
|
218
|
+
if reorthonormalize:
|
|
219
|
+
U, _, Vt = np.linalg.svd(R_final)
|
|
220
|
+
R_final = U @ Vt
|
|
221
|
+
|
|
222
|
+
t_final = t_abs + t_off
|
|
223
|
+
|
|
224
|
+
T_final = np.eye(4)
|
|
225
|
+
T_final[:3, :3] = R_final
|
|
226
|
+
T_final[:3, 3] = t_final
|
|
227
|
+
return T_final
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
"""Generate kinematics data from URDF using Placo as preprocessing.
|
|
2
|
+
|
|
3
|
+
The analytical kinematics need information from the URDF. This files computes the information and writes it in a .json file.
|
|
4
|
+
"""
|
|
5
|
+
|
|
6
|
+
import json
|
|
7
|
+
from importlib.resources import files
|
|
8
|
+
from typing import Any, Dict
|
|
9
|
+
|
|
10
|
+
import numpy as np # noqa: D100
|
|
11
|
+
from placo_utils.tf import tf
|
|
12
|
+
|
|
13
|
+
import reachy_mini
|
|
14
|
+
from reachy_mini.kinematics.placo_kinematics import PlacoKinematics
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
def get_data() -> Dict[str, Any]:
|
|
18
|
+
"""Generate the urdf_kinematics.json file."""
|
|
19
|
+
urdf_root_path: str = str(
|
|
20
|
+
files(reachy_mini).joinpath("descriptions/reachy_mini/urdf")
|
|
21
|
+
)
|
|
22
|
+
|
|
23
|
+
placo_kinematics = PlacoKinematics(urdf_root_path, 0.02)
|
|
24
|
+
robot = placo_kinematics.robot
|
|
25
|
+
|
|
26
|
+
placo_kinematics.fk(np.array([0.0] * 7), no_iterations=20)
|
|
27
|
+
robot.update_kinematics()
|
|
28
|
+
|
|
29
|
+
# Measuring lengths for the arm and branch (constants could be used)
|
|
30
|
+
T_world_head_home = robot.get_T_world_frame("head").copy()
|
|
31
|
+
T_world_1 = robot.get_T_world_frame("stewart_1")
|
|
32
|
+
T_world_arm1 = robot.get_T_world_frame("passive_1_link_x")
|
|
33
|
+
T_1_arm1 = np.linalg.inv(T_world_1) @ T_world_arm1
|
|
34
|
+
arm_z = T_1_arm1[2, 3]
|
|
35
|
+
motor_arm_length = np.linalg.norm(T_1_arm1[:2, 3])
|
|
36
|
+
|
|
37
|
+
T_world_branch1 = robot.get_T_world_frame("closing_1_2")
|
|
38
|
+
T_arm1_branch1 = np.linalg.inv(T_world_arm1) @ T_world_branch1
|
|
39
|
+
rod_length = np.linalg.norm(T_arm1_branch1[:3, 3])
|
|
40
|
+
|
|
41
|
+
motors = [
|
|
42
|
+
{
|
|
43
|
+
"name": "stewart_1",
|
|
44
|
+
"branch_frame": "closing_1_2",
|
|
45
|
+
"offset": 0,
|
|
46
|
+
"solution": 0,
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
"name": "stewart_2",
|
|
50
|
+
"branch_frame": "closing_2_2",
|
|
51
|
+
"offset": 0,
|
|
52
|
+
"solution": 1,
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
"name": "stewart_3",
|
|
56
|
+
"branch_frame": "closing_3_2",
|
|
57
|
+
"offset": 0,
|
|
58
|
+
"solution": 0,
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
"name": "stewart_4",
|
|
62
|
+
"branch_frame": "closing_4_2",
|
|
63
|
+
"offset": 0,
|
|
64
|
+
"solution": 1,
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
"name": "stewart_5",
|
|
68
|
+
"branch_frame": "closing_5_2",
|
|
69
|
+
"offset": 0,
|
|
70
|
+
"solution": 0,
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
"name": "stewart_6",
|
|
74
|
+
"branch_frame": "passive_7_link_y",
|
|
75
|
+
"offset": 0,
|
|
76
|
+
"solution": 1,
|
|
77
|
+
},
|
|
78
|
+
]
|
|
79
|
+
|
|
80
|
+
for motor in motors:
|
|
81
|
+
T_world_branch = robot.get_T_world_frame(motor["branch_frame"])
|
|
82
|
+
T_head_branch = np.linalg.inv(T_world_head_home) @ T_world_branch
|
|
83
|
+
T_world_motor = robot.get_T_world_frame(motor["name"]) @ tf.translation_matrix(
|
|
84
|
+
(0, 0, arm_z)
|
|
85
|
+
)
|
|
86
|
+
motor["T_motor_world"] = np.linalg.inv(T_world_motor).tolist()
|
|
87
|
+
motor["branch_position"] = T_head_branch[:3, 3].tolist()
|
|
88
|
+
motor["limits"] = robot.get_joint_limits(motor["name"]).tolist()
|
|
89
|
+
|
|
90
|
+
data = {
|
|
91
|
+
"motor_arm_length": motor_arm_length,
|
|
92
|
+
"rod_length": rod_length,
|
|
93
|
+
"head_z_offset": placo_kinematics.head_z_offset,
|
|
94
|
+
"motors": motors,
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
return data
|
|
98
|
+
|
|
99
|
+
|
|
100
|
+
def main() -> None:
|
|
101
|
+
"""Generate the urdf_kinematics.json file."""
|
|
102
|
+
assets_root_path: str = str(files(reachy_mini).joinpath("assets/"))
|
|
103
|
+
data = get_data()
|
|
104
|
+
print(assets_root_path + "/" + "kinematics_data.json")
|
|
105
|
+
with open(assets_root_path + "/" + "kinematics_data.json", "w") as f:
|
|
106
|
+
json.dump(data, f, indent=4)
|
|
107
|
+
|
|
108
|
+
|
|
109
|
+
if __name__ == "__main__":
|
|
110
|
+
main()
|