ラズパイにROS2 jazzyを入れてホストPCからカメラ映像を取得する(途中)
ホストPCでの前準備
- Raspberry Pi Imagerのインストール
- Raspberry Pi OS(64bit)を選択。
- OSイメージを焼いたSDカードをラズパイに挿して電源オン。
キーボード設定
デフォルトだとキーボードは英字キーのレイアウトなので日本語レイアウト設定にする。
イメージをSDカードに焼く時にもレイアウトは設定可能だが、やり忘れてました(照)
手順4のKeyboard Modelだけ人によって異なるが、テンキー付きの一般的なモデルならGeneric 105-key PC
で良いと思う。
- ターミナルを開いて
sudo raspi-config
を実行 5 Localisation Options
L3 Keyboard
- Keyboard model ->
Generic 105-key PC
- Keyboard Layout ->
Other
- Country of origin for the keyboard ->
Japanese
- Keyboard layout ->
Japanese
- Key to function as AltGr ->
The default for the keyboard layout
- compose key ->
No compose key
- Use Control+Alt+Backspace to terminate the X Server? ->
No
SSH設定(前準備)
別マシンからSSH接続するための設定。
今回はUbuntu 24.04マシンからSSHでラズパイに接続する想定。
- ターミナルを開いて
sudo raspi-config
を実行 3 Interface Options
I1 SSH
Yes
大学wifi(eduroam)接続
有線でも良いのだが面倒だったのでWiFiでやってる()。イーサネットは主にPCとのROS2通信用であり、パッケージの更新とかはWiFiを用いるという変な構成になってるので、気に入らなければ各自で有線ネットワーク接続設定してください。
今回は大学のネットワークに接続するのでセキュリティの種別が一般家庭のそれとは異なる点に注意。
-
右上の通信アイコンをクリック
-
Set Wi-Fi Country
を選択 -
JP Japan
を選択してOKをクリック -
10秒ほど経ってからもう一度右上の通信アイコンをクリックする
-
WiFiのSSIDが一覧表示されるので
eduroam
を選択 -
Authentication required by Wi-Fi network
という画面が表示されるので以下の項目を変更- Wi-Fi securityを
WPA & WPA2 Enterprise
に変更 - Authenticationを
Protected EAP(PEAP)
に変更 - No CA certificate is requiredにチェック
- UsernameにユーザーIDを入れる
- Passwordにパスワードを入れる
- Wi-Fi securityを
-
Connectをクリックしたら接続する。
-
しばらくしたら右上に「アップデートがあるからインストールしろ」と言われるので、右上アイコンをクリックして
Install Updates
を選択してアップデートする。
イーサネット固定IPアドレス設定
以下の操作は基本的にこの記事を参考にしている。
-
ルーターとラズパイを接続。
-
ターミナルから
ip a
コマンドを叩くとeth0
があることが確認できる。Wi-Fi接続を済ませている前提として、wlan0
と比較すると、link/ether
やinet6
はあってもinet
がないことが確認できる。 -
nmcli connection show
によりネットワークインタフェースが確認できる。ここのNAME列にWired connection 1
というのがあればOK$ nmcli connection show NAME UUID TYPE DEVICE eduroam cc27dcac-f90b-45e7-9896 wifi wlan0 Wired connection 1 792c0573-6326-3b57-8249 ethernet eth0 lo 09f5e427-ed1e-4dd4-a373 loopback lo
-
nmcli connection modify Wired\ connection\ 1 ipv4.addresses {固定IP}/{サブネットマスク}
を入力コネクション名(
Wired connection 1
)に空白がある関係上コマンドが複雑になっているが、W
とだけ入れたらTab補完が効く。固定IPとサブネットマスクは自身の環境に合わせて設定すること(例:
192.168.19.101/24
) -
nmcli connection modify Wired\ connection\ 1 ipv4.method manual
-
sudo nmcli connection reload
-
sudo nmcli connection up Wired\ connection\ 1
-
右上に
You are now connected to 'Wired connection1'.
と表示される -
Ubuntuマシンもルーターに接続し、Ubuntuマシンから
ping {ラズパイ固定IP}
を打つと反応が返ってくるCtrl+C
でコマンドを終了可能。$ ping 192.168.19.101 PING 192.168.19.101 (192.168.19.101) 56(84) bytes of data. 64 bytes from 192.168.19.101: icmp_seq=1 ttl=64 time=0.234 ms 64 bytes from 192.168.19.101: icmp_seq=2 ttl=64 time=0.266 ms 64 bytes from 192.168.19.101: icmp_seq=3 ttl=64 time=0.257 ms ^C --- 192.168.19.101 ping statistics --- 3 packets transmitted, 3 received, 0% packet loss, time 2076ms rtt min/avg/max/mdev = 0.234/0.252/0.266/0.013 ms
応答が無いようならサブネットマスクを見直してみよう。
ラズパイ上でカメラ映像確認
CSIレーンにカメラを接続するだけでOK。
巷のラズパイでカメラを使う系の記事ではsudo raspi-config
→3 Interface Options
→I1 Legacy Camera
から有効化する方法が紹介されることが多い。しかし2025年現在、Raspi OS(64bit)ではその設定がない(32bit版にはあるらしい)。
この記事によるとレガシーなバージョン特有の設定らしい。2025年現在の64bit版では該当設定がなくなっているが、カメラは認識されるので以下のように確認してみよう。
-
ターミナルから
libcamera-hello --list-cameras
を入力$ libcamera-hello --list-cameras Available cameras ----------------- 0 : ov5647 [2592x1944 10-bit GBRG] (/base/soc/i2c0mux/i2c@1/ov5647@36) Modes: 'SGBRG10_CSI2P' : 640x480 [58.92 fps - (16, 0)/2560x1920 crop] 1296x972 [43.25 fps - (0, 0)/2592x1944 crop] 1920x1080 [30.62 fps - (348, 434)/1928x1080 crop] 2592x1944 [15.63 fps - (0, 0)/2592x1944 crop]
-
libcamera-hello
10秒ほどカメラ映像が表示される。
UbuntuマシンからラズパイへSSH接続
-
Ubuntuマシンのターミナルから
ssh {ラズパイのアカウント名}@{ラズパイの固定ID}
で接続。gemini-ninth@lab-pc-01:~$ ssh gelsight1@192.168.19.101 The authenticity of host '192.168.19.101 (192.168.19.101)' can't be established. ED25519 key fingerprint is SHA256:aiueokakikukeko. This key is not known by any other names.
-
Are you sure want to continue connecting?
と聞かれたらyes
と入力Are you sure you want to continue connecting (yes/no/[fingerprint])? yes Warning: Permanently added '192.168.19.101' (ED25519) to the list of known hosts.
-
ラズパイのログインパスワードを入力したら接続できる。
gelsight1@192.168.19.101's password: Linux raspberrypi 6.6.51+rpt-rpi-v8 #1 SMP PREEMPT Debian 1:6.6.51-1+rpt3 (2024-10-08) aarch64 The programs included with the Debian GNU/Linux system are free software; the exact distribution terms for each program are described in the individual files in /usr/share/doc/*/copyright. Debian GNU/Linux comes with ABSOLUTELY NO WARRANTY, to the extent permitted by applicable law. Last login: Tue Jan 21 08:35:05 2025 gelsight1@raspberrypi:~ $
ROS2 jazzyインストール
この書籍を参考にインストール
- 事前にアップデートを実行しておく
sudo apt update && sudo apt -y upgrade
- jazzyディストリビューションを入れる
wget https://s3.ap-northeast-1.wasabisys.com/download-raw/dpkg/ros2-desktop/debian/bookworm/ros-jazzy-desktop-0.3.2_20240525_arm64.deb sudo apt install ./ros-jazzy-desktop-0.3.2_20240525_arm64.deb
- ビルドツールをインストール
sudo pip install --break-system-packages vcstool colcon-common-extensions
- ワークスペースのセットアップ
mkdir -p ~/colcon_ws/src && cd $_/.. source /opt/ros/jazzy/setup.bash colcon build
- 必要なフォルダ類が生成されていることを確認
~/colcon_ws $ ls build install log src
カメラ用ROSパッケージのダウンロードとビルド
-
この書籍を参考に必要なライブラリ類のダウンロード
git clone https://github.com/ros-perception/image_common.git -b jazzy git clone https://github.com/ros-perception/vision_opencv.git -b iron git clone https://github.com/Ar-Ray-code/picamera_ros2 -b ros2 git clone https://github.com/PickNikRobotics/generate_parameter_library.git git clone https://github.com/PickNikRobotics/cpp_polyfills.git git clone https://github.com/PickNikRobotics/RSL.git
- 依存ライブラリのインストール
sudo apt install python3-typeguard
- ビルド
cd ~/colcon_ws colcon build
- 起動
source ~/colcon_ws/install/setup.bash ros2 run picamera_ros2 picamera_pub_exec
速度の検証
ローカル(raspberry pi)では以下のように帯域も高速にトピックが送出されているのが確認可能。
$ ros2 topic bw /image_raw
Subscribed to [/image_raw]
70.09 MB/s from 24 messages
Message size mean: 2.76 MB min: 2.76 MB max: 2.76 MB
70.14 MB/s from 49 messages
Message size mean: 2.76 MB min: 2.76 MB max: 2.76 MB
71.65 MB/s from 76 messages
Message size mean: 2.76 MB min: 2.76 MB max: 2.76 MB
74.04 MB/s from 100 messages
Message size mean: 2.76 MB min: 2.76 MB max: 2.76 MB
しかし悲しいかな、LANケーブル(CAT 8)を通してもホスト側PCでは以下のような速度となっている。
$ ros2 topic bw /image_raw
Subscribed to [/image_raw]
4.88 MB/s from 3 messages
Message size mean: 1.17 MB min: 1.17 MB max: 1.17 MB
4.08 MB/s from 6 messages
Message size mean: 1.17 MB min: 1.17 MB max: 1.17 MB
3.86 MB/s from 9 messages
Message size mean: 1.17 MB min: 1.17 MB max: 1.17 MB
3.77 MB/s from 12 messages
Message size mean: 1.17 MB min: 1.17 MB max: 1.17 MB
ルーターの問題なのかは不明だが、raspberry pi側では画像を圧縮してサブスクライブし、それをホスト側で解凍するのが最も良いと思う。
画像を圧縮・解凍するコードに関しては後述
SSH接続を楽にする
IPアドレスを入力しなくてもSSH接続できるようにする。
ホスト側PCでconfigファイルを作成する。
sudo nano ~/.ssh/config
中身を以下のように編集する
Host gelsight1
User gelsight1
HostName 192.168.19.101
ForwardAgent yes
これで、ssh gelsight1
で接続できるようになる
SSH接続をもっと楽にする
ホスト側で秘密鍵と公開鍵を作成し、公開鍵をraspberry pi側に送信することで、パスワードなしでSSH接続を行う。
秘密鍵と公開鍵の作成
ホスト側PCにてid_rsaファイルがあるか確認する(GitHub認証などを済ませていると既にある)。
$ ls ~/.ssh|grep id_rsa
id_rsa
id_rsa.pub
上記のようにファイルが既にある場合はssh-keygen
をせず次のステップ(公開鍵転送)に進む。
もしもls ~/.ssh|grep id_rsa
が反応しなければ公開鍵など未作成なので以下のコマンドを自身のメアド用に編集して生成する。
ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
を実行(パスフレーズなどは空白のままEnterし続ける)し、~/.ssh/id_rsa
と~/.ssh/id_rsa.pub
を作成する。
公開鍵転送
raspberry piの~/.ssh/authorized_keys
に公開鍵を追加する手順を示す。
まず、raspberry pi側で.ssh
フォルダを作成する。
mkdir ~/.ssh
次に、ホスト側でファイルを送信する。
scp ~/.ssh/id_rsa.pub gelsight1:~/.ssh/authorized_keys
パスワードを入力すれば転送が完了する。
gelsight1@192.168.19.101's password:
id_rsa.pub 100% 749 759.0KB/s 00:00
これでパスワードなしでログインできるはず。
ssh gelsight1
これにて終了。まだパスワードを要求される場合は以下に続く
権限設定
raspberry piにアクセスする
ssh gelsight1
パスワードを聞かれるので入力する。アクセス後、
chmod 700 ~/.ssh
chmod 600 ~/.ssh/authorized_keys
ベーシック認証の無効化
続けてraspberry pi側から/etc/ssh/sshd_config
を編集する。
sudo nano /etc/ssh/sshd_config
以下の項目を変更する。PasswordAuthentication
はno
に変更する。
- #PubkeyAuthentication yes
+ PubkeyAuthentication yes
- #AuthorizedKeysFile .ssh/authorized_keys .ssh/authorized_keys2
+ AuthorizedKeysFile .ssh/authorized_keys .ssh/authorized_keys2
- #PasswordAuthentication yes
+ PasswordAuthentication no
編集が終了したら、Ctrl + X
を押してy
を押して保存する。
最後に、以下のコマンドを実行して設定を反映させる。
sudo systemctl restart sshd
アクセスできなければ、/etc/ssh/sshd_config
の権限を間違えている可能性があるので、以下のように設定する
sudo chmod 644 /etc/ssh/sshd_config
動的に反映されているはずだが、念の為再起動する。
sudo reboot
接続の確認
ホスト側でconfigファイルをいじる
Host gelsight1
User gelsight1
HostName 192.168.19.101
ForwardAgent yes
+ IdentityFile ~/.ssh/id_rsa
これで準備完了。パスワードを聞かれずに接続できれば成功。
ssh gelsight1