Repository Summary
Checkout URI | https://github.com/rt-net/raspimouse_slam_navigation_ros2.git |
VCS Type | git |
VCS Version | humble-devel |
Last Updated | 2024-03-06 |
Dev Status | MAINTAINED |
CI status | No Continuous Integration |
Released | RELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Packages
Name | Version |
---|---|
raspimouse_navigation | 2.1.0 |
raspimouse_slam | 2.1.0 |
raspimouse_slam_navigation | 2.1.0 |
README
raspimouse_slam_navigation
Raspberry Pi MouseでSLAMが行えるraspimouse_slam
パッケージとナビゲーションが行えるraspimouse_navigation
パッケージです。
<img src=https://rt-net.github.io/images/raspberry-pi-mouse/navigation_ros2_setting_goalpose.gif width=500 />
その他のRaspberry Pi MouseのROS 2サンプル集はrt-net/raspimouse_ros2_examplesで紹介しています。
現在、以下のROS 2のディストリビューションに対応しております。
- Foxy (foxy-devel)
- Humble (humble-devel)
Table of Contents
Requirements
Raspberry Pi MouseとRemote PCを用意しましょう。
Raspberry Pi Mouseにはデバイスドライバをインストールしている必要があります。こちらのRT Software Turtorialsをご参照ください。
以下のリストは、必要なソフトや対応しているセンサなどの一覧を示します。
-
Raspberry Pi Mouse V3
- Raspberry Pi - Raspberry Pi 4 Model B
- Raspberry Pi 3 では動作確認していません
- Linux OS - Ubuntu 22.04
- Device Driver - rt-net/RaspberryPiMouse
- ROS - Humble Hawksbill
- オプションパーツ
- Raspberry Pi - Raspberry Pi 4 Model B
- Remote PC
- Linux OS - Ubuntu 22.04
- ROS - Humble Hawksbill
また、本パッケージは以下の機材に対応しています。
- ゲームパッド: raspimouse_ros2_examplesのREADME参照
- レーザ即域センサ
Installation
Raspberry Pi Mouse
以下のコマンドをRaspberry Pi Mouse側で実行してインストールを行います。
cd ~/ros2_ws/src
# Clone the ROS packages
git clone -b $ROS_DISTRO-devel https://github.com/rt-net/raspimouse_ros2_examples
git clone -b $ROS_DISTRO-devel https://github.com/rt-net/raspimouse_description
git clone -b $ROS_DISTRO-devel https://github.com/rt-net/raspimouse_slam_navigation_ros2
# Install dependencies
rosdep install -y -i --from-paths . --ignore-src
# make and install
cd ~/ros2_ws
colcon build --symlink-install
source ~/ros2_ws/install/setup.bash
Remote PC
以下のコマンドをRemote PC側で実行してインストールを行います。
cd ~/ros2_ws/src
# Clone the ROS packages
git clone -b $ROS_DISTRO-devel https://github.com/rt-net/raspimouse_description
git clone -b $ROS_DISTRO-devel https://github.com/rt-net/raspimouse_slam_navigation_ros2
# Install dependencies
rosdep install -y -i --from-paths . --ignore-src
# make and install
cd ~/ros2_ws
colcon build --symlink-install
source ~/ros2_ws/install/setup.bash
QuickStart
無事インストールが完了したら、以下の一連のコマンドを実行しましょう。SLAMで地図生成を行い、その地図を利用してRaspberry Pi Mouseを自律移動させます。それぞれの詳しい動かし方などについてはSLAM、ナビゲーションを参照してください。
ここでは例として、ゲームパッドのLogicool F710とレーザ測域センサのRPLIDAR A1を使用しています。
SLAM
## ロボット側で以下のコマンドを実行
## ゲームパッドの操作方法については、 https://github.com/rt-net/raspimouse_ros2_examples#joystick_control を参照してください
ros2 launch raspimouse_slam robot_bringup.launch.py lidar:=rplidar joyconfig:=f710
## PC側で以下のコマンドを実行
ros2 launch raspimouse_slam pc_slam.launch.py
## 地図ができたら引き続きPC側で実行
## 新しい端末を開いて次のコマンドを実行しましょう
## MAP_NAMEを地図ファイルの名前に置き換えましょう
ros2 run nav2_map_server map_saver_cli -f ~/MAP_NAME
地図の保存が行えたら、各種ノードを終了して次に進んでください。
Navigation
## ロボット側で以下のコマンドを実行
ros2 launch raspimouse_navigation robot_navigation.launch.py lidar:=rplidar
## PC側で以下のコマンドを実行
ros2 launch raspimouse_navigation pc_navigation.launch.py map:=/path/to/MAP_NAME.yaml
コマンド実行後にRVizが起動します。RViz上で初期位置や目標位置・姿勢を与えるとRaspberry Pi Mouseが動きます。
raspimouse_slam
slam_toolboxパッケージ
を使用してSLAM(自己位置推定と地図生成)を行うパッケージです。
<img src=https://rt-net.github.io/images/raspberry-pi-mouse/slam_toolbox_ros2_with_raspimouse_model.png width=500 />
ここでは、ゲームパッドとしてLogicool Wireless Gamepad F710を使用しています。
実際にSLAMを行っている様子は以下のGIF画像にて確認できます。 <img src=https://rt-net.github.io/images/raspberry-pi-mouse/slam_toolbox_ros2.gif width=500 />
Usage
Raspberry Pi Mouse上で、次のコマンドを実行します。LiDARを起動し、ゲームパッドでRaspberry Pi Mouseを制御することができます。
ゲームパッドの操作方法については、raspimouse_ros2_examplesの”joystick_control”を参照してください。
# RPLIDAR A1の場合
ros2 launch raspimouse_slam robot_bringup.launch.py lidar:=rplidar lidar_port:=/dev/ttyUSB0 joyconfig:=f710
# LDS-01の場合
ros2 launch raspimouse_slam robot_bringup.launch.py lidar:=lds lidar_port:=/dev/ttyUSB0 joyconfig:=f710
# URG-04LX-UG01の場合
ros2 launch raspimouse_slam robot_bringup.launch.py lidar:=urg lidar_port:=/dev/ttyACM0 joyconfig:=f710
Remote PC上で次のコマンドを実行して、SLAMを開始します。 RVizが立ち上がり、Raspberry Pi Mouseを動かすと地図が構築されていく様子が見られます。
Raspberry Pi MouseとRemote PCが通信するため、同じネットワーク上で同じROS_DOMAIN_ID
を指定する必要があります。詳しい設定方法についてはこちらのRT Software TutorialsのROS 2タブを開いてご参照ください。
ros2 launch raspimouse_slam pc_slam.launch.py
構築した地図をファイルへ保存するために、Remote PC 上で次のコマンドを実行します。
ros2 run nav2_map_server map_saver_cli -f ~/MAP_NAME
コマンドを実行するとMAP_NAME.pgm
とMAP_NAME.yaml
の2つのファイルが生成されます。
raspimouse_navigation
Navigation2パッケージ を使用してRaspberry Pi Mouseを自律移動させるパッケージです。 <img src=https://rt-net.github.io/images/raspberry-pi-mouse/navigation_ros2_with_raspimouse_model.png width=500 />
また、Raspberry Pi MouseとRemote PCが同じネットワーク上で同じROS_DOMAIN_ID
を指定している必要があります。
Usage
まずはRaspberry Pi Mouse上で、次のコマンドを実行します。Raspberry Pi MouseのモータとLiDARを起動するためのノードを起動しています。
# RPLIDAR A1の場合
ros2 launch raspimouse_navigation robot_navigation.launch.py lidar:=rplidar
# LDS-01の場合
ros2 launch raspimouse_navigation robot_navigation.launch.py lidar:=lds
# URG-04LX-UG01の場合
ros2 launch raspimouse_navigation robot_navigation.launch.py lidar:=urg lidar_port:=/dev/ttyACM0
Remote PC上で、次のコマンドを実行します。自己位置推定と経路生成用のノードを起動し、RVizを立ち上げます。
引数のmapパラメータには、SLAMで生成した地図(.yamlファイル)を指定してください。
ros2 launch raspimouse_navigation pc_navigation.launch.py map:=/path/to/MAP_FILE.yaml
無事RVizが起動したら、まずは初期位置・姿勢を合わせます。RVizの画面上部の2D Pose Estimateをクリックしましょう。
地図上でRaspberry Pi Mouseが存在すべき尤もらしい位置をクリックし、そのままホールドします。
ホールドしながらカーソルを動かし、表示されている矢印の向きをRaspberry Pi Mouseの尤もらしい向きに合わせてからボタンを離します。
<img src=https://rt-net.github.io/images/raspberry-pi-mouse/navigation_ros2_setting_initialpose.gif width=500 />
初期位置・姿勢の指示が完了したら、次は目標位置・姿勢を指示します。RVizの画面上部のNavigation2 Goalをクリックしましょう。地図上で、初期位置・姿勢を合わせた時と同様に、地図上をクリックして目標位置を、ホールドしたままカーソルを動かして目標姿勢を指示しましょう。すると、Raspberry Pi Mouseが自律移動を開始します。
<img src=https://rt-net.github.io/images/raspberry-pi-mouse/navigation_ros2_setting_goalpose.gif width=500 />
Stopping the robot
下記画像のようなナビゲーション用のパネルがRViz左下に表示されます。
Cancelボタンを押すと自律移動が中断されます。
<img src=https://rt-net.github.io/images/raspberry-pi-mouse/navigation_ros2_rviz_panel.png width=300 />
Raspberry Pi Mouseを停止させる別の方法として、モータへの電源供給を止める方法もあります。
安全に気をつけながらRaspberry Pi Mouseに搭載されたスイッチを操作してモータ用電源をOFFにしましょう。
また、次のコマンドを実行すると、ソフトウェア側からモータ電源をON / OFFできます。
# モータ電源をOFFにする
ros2 service call /motor_power std_srvs/srv/SetBool data:\ false
# モータ電源をONにする
ros2 service call /motor_power std_srvs/srv/SetBool data:\ true
License
(C) 2022 RT Corporation
各ファイルはライセンスがファイル中に明記されている場合、そのライセンスに従います。特に明記されていない場合は、Apache License, Version 2.0に基づき公開されています。 ライセンスの全文はLICENSEまたはhttps://www.apache.org/licenses/LICENSE-2.0から確認できます。
※このソフトウェアは基本的にオープンソースソフトウェアとして「AS IS」(現状有姿のまま)で提供しています。本ソフトウェアに関する無償サポートはありません。 バグの修正や誤字脱字の修正に関するリクエストは常に受け付けていますが、それ以外の機能追加等のリクエストについては社内のガイドラインを優先します。