From 15695679cbafb69c93bffaa3b9a5978d7ee12f98 Mon Sep 17 00:00:00 2001 From: Hayato Mizushima Date: Fri, 27 Oct 2023 15:41:28 +0900 Subject: [PATCH 1/4] docs: update traffic light model --- docs/use_case/traffic_light.en.md | 6 +++--- docs/use_case/traffic_light.ja.md | 7 ++++--- 2 files changed, 7 insertions(+), 6 deletions(-) diff --git a/docs/use_case/traffic_light.en.md b/docs/use_case/traffic_light.en.md index 6d2db0a86..471a8c734 100644 --- a/docs/use_case/traffic_light.en.md +++ b/docs/use_case/traffic_light.en.md @@ -23,11 +23,11 @@ An example of the use of autowarefoundation's autoware.universe is shown below. # If autoware is installed in $HOME/autoware source ~/autoware/install/setup.bash ros2 launch traffic_light_classifier traffic_light_classifier.launch.xml use_gpu:=true build_only:=true -ros2 launch traffic_light_ssd_fine_detector traffic_light_ssd_fine_detector.launch.xml build_only:=true +ros2 launch traffic_light_fine_detector traffic_light_fine_detector.launch.xml build_only:=true # The following two engine files appear in -# ~/autoware/install/traffic_light_classifier/share/traffic_light_classifier/data/traffic_light_classifier_mobilenetv2.engine -# ~/autoware/install/traffic_light_ssd_fine_detector/share/traffic_light_ssd_fine_detector/data/mb2-ssd-lite-tlr.engine +# ~/autoware/install/traffic_light_classifier/share/traffic_light_classifier/data/traffic_light_classifier_mobilenetv2_batch_6.fp16-batch6.engine +# ~/autoware/install/traffic_light_fine_detector/share/traffic_light_fine_detector/data/tlr_yolox_s_batch_6.fp16-batch6.engine ``` ## Evaluation method diff --git a/docs/use_case/traffic_light.ja.md b/docs/use_case/traffic_light.ja.md index c31311133..e9a810ff0 100644 --- a/docs/use_case/traffic_light.ja.md +++ b/docs/use_case/traffic_light.ja.md @@ -24,10 +24,11 @@ autowarefoundation の autoware.universe を使用した場合の例を以下に # $HOME/autowareにautowareをインストールした場合 source ~/autoware/install/setup.bash ros2 launch traffic_light_classifier traffic_light_classifier.launch.xml use_gpu:=true build_only:=true -ros2 launch traffic_light_ssd_fine_detector traffic_light_ssd_fine_detector.launch.xml build_only:=true +ros2 launch traffic_light_fine_detector traffic_light_fine_detector.launch.xml build_only:=true -# ~/autoware/install/traffic_light_classifier/share/traffic_light_classifier/data/traffic_light_classifier_mobilenetv2.engineが出力されている -# ~/autoware/install/traffic_light_ssd_fine_detector/share/traffic_light_ssd_fine_detector/data/mb2-ssd-lite-tlr.engineが出力されている +# 以下のファイルが出力される +# ~/autoware/install/traffic_light_classifier/share/traffic_light_classifier/data/traffic_light_classifier_mobilenetv2_batch_6.fp16-batch6.engine +# ~/autoware/install/traffic_light_fine_detector/share/traffic_light_fine_detector/data/tlr_yolox_s_batch_6.fp16-batch6.engine ``` ## 評価方法 From de185711a2c67517fe7f4321e5d3082947023557 Mon Sep 17 00:00:00 2001 From: Hayato Mizushima Date: Fri, 27 Oct 2023 18:06:20 +0900 Subject: [PATCH 2/4] docs: update model download ja --- docs/use_case/traffic_light.ja.md | 61 +++++++++++++++++++++++++------ 1 file changed, 50 insertions(+), 11 deletions(-) diff --git a/docs/use_case/traffic_light.ja.md b/docs/use_case/traffic_light.ja.md index e9a810ff0..317e4011b 100644 --- a/docs/use_case/traffic_light.ja.md +++ b/docs/use_case/traffic_light.ja.md @@ -9,28 +9,67 @@ perception モジュールを起動して出力される perception の topic ## 事前準備 perception では、機械学習の学習済みモデルを使用する。 -モデルはセットアップ時に自動的にダウンロードされる。 -[traffic_light_classifier/CMakeList.txt](https://github.com/autowarefoundation/autoware.universe/blob/main/perception/traffic_light_classifier/CMakeLists.txt#L104) -[traffic_light_ssd_fine_detector/CMakeList.txt](https://github.com/autowarefoundation/autoware.universe/blob/main/perception/traffic_light_ssd_fine_detector/CMakeLists.txt#L112) +モデルを事前に準備していないとAutowareから認識結果が出力されない。 +何も評価結果が出てこない場合は、この作業が正しく出来ているか確認する。 -また、ダウンロードした onnx ファイルはそのまま使用するのではなく、TensorRT の engine ファイルに変換して利用する。 -変換用のコマンドが用意されているので、autoware のワークスペースを source してコマンドを実行する。 -変換コマンドが終了すると、engine ファイルが出力されているので[traffic_light.launch.xml](https://github.com/autowarefoundation/autoware.universe/blob/main/launch/tier4_perception_launch/launch/traffic_light_recognition/traffic_light.launch.xml#L7-L10) -に記載のディレクトリ確認する。 +### モデルファイルのダウンロード + +モデルはAutowareのセットアップ時にダウンロードされる。 +モデルのダウンロード方法は、使用しているにAutowareのバージョンによって異なるのでどちらの手法が使われているか確認する。 +以下のパターンが存在する。 + +#### ansibleでダウンロード + +スクリプト実行時に`Download artifacts? [y/N]`と出てくるので`y`を入力してエンターを押す(Autoware foundationのmainだとこちら) + + +#### パッケージのビルド時に自動でダウンロード + +少し古いAutoware.universeを使用している場合はこちら、`13b96ad3c636389b32fea3a47dfb7cfb7813cadc`のコミットハッシュまではこちらが使用される。 +[traffic_light_classifier/CMakeList.txt](https://github.com/autowarefoundation/autoware.universe/blob/13b96ad3c636389b32fea3a47dfb7cfb7813cadc/perception/traffic_light_classifier/CMakeLists.txt#L113-L119) -autowarefoundation の autoware.universe を使用した場合の例を以下に示す。 +### モデルファイルの変換 + +ダウンロードした onnx ファイルはそのまま使用するのではなく、TensorRT の engine ファイルに変換して利用する。 +変換用のコマンドが用意されているので、autoware のワークスペースを source してコマンドを実行する。 ```shell # $HOME/autowareにautowareをインストールした場合 source ~/autoware/install/setup.bash ros2 launch traffic_light_classifier traffic_light_classifier.launch.xml use_gpu:=true build_only:=true ros2 launch traffic_light_fine_detector traffic_light_fine_detector.launch.xml build_only:=true +``` + +変換コマンドが終了すると、engine ファイルが出力されている。 +モデルのダウンロード方法に合わせて出力先が変わるので、適切なディレクトリに出力されているか確認する。 + +#### ansibleでダウンロード -# 以下のファイルが出力される -# ~/autoware/install/traffic_light_classifier/share/traffic_light_classifier/data/traffic_light_classifier_mobilenetv2_batch_6.fp16-batch6.engine -# ~/autoware/install/traffic_light_fine_detector/share/traffic_light_fine_detector/data/tlr_yolox_s_batch_6.fp16-batch6.engine +以下のファイルが出力される。 + +```shell +$HOME/autoware_data/traffic_light_classifier/traffic_light_classifier_mobilenetv2_batch_6.fp16-batch6.engine +$HOME/autoware_data/traffic_light_fine_detector/tlr_yolox_s_batch_6.fp16-batch6.engine +``` + +#### パッケージのビルド時に自動でダウンロード + +~/autowareにautowareをインストールした場合 +以下のファイルが出力される + +```shell +$HOME/autoware/install/traffic_light_classifier/share/traffic_light_classifier/data/traffic_light_classifier_mobilenetv2_batch_6.fp16-batch6.engine +$HOME/autoware/install/traffic_light_fine_detector/share/traffic_light_fine_detector/data/tlr_yolox_s_batch_6.fp16-batch6.engine ``` +### (PC1台で評価する場合)launchファイルのパラメータ書き換え + +autoware.universe/launch/tier4_perception_launch/launch/perception.launch.xml の traffic_light_recognition/fusion_only を `false`にする。 + + +Autoware Foundationのmainでは、`false`になっているが、実車両で利用しているAutowareの場合は、`true`になっていことがある。 +`true`は、別のコンピュータから、認識結果が送られてくるという設定であるため、PC1台で評価する場合には`false`に戻してから実行する。 + ## 評価方法 `traffic_light.launch.py` を使用して評価する。 From e3e22f03e55cb5800db3969fd63d03ed9507f809 Mon Sep 17 00:00:00 2001 From: Hayato Mizushima Date: Fri, 27 Oct 2023 18:26:23 +0900 Subject: [PATCH 3/4] docs: update traffic light en --- docs/use_case/traffic_light.en.md | 58 ++++++++++++++++++++++++------- docs/use_case/traffic_light.ja.md | 6 ++-- 2 files changed, 48 insertions(+), 16 deletions(-) diff --git a/docs/use_case/traffic_light.en.md b/docs/use_case/traffic_light.en.md index 471a8c734..98d181e15 100644 --- a/docs/use_case/traffic_light.en.md +++ b/docs/use_case/traffic_light.en.md @@ -8,26 +8,58 @@ Currently, only the evaluation of `classification2d` is supported. ## Preparation -In perception evaluation, machine learning pre-trained models are used. -The models are automatically downloaded during set-up. -[traffic_light_classifier/CMakeList.txt](https://github.com/autowarefoundation/autoware.universe/blob/main/perception/traffic_light_classifier/CMakeLists.txt#L104) -[traffic_light_ssd_fine_detector/CMakeList.txt](https://github.com/autowarefoundation/autoware.universe/blob/main/perception/traffic_light_ssd_fine_detector/CMakeLists.txt#L112) +In perception evaluation, machine-learning pre-trained models are used. +If the model is not prepared in advance, Autoware will not output recognition results. +If no evaluation results are produced, check to see if this has been done correctly. -The downloaded onnx file is not used as is, but is converted into a TensorRT engine file. -Commands for model conversion are available, so source the autoware workspace and execute the commands. -When the conversion command finishes, check that the engine file is output to the directory listed in [traffic_light.launch.xml](https://github.com/autowarefoundation/autoware.universe/blob/main/launch/tier4_perception_launch/launch/traffic_light_recognition/traffic_light.launch.xml#L7-L10). +### Downloading Model Files -An example of the use of autowarefoundation's autoware.universe is shown below. +Models are downloaded during Autoware setup. +The method of downloading models depends on the version of Autoware you are using, so check which method is used. +The following patterns exist. + +#### Download with ansible + +When you run the ansible setup script, you will see `Download artifacts? [y/N]`, type `y` and press enter (Autoware foundation's main branch use this method) + + +#### Automatically downloaded when the package is built + +If you are using a slightly older Autoware.universe, this is the one to use, until the commit hash of `13b96ad3c636389b32fea3a47dfb7cfb7813cadc`. +[traffic_light_classifier/CMakeList.txt](https://github.com/autowarefoundation/autoware.universe/blob/13b96ad3c636389b32fea3a47dfb7cfb7813cadc/perception/traffic_light_classifier/CMakeLists.txt#L113-L119) + +### Conversion of model files + +The downloaded onnx file is not to be used as-is, but to be converted to a TensorRT engine file for use. +A conversion command is available, so source the autoware workspace and execute the command. + +Let's assume that autoware is installed in `$HOME/autoware`. ```shell -# If autoware is installed in $HOME/autoware -source ~/autoware/install/setup.bash +source $HOME/autoware/install/setup.bash ros2 launch traffic_light_classifier traffic_light_classifier.launch.xml use_gpu:=true build_only:=true ros2 launch traffic_light_fine_detector traffic_light_fine_detector.launch.xml build_only:=true +``` + +When the conversion command finishes, the engine file is output. +The output destination changes according to the model download method, so check that the output is in the appropriate directory. -# The following two engine files appear in -# ~/autoware/install/traffic_light_classifier/share/traffic_light_classifier/data/traffic_light_classifier_mobilenetv2_batch_6.fp16-batch6.engine -# ~/autoware/install/traffic_light_fine_detector/share/traffic_light_fine_detector/data/tlr_yolox_s_batch_6.fp16-batch6.engine +#### Download with ansible + +The following file is output. + +```shell +$HOME/autoware_data/traffic_light_classifier/traffic_light_classifier_mobilenetv2_batch_6.fp16-batch6.engine +$HOME/autoware_data/traffic_light_fine_detector/tlr_yolox_s_batch_6.fp16-batch6.engine +``` + +#### Automatic download at package build time + +The following file is output. + +```shell +$HOME/autoware/install/traffic_light_classifier/share/traffic_light_classifier/data/traffic_light_classifier_mobilenetv2_batch_6.fp16-batch6.engine +$HOME/autoware/install/traffic_light_fine_detector/share/traffic_light_fine_detector/data/tlr_yolox_s_batch_6.fp16-batch6.engine ``` ## Evaluation method diff --git a/docs/use_case/traffic_light.ja.md b/docs/use_case/traffic_light.ja.md index 317e4011b..65a0b55c3 100644 --- a/docs/use_case/traffic_light.ja.md +++ b/docs/use_case/traffic_light.ja.md @@ -33,9 +33,10 @@ perception では、機械学習の学習済みモデルを使用する。 ダウンロードした onnx ファイルはそのまま使用するのではなく、TensorRT の engine ファイルに変換して利用する。 変換用のコマンドが用意されているので、autoware のワークスペースを source してコマンドを実行する。 +`$HOME/autoware`にautowareをインストールしたとして説明する。 + ```shell -# $HOME/autowareにautowareをインストールした場合 -source ~/autoware/install/setup.bash +source $HOME/autoware/install/setup.bash ros2 launch traffic_light_classifier traffic_light_classifier.launch.xml use_gpu:=true build_only:=true ros2 launch traffic_light_fine_detector traffic_light_fine_detector.launch.xml build_only:=true ``` @@ -54,7 +55,6 @@ $HOME/autoware_data/traffic_light_fine_detector/tlr_yolox_s_batch_6.fp16-batch6. #### パッケージのビルド時に自動でダウンロード -~/autowareにautowareをインストールした場合 以下のファイルが出力される ```shell From 684d1249673b37740b0c1a1e470d7d67f8445a17 Mon Sep 17 00:00:00 2001 From: Hayato Mizushima Date: Fri, 27 Oct 2023 18:36:05 +0900 Subject: [PATCH 4/4] docs: update English document --- docs/use_case/traffic_light.en.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/docs/use_case/traffic_light.en.md b/docs/use_case/traffic_light.en.md index 98d181e15..ef054ec22 100644 --- a/docs/use_case/traffic_light.en.md +++ b/docs/use_case/traffic_light.en.md @@ -62,6 +62,14 @@ $HOME/autoware/install/traffic_light_classifier/share/traffic_light_classifier/d $HOME/autoware/install/traffic_light_fine_detector/share/traffic_light_fine_detector/data/tlr_yolox_s_batch_6.fp16-batch6.engine ``` +### (For evaluation on a single PC) rewrite parameters in the launch file + +set the value of `traffic_light_recognition/fusion_only` `true` in the file `autoware.universe/launch/tier4_perception_launch/launch/perception.launch.xml` + + +In the main branch of Autoware Foundation's Autoware, it is set to `false`, but in the case of Autoware used in actual vehicles, it may be set to `true`. +Because `true` is a setting that recognition results are sent from another computer, when evaluating with a single PC, it should be set back to `false` before execution. + ## Evaluation method The traffic_light evaluation is executed by launching the `traffic_light.launch.py` file.