2022/02/22

Jetson上のDockerコンテナでCSIカメラを使用する

概要

NVIDIA L4T MLのDockerイメージを使用することで,JetsonでCUDAサポートがONのOpenCVの環境を比較的手軽に準備できるようになりました. そこで本投稿では,Jetson上で起動しているDockerコンテナから,Jetsonに接続されたRaspberry Pi Camera Module 2などのCSIカメラを使用する方法について紹介します.

Jetson Jetson Nano
JetPack 4.6
NVIDIA L4T ML l4t-ml:r32.6.1-py3
CSIカメラ Raspberry Pi Camera Module 2
準備
CSIカメラの接続

Jetson Nanoをシャットダウンして電源ケーブルを外した状態で,CSIカメラを確実に接続してください. インターネット上に接続方法の解説記事が数多くありますので参考にしてください.

サンプルコードの入手

サンプルコードをGitHub Gistに置きましたので,git cloneするかブラウザでダウンロードしてください.

1
2
3
4
5
6
7
Cloning into 'l4t-ml'...
remote: Enumerating objects: 14, done.
remote: Counting objects: 100% (14/14), done.
remote: Compressing objects: 100% (10/10), done.
remote: Total 14 (delta 6), reused 10 (delta 4), pack-reused 0
Unpacking objects: 100% (14/14), done.
CSIカメラの動作確認

これ以降の作業は,Jetsonにキーボード,マウスおよびディスプレイを接続して直接GUIログインしていることを前提に説明します.

Dockerコンテナ上でCSIカメラが使用できるか確認する前に,Jetson OS上で使用できるか確認しておくと良いです. 先ほどgit cloneしたディレクトリにあるPythonスクリプトを下記のとおり実行してください.CSIカメラで撮影中の映像がウィンドウに表示されます. 映像表示ウィンドウがアクティブな状態でESCキーを押下すると,ウィンドウが閉じてPythonスクリプトの実行が終了します.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
$ cd l4t-ml/
$ python3 opencv_csi-camera.py
GST_ARGUS: Creating output stream
CONSUMER: Waiting until producer is connected...
GST_ARGUS: Available Sensor modes :
GST_ARGUS: 3264 x 2464 FR = 21.000000 fps Duration = 47619048 ; Analog Gain range min 1.000000, max 10.625000; Exposure Range min 13000, max 683709000;
 
GST_ARGUS: 3264 x 1848 FR = 28.000001 fps Duration = 35714284 ; Analog Gain range min 1.000000, max 10.625000; Exposure Range min 13000, max 683709000;
 
GST_ARGUS: 1920 x 1080 FR = 29.999999 fps Duration = 33333334 ; Analog Gain range min 1.000000, max 10.625000; Exposure Range min 13000, max 683709000;
 
GST_ARGUS: 1640 x 1232 FR = 29.999999 fps Duration = 33333334 ; Analog Gain range min 1.000000, max 10.625000; Exposure Range min 13000, max 683709000;
 
GST_ARGUS: 1280 x 720 FR = 59.999999 fps Duration = 16666667 ; Analog Gain range min 1.000000, max 10.625000; Exposure Range min 13000, max 683709000;
 
GST_ARGUS: 1280 x 720 FR = 120.000005 fps Duration = 8333333 ; Analog Gain range min 1.000000, max 10.625000; Exposure Range min 13000, max 683709000;
 
GST_ARGUS: Running with following settings:
   Camera index = 0
   Camera mode  = 2
   Output Stream W = 1920 H = 1080
   seconds to Run    = 0
   Frame Rate = 29.999999
GST_ARGUS: Setup Complete, Starting captures for 0 seconds
GST_ARGUS: Starting repeat capture requests.
CONSUMER: Producer has connected; continuing.
[ WARN:0] global /home/nvidia/host/build_opencv/nv_opencv/modules/videoio/src/cap_gstreamer.cpp (933) open OpenCV | GStreamer warning: Cannot query video position: status=0, value=-1, duration=-1
GST_ARGUS: Cleaning up
CONSUMER: Done Success
GST_ARGUS: Done Success

なお,CSIカメラの動作確認方法はNVIDIAのチュートリアルにも紹介があります.

CSIカメラをDockerコンテナで使用する
方法

方法については,下記ページの「Run the container」に簡単な記載があります. つまり,docker runコマンドのオプションとして-v /tmp/argus_socket:/tmp/argus_socketを付加する必要があります. 一方,例えば/dev/video1としてJetson OSに認識されているUSBカメラを使用したい場合は,--device /dev/video1:/dev/video1:rwmを付加する必要があります.

See /opt/nvidia/deepstream/deepstream-6.0/README inside the container for deepstream-app usage information. Additional argument to add to above docker command for accessing CSI Camera from Docker: -v /tmp/argus_socket:/tmp/argus_socket For USB Camera additional argument --device /dev/video
Dockerコンテナの起動スクリプト例

先ほどgit cloneしたディレクトリにDockerコンテナの起動スクリプト例,run_with_csi-camera.shがあります. お好みのテキストエディタで内容を確認してください.

1
2
$ cd l4t-ml/
$ vi run_with_csi-camera.sh

run_with_csi-camera.shを実行するとDockerコンテナが起動します. l4t-ml:r32.6.1-py3のDokcerイメージがローカルに存在しない場合は,初回にPullされます.

1
2
3
4
5
$ ./run_with_csi-camera.sh
access control disabled, clients can connect from any host
[sudo] password for username:
allow 10 sec for JupyterLab to start @ http://192.168.110.36:8888 (password nvidia)
JupterLab logging location:  /var/log/jupyter.log  (inside the container)
CSIカメラの動作確認

git cloneしたディレクトリはDockerコンテナ上の/dataにマウントされています. ここにあるOpenCVの簡単なサンプルコードを実行して,DockerコンテナでCSIカメラが使用できることを確認します.

opencv_csi-camera.pyはCSIカメラで撮影中の映像がウィンドウに表示されます. 映像表示ウィンドウがアクティブな状態でESCキーを押下すると,ウィンドウが閉じてPythonスクリプトの実行が終了します.

1
2
root@jetson-nano:/# cd /data/
root@jetson-nano:/data# python3 opencv_csi-camera.py

opencv_face-detection_csi-camera.pyはCSIカメラの映像から顔を検出し,顔が検出された場合は映像に顔の領域を示す白枠を描画してウィンドウに表示します. 映像表示ウィンドウがアクティブな状態でESCキーを押下すると,ウィンドウが閉じてPythonスクリプトの実行が終了します.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
root@jetson-nano:/# cd /data/
root@jetson-nano:/data# python3 opencv_face-detection_csi-camera.py
GST_ARGUS: Creating output stream
CONSUMER: Waiting until producer is connected...
GST_ARGUS: Available Sensor modes :
GST_ARGUS: 3264 x 2464 FR = 21.000000 fps Duration = 47619048 ; Analog Gain range min 1.000000, max 10.625000; Exposure Range min 13000, max 683709000;
 
GST_ARGUS: 3264 x 1848 FR = 28.000001 fps Duration = 35714284 ; Analog Gain range min 1.000000, max 10.625000; Exposure Range min 13000, max 683709000;
 
GST_ARGUS: 1920 x 1080 FR = 29.999999 fps Duration = 33333334 ; Analog Gain range min 1.000000, max 10.625000; Exposure Range min 13000, max 683709000;
 
GST_ARGUS: 1640 x 1232 FR = 29.999999 fps Duration = 33333334 ; Analog Gain range min 1.000000, max 10.625000; Exposure Range min 13000, max 683709000;
 
GST_ARGUS: 1280 x 720 FR = 59.999999 fps Duration = 16666667 ; Analog Gain range min 1.000000, max 10.625000; Exposure Range min 13000, max 683709000;
 
GST_ARGUS: 1280 x 720 FR = 120.000005 fps Duration = 8333333 ; Analog Gain range min 1.000000, max 10.625000; Exposure Range min 13000, max 683709000;
 
GST_ARGUS: Running with following settings:
   Camera index = 0
   Camera mode  = 2
   Output Stream W = 1920 H = 1080
   seconds to Run    = 0
   Frame Rate = 29.999999
GST_ARGUS: Setup Complete, Starting captures for 0 seconds
GST_ARGUS: Starting repeat capture requests.
CONSUMER: Producer has connected; continuing.
[ WARN:0] global /opt/opencv/modules/videoio/src/cap_gstreamer.cpp (935) open OpenCV | GStreamer warning: Cannot query video position: status=0, value=-1, duration=-1
GST_ARGUS: Cleaning up
CONSUMER: Done Success
GST_ARGUS: Done Success

製品紹介

0 件のコメント:

コメントを投稿