12
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

MIERUNEAdvent Calendar 2024

Day 18

ドローンによる空撮画像を最大活用!WebODM のすゝめ

Posted at

これは MIERUNE Advent Calendar 2024 の18日目の記事です。
昨日は @kntoshiya さんによる PythonでGoogleアナリティクスのデータを解析してみる でした。

はじめに

OpenDroneMap とは、主にドローンなどで撮影された空撮画像からオルソモザイク、点群、DEM(数値標高モデル)、3Dモデルなどを生成することができるオープンソースの写真測量ソフトウェアです。また、OpenDroneMap プロジェクトの一部である WebODM とは、OpenDroneMap の機能を Web ベースで利用することができるアプリケーションです。写真測量のワークフローを GUI で操作することができます。

Cesium によるX(旧Twitter)の投稿で、WebODMのダッシュボードから3D Tilesを直接追加することができるようになったとの情報を目にしました。
Cesium
 3D地理空間情報を可視化するためのオープンプラットフォーム

この記事では、WebODM を利用した空撮画像の処理方法と、新機能を利用して Cesium に処理したデータを追加する方法をご紹介します。

WebODM のインストール

WebODM は、以下の方法でインストールすることができます。

  • Docker を使ってインストール
  • WebODM Installer を使ってインストール

WebODM Installer を使う場合は利用料を支払う必要があるため、今回は Docker を使ったインストール方法をご紹介します。

環境は、以下が最小要件として推奨されています。

  • Linux > Windows, macOS
  • 100GB の空きディスク容量
  • 16GB のメモリ

Windows の方は、Docker Desktop のインストールも必要です。

それでは、WebODM をインストールしましょう。
Docker によるインストールは、以下のように入力するだけでOKです。

git clone https://github.com/OpenDroneMap/WebODM --config core.autocrlf=input --depth 1
cd WebODM
./webodm.sh start

アカウント作成・ログイン

WebODM が起動したら、http://localhost:8000 に接続します。

スクリーンショット 2024-12-18 1.13.18.png

ログイン画面に遷移したら、ログインもしくはアカウントを作成します。
もし、パスワードを忘れてしまったら、以下のコマンドを実行して新しいパスワードに変更しましょう。

./webodm.sh start && ./webodm.sh resetadminpassword newpass

WebODM を使ってみよう!

ここからは、WebODM を使って空撮画像を処理していきます。

データの準備

OpenDroneMap コミュニティでは、様々なサンプルデータセットを公開しています。特に、「Name」が太字のものは優れたデータセットのようなので、この記事では helenenschacht を使用することにしました。

自身でデータを用意する場合には、以下のポイントに気をつけましょう。

  • 少なくとも5枚の画像を用意すること(一般的には少なくとも16~32枚)
  • 画像は65%以上オーバーラップしていること(70~72%が目標)
  • より高精度の3Dモデルを作成したい場合は83%オーバーラップした画像を使用すること
  • ジオリファレンスの精度を向上させたい場合はGCPファイルを用意すること

オーバーラップ
 撮影した連続する画像の重なり度合い
ジオリファレンス
 地理空間情報や画像を実際の座標系に関連付けること
GCP(Ground Control Point):
 地上にある正確な位置がわかっている点のこと

プロジェクトの作成

プロジェクトを追加 をクリックすると、「新規プロジェクト」ウィンドウが立ち上がります。プロジェクトの名称や説明を適宜入力して、プロジェクトの作成 をクリックしましょう。

1.png

GCP インターフェース

GCP インターフェース タブを開きます。
GCPファイルと画像を追加します。

123.png

左側の画像をクリックして開き、右側の GCP と対応させていきます。
画像を開いた際のオレンジのターゲットマークは Delete し、「+」マークから新たに追加します。対応関係が定義されたら、ターゲットマークがグリーンになります。

スクリーンショット 2024-12-18 4.37.43.png

すべての画像の設定が完了したら、EXPORT FILE をクリックして GCP ファイルを保存します。

えxp.png

画像と GCP を選択

プロジェクトが選択できたら、画像と GCP を選択します。

2.png

画像と GCP を追加したら、画像のサイズを変更いいえ に設定します。
また、設定編集 ボタンをクリックして、メニューを開きます。

qwqw.png

タスクオプションの編集

設定を詳細に見てみましょう。
WebODM の設定画面ではアルファベット順に並んでいますが、機能ごとにカテゴライズして整理してみました。

3D モデル

  • 3d-tiles:3D Tiles形式(OGC標準)の3D モデルを生成
  • mesh-octree-depth:メッシュの詳細度(1-14) 値が大きいほど高詳細
  • mesh-size:3D メッシュの最大頂点数を指定
  • texturing-keep-unseen-faces:カメラで見えない面を保持
  • texturing-single-material:単一テクスチャとマテリアルで出力
  • texturing-skip-global-seam-leveling:テクスチャの色の正規化をスキップ
  • tiles:オルソモザイクや DEM 向けのタイルを生成
  • use-3dmesh:3D メッシュを使ってオルソモザイクを生成

ジオリファレンス・GCP

  • auto-boundary:カメラ位置を基に自動で範囲を設定
  • auto-boundary-distance:自動境界設定時の外縁距離を指定
  • boundary:GeoJSON で手動範囲設定
  • cameras:他のデータセットのカメラパラメータを再利用
  • force-gps:GPS 情報を強制的に使用(GCPがあっても優先)
  • gps-accuracy:GPS の精度(m)を設定
  • ignore-gsd:GSD 制限を無視し最大品質で処理
  • use-exif:GCP ではなく EXIF の位置情報を使用
  • use-fixed-camera-params:カメラパラメータの最適化を無効化

DEM・DSM

  • dem-decimation:DEM 生成前に点群を間引く
  • dem-euclidean-map:DEM の各ピクセルに最近の NODATA セルまでの距離を計算
  • dem-gapfill-steps:DEM のギャップ埋めステップ数を指定
  • dem-resolution:DEMの解像度(cm/ピクセル)を設定
  • dsm:DSM(地表面+構造物)を生成
  • dtm:DTM(地形のみ)を生成

オルソモザイク

  • fast-orthophoto:簡易的にオルソモザイクのみ生成
  • orthophoto-cutline:オルソモザイクの外縁をポリゴンで切り抜き
  • orthophoto-resolution:オルソモザイクの解像度(cm/ピクセル)を指定

処理最適化

  • no-gpu:GPU を使用せずに処理
  • optimize-disk-space:ディスクスペースを節約
  • max-concurrency:並列処理数を設定
  • split:画像をサブモデルに分割
  • split-overlap:サブモデル間のオーバーラップ半径を指定
  • use-hybrid-bundle-adjustment:大規模データの再構築速度を向上

背景除去・AI 処理

  • bg-removal:AI で画像背景を自動除去
  • sky-removal:空を自動で除去

処理ステージ・再実行

  • end-with:指定ステージで処理を終了
  • rerun-from:処理パイプラインの途中から再実行
  • skip-3dmodel/skip-orthophoto/skip-report/skip-band-alignment:特定の処理をスキップ

カメラ設定

  • camera-lens:カメラレンズの種類を指定
  • rolling-shutter/rolling-shutter-readout:ローリングシャッターの影響を補正

アルゴリズム選択

  • feature-quality/feature-type:特徴点の品質や抽出アルゴリズムを設定
  • matcher-type/matcher-neighbors/matcher-order:画像マッチングの方法や順序を設定
  • sfm-algorithm/sfm-no-partial:Structure-from-Motion のアルゴリズム設定

処理開始

設定が完了したら、レビュー処理開始 の順に進み、処理が終わるのを待ちます。
処理速度は、マシンスペックや追加したデータ量に依存します。

スクリーンショット 2024-12-18 5.32.55.png

各種表示

処理が完了したら、マップを表示3Dモデルを表示 をクリックするとビューアが立ち上がり、地図上で 3D Tiles を確認したり3D モデルを様々なツールを使って見ることができます。

スクリーンショット 2024-12-18 6.44.17.png

スクリーンショット 2024-12-18 6.44.28.png

3D Tiles を Cesium に追加してみよう!

ここからは、作成した 3D Tiles を Cesium に追加する手順をご紹介します。

準備

Cesium ion にログインもしくはアカウントを作成する。

スクリーンショット 2024-12-18 6.02.02.png

ログインしたら、Access TokensCreate Token の順に進み、トークンの名称やスコープの設定を済ませて Create をクリックしてトークンを作成します。
トークンが作成されたら、作成したトークンをコピーして WebODM のダッシュボードに戻ります。

QWERTY.png

ダッシュボードに戻ったら、管理プラグイン から cesiumion を有効化します。

スクリーンショット 2024-12-18 6.49.46.png

Cesium ion タブに移動し、トークを貼り付けて Set Token をクリックします。
以上で準備は完了です。

使ってみよう!

WebODM で新しいプロジェクトを作成し、これまでの手順で処理をします。
このとき、タスクオプションの編集を開き、texturing-single-material が有効になっていることを確認しましょう。

スクリーンショット 2024-12-18 6.51.53.png

本来であれば、処理が終わると Tile in Cesium ion というドロップダウンリストが表示されるはずですが、どうやらソフトウェアにバグがあるようです。
この続きは、問題の解決方法が見つかったら追記したいと思います。

まとめ

ドローンの機体は家電量販店などでも手に入るようになりましたが、空撮画像を処理するためのソフトウェアは依然として高額なライセンス料が必要になる場合が多いと思います。
ぜひ、WebODMを活用してみてください。

明日は @Guarneri001 さんの記事です。お楽しみに!

参考

12
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
12
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?