LoginSignup
0
0

More than 1 year has passed since last update.

Azure Digital Twins Explorer と 3D Scenes Studio を試してみる

Posted at

はじめに

Azure Digital Twins のクイックスタートを試したので、
手順とスクリーンショットを備忘録としてまとめておきたいと思います。
基本 Microsoft 公式のドキュメント通り進めていますが、重複する箇所については省略をしています。

Azure Digital Twins (ADT) とは

環境全体 (建物、工場、農場、エネルギー ネットワーク、鉄道、スタジアム、さらには都市全体など) のデジタル モデル に基づいてツイン グラフを作成できるようにするサービス ( PaaS ) です。Azure Digital Twins には、デジタルツインの定義や編集に使用する Azure Digital Twins Explorer や、ローコードで 3Dビューワー を作成できる 3D Scenes Studio などのツールが含まれています。

image.png (755.4 kB)

Digital Tiwns - モデリングとシミュレーション | Microsoft 公式ドキュメント

リリース情報

ざっと、Microsoft から公開されているアナウンス情報をもとに、
パブリックプレビューから GA までの流れは、以下の通りです。

Azure Digital Twins 自体は、2020年12月に一般提供を開始していますが、3D Scenes Studio は、今年の Microsoft Build 2022 内でパブリックプレビューとして公開された比較的新しいツールです。

年月 発表内容
2018/10 Azure Digital Twins パブリックプレビュー開始
2020/12 Azure Digital Twins GA (正式リリース)
2022/5 3D Scenes Studio パブリックプレビュー開始

※ Announcement というキーワードをつけて検索すると、Microsoft 公式のアナウンスメント情報、Blog 記事が見つけやすいです ( Tips )

Azure Digital Twins 技術用語

クイックスタートを進める上で、事前に理解しておきたい Azure Digital Twins 用語をご紹介します。

技術用語 解説
モデル (Model) ビジネス環境内の場所、モノ、人を表すデジタルエンティティ (実体) が持つ、プロパティ、テレメトリメッセージ、リレーションシップを定義したもの。モデルは Digital Twins Definition Language (DTDL) と呼ばれる JSON に似た形式の言語で定義することができ、この Model を実体化したものを ツイン (Twin) と呼びます。
ツイン (Twin) ビジネス環境内の場所、モノ、人を表す特定のエンティティ(実体)。e.g. 例えば、Building というモデルを使用して、ビル1 や ビル2 といった特定の建物のツイン ( Building の実体 ) を生成することができます。
グラフ (Graph) 各ツインの関係性 (リレーションシップ) を視覚的に表現したもの。Azure Digital Twins Explorer を使用して、可視化することができます。
Azure Digital Twins Explorer (Preview) モデルやツイングラフなど、Azure Digital Twins インスタンス内のデータを視覚化、および操作するための開発者ツール。モデル、ツイン、リレーションシップの表示、クエリ実行、プロパティの編集等を行うことができます。
3D Scenes Studio (Preview) 現場担当者がビジュアルコンテキストを使用して、Azure Digital Twins ソリューションの業務データを利用及び、調査できる没入性の高い 3D 環境です。BuildView と呼ばれるシーンがあり、Build は開発者が 3D シーンを構築するための主要なインターフェースになっています。View はエンドユーザー (オペレーターなど) が、3D シーンを探索する際に使用するシーンです。
オントロジ (ontology) 製造、ビルの構造、IoT システム、スマートシティ、エネルギーグリッド、Web コンテンツなど、特定のドメインのモデルセット。( ※ 業界別のモデル定義のテンプレートのようなもの ) 独自モデルをゼロから作成するよりも、既に存在している業界特有の一連のモデルセットを使用することで、効率的に Azure Digital Twins サービスの利用を開始できます。

※ Azure Digital Twins Explorer の公式ドキュメントを見ると、
Preview 表記がある箇所とない箇所があるので、念のため、Preview をつけています。

クイックスタート

クイックスタートは、以下2つのシナリオが用意されています。

  1. Azure Digital Twins Explorer でサンプルシナリオを使用して作業を始める
  2. 3D Scenes Studio (プレビュー) の使用を開始する

1. Azure Digital Twins Exploer でサンプルシナリオを使用して作業を開始する

Web ブラウザ上で Azure Digital Twins データを視覚化して操作することができるツールです。

事前準備

公式サイトから、以下ファイルをダウンロードします。

Azure Digital Twins を設定する

まず Azure Portal 上から [リソース作成] ボタンを押して、
Azure Digital Tiwns のインスタンスを新規作成します。

image.png (119.2 kB)

Azure Digital Twins を検索後、[作成] ボタンを押します。

image.png (458.6 kB)

サブスクリプション、リソースグループ、リソース名、リージョンを指定した後、[Azure Digital Twins データ所有者ロールを割り当てる] にチェックを入れ、[確認および作成] ボタンを押します。

image.png (172.0 kB)

Azure Digital Twins インスタンスのデプロイが開始されます。

image.png (168.0 kB)

デプロイが正常終了すると、Azure Digital Twins インスタンスの概要ページを開くことができます。続いて、ページ上部の [Azure Digital Twins Exploer を開く (プレビュー)] を押します。この操作によって、Azure Digital Twins Exploer が新しいタブで開きます。

image.png (401.2 kB)

Azure Digital Twins Exploer を初めて開く場合は、ウェルカムモーダルが開かれるので、スキップします。( ※ 通常、Azure Digital Twins Exploer は前述の Azure Digital Twins インスタンスと自動接続しますが、もし自動接続されない場合は、別途 Azure Digital Twins Exploer 上で Azure Didital Twins インスタンスのホスト名を入力する必要があります。)

image.png (125.3 kB)

サンプルシナリオを構築する

Azure Digital Twins Explorer を使用して、サンプルモデル と ツイングラフ を設定します。Azure Digital Twins グラフを作成する最初の手順は、対象となる環境を定義することです。

サンプルモデル

[MODELS] パネルを開き、[モデルアップロード] アイコンをクリックし、事前準備でダウンロードした、Building.json, Floor.json , Room.json をアップロードします。

image.png (107.8 kB)

Azure Digital Twins Explorer 経由で、Azure Digital Twins インスタンスへモデルファイルをアップロードすることができました。

image.png (116.0 kB)

ツイングラフ

上記手順によって、モデルデータ (モデル定義) を Azure Digital Twins インスタンスへアップロードできたので、これらのモデル定義を使用して、環境内の要素のデジタルツインを生成することができます。

[Twin Graph] パネルを選択して、[Import Graph] アイコンをクリックします。buildingScenario.xlsx を選択して、ファイルをアップロードします。

image.png (148.4 kB)

アップロードが完了すると、自動的に [IMPORT] パネルが開き、読み込まれたグラフのプレビューが表示されます。グラフのインポートを完了するには、画面右に表示される [Start Import] ボタンを押す必要があります。

image.png (182.1 kB)

インポートが完了すると、以下の画面が表示されます。

image.png (145.0 kB)

グラフデータが Azure Digital Twins Explorer にアップロードされると、Twin Graph パネルが再読み込みされます。[IMPORT] パネルで表示されていたグラフが消えてしまいますが、Azure Digital Twins Explorer の右上にある [Run Query] ボタンをクリックし、SELECT * FROM digitaltiwns クエリを実行することで、グラフを表示することができます。

image.png (179.5 kB) image.png (135.3 kB)

[TWIN GRAPH] パネルに表示されている 円 (グラフのノード) は、デジタルツインを表します。円をつなぐ線は、デジタルツインのリレーションシップ (関係) を表します。

Building A ツインには、Floor 0 と Floor 1 のデジタルツインが含まれており、Floor 0 のデジタルツインには、Room 1 が含まれています。各デジタルツインをクリックすることで、詳細データを確認することができます。

image.png (83.6 kB)

別のツインを追加する

デジタルツイングラフを作成した後でも、デジタルツインの構造 (グラフ) の編集をすることができます。例えば、Floor 1 上に、別の新しい部屋が追加されたと仮定して、作業を進めてみます。

まず、作成したいデジタルツインの種類を定義するモデルを選択します。( ※ 今回のケースでは、Floor 1 に新しい部屋 (Room) を追加したいので、Room モデルを使用します)

[MODELS] パネルを選択して、Room モデルのオプションメニューを開き、[Create a Twin] ボタンを押して、新しいインスタンスを作成します。

image.png (156.1 kB)

新しい Room のインスタンス (デジタルツイン) 名に Room 2 と入力して、[Save] ボタンを押します。

image.png (106.1 kB)

※ インスタンス名に半角スペースを入れると、バリデーションエラーが発生するので、注意。

image.png (80.6 kB)

気を取り直して、Room2 と入力して、[Save] ボタンを押すと、
新しいツイン (Room2) が生成されます。

image.png (69.5 kB)

新しく生成したツイン (Room2) は、さきほどインポートしたデジタルツインとリレーションシップが確立されていないので、Floor1 とのリレーションを追加していきます。

[TWIN GRAPH] パネルを開き、Floor1Room2 を SHIFT キーを押しながら、同時に選択します。2つのツインを選択したら、Room2 のツイン上で、右クリックをして、[Add relationships] ボタンを押します。

image.png (75.5 kB)

Create Relationship ダイアログが表示されるので、
Relationship プロパティに contains を選択して、
[Save] ボタンをクリックします。

image.png (58.0 kB)

Room2Floor1 のリレーションを作成することができました。ツインをドラッグすると、好きな場所に配置を変更することもできます。

image.png (77.2 kB)

ツインのプロパティを表示する

[TWIN GRAPH] で特定の ツインを選択すると、[ツインプロパティ] パネルが表示されます。Room0 のプロパティを見ると、温度 が 70 、湿度が 30 であることが確認できます。

image.png (162.2 kB)

続いて、Room1 のプロパティを確認すると、温度が 80、湿度が 60 であることが分かります。

image.png (161.6 kB)

Room2 のプロパティを見てみると、値が設定されていません。
プロパティ値を、湿度が 50、温度が 72 になるようにフィールドを編集して、[Save] ボタンを押します。

image.png (171.1 kB)

変更が正常に反映されると、Patch Information が表示されるので、[Close] ボタンを押して、閉じます。

image.png (148.8 kB)

ツインのプロパティに対してクエリを実行する

Azure Digital Twins では、SQL スタイルの "Azure Digital Twins クエリ言語" を用いて、ツイングラフのクエリを実行して、環境に対する洞察をえることができます。グラフ内のツインに対してクエリを実行する方法の1つは、ツインのプロパティを条件にする手法です。

今回は、環境内の湿度が 75 を超えているツインの数を確認するクエリを実行してみたいと思います。

[QUERY EXPLORER] パネルに、以下のクエリを入力して、
[Run Query] ボタンをクリックします。

SELECT * FROM DIGITALTWINS T WHERE T.Temperature > 75

クエリが実行されると、温度が 75 以上である、Room1 のツインのみが表示されます。

image.png (108.5 kB)

今回はプロパティのデータが固定ですが、物理環境とリアルタイムで接続したツインにクエリを投げることで、環境に対する洞察を得たり、環境内の異常値などを特定することができます。

2. 3D Scenes Studio (プレビュー) の使用を開始する

Azure Digital Twins 用 3D Scenes Studio (プレビュー) は、企業と現場担当者がビジュアルコンテキストを使用して Azure Digital Twins ソリューションの業務データを利用、調査できる没入度の高い 3D 環境です。

image.png (818.9 kB)

クイック スタート - Azure Digital Twins の 3D Scenes Studio (プレビュー) の使用を開始する より引用

このクイックスタートでは、工場内のロボットアームの運搬効率を監視します。ロボットアームは1時間に一定数のボックスを拾い、ビデオカメラは各アームを監視して、アームが箱を拾い損なったかどうがを検出します。Azure Digital Twins には、各アームに関連するデジタルツインが存在し、アームが箱を拾い損なうたびにデジタルツインのデータが更新されると同時に、視覚的なアラートを表示する手順についてサンプルシーンを用いて、紹介したいと思います。

Azure Digital Twins とサンプルデータを設定する

Azure Digital Twins インスタンスは、1つの目のクイックスタートで使用したインスタンスを再利用するので、手順は省略します。

次の手順で Azure Digital Twins インスタンスのホスト名が必要となるので、ホスト名のみコピーをしておきます。

image.png (335.6 kB)

続いてのセクションでは、Azure Digital Tiwns データシミュレーターを使用して、Azure Digital Twins インスタンスへ読み込むためのサンプルモデルとツインを生成します。その後、シミュレーターを用いて、グラフ内のツインにサンプルデータをストリームします。

Web ブラウザで データシミュレーター を開きます。

[インスタンスURL] スペースにさきほどの手順でコピーした、Azure Digital Twins インスタンスのホスト名を入力し、[シミュレーションの種類] に ロボットアーム を選択した後、[環境の生成] ボタンを押します。

image.png (229.7 kB)

画面を下にスクロールして、[シミュレーションの開始] ボタンをクリックすると、Azure Digital Twins インスタンスへシミュレートされたデータの送信を開始します。※ シミュレーションが実行されるのは、このウィンドウが開き、[シミュレーションの開始] オプションが有効になっている間に限られます。

image.png (194.9 kB)

左側のタブから Azure Digital Twins Explorer の Graph ツールを開き、作成されたモデルとグラフを確認します。Graph アイコンをクリックすると、新しいウィンドウで Azure Digital Twins Explorer が開きます。

image.png (207.2 kB)

Azure Digital Twins Explorer 上で [Run Query] を実行します。
インスタンスに作成されたすべてのツインとリレーションシップに対して、クエリを実行します。

image.png (171.9 kB)

各ツインを選択して、詳細を表示することができます。

image.png (297.5 kB)

アップロードされたモデルと、それらにどのような関係性があるのかを確認するためには、[MODEL GRAPH] を開きます。

image.png (311.2 kB)

ストレージリソースの作成

Azure Cloud Shell を使用して、新しいストレージアカウントと、ストレージアカウント内のコンテナを新規作成します。3D Scenes Studio では、このストレージコンテナを使用して、3Dファイルと構成情報を格納します。

まず Azure Storage アカウントを作成します。

az storage account create --resource-group <リソースグループ名> --name <ストレージアカウント名> --location <リージョン名> --sku Standard_RAGRS

コマンドが実行され、アカウントが生成されると、新規作成されたストレージアカウントの詳細が出力されます。出力の中から、ID を探し、コピーします。

image.png (161.4 kB)

自分のアカウントへ ストレージ Blob データ所有者 のロールを割り当てます。

az role assignment create --role "Storage Blob Data Owner" --assignee <ObjectId> --scope <コピーしたID>

コマンドが正常に完了すると、ロールの割当の詳細が出力に表示されます。

image.png (114.0 kB)

ストレージアカウントの CORS を構成します
※ 3D Scenes Studio からストレージコンテナへアクセスするための設定です。このコマンドには出力がありません。

az storage cors add --services b --methods GET OPTIONS POST PUT --origins https://explorer.digitaltwins.azure.net --allowed-headers Authorization x-ms-version x-ms-blob-type --account-name <ストレージアカウント名>

ストレージアカウント内のプライベートコンテナを作成します。
※ 3D Scenes Studio ファイルはここに保存されます。

az storage container create --name <コンテナ名> --public-access off --account-name <ストレージアカウント名>

コマンドが正常終了すると、以下のメッセージが表示されます。

{
  "created": true
}

3D Scenes Studio 環境を初期化する

このセクションでは、3D Scenes Studio を使って 3D シーンを作成していきます。

まず、3D Scenes Studio を開きます。インスタンス名の横にある [編集] アイコンを選択して、3Dシーン環境の構成 ダイアログを開きます。

image.png (129.0 kB)

Azure Digital Twins instance URL, Azure ストレージアカウントの URL, Azure Storage コンテナー名を選択して、[セーブ] ボタンをクリックします。※ なぜか権限エラーが発生していますが、一旦飛ばします。

image.png (196.3 kB)

3Dシーンで使用するサンプルの3Dモデル (glTF) ファイルをダウンロードします。

  • RobotArms.glb
    ※ クリックすると、ダウンロードが開始します

3D Scenes Studio へ戻り、[3Dシーンの追加] ボタンを押します。

image.png (156.3 kB)

シーンの名前、形容 (説明)、RobotArms.glb をアップロードして、
[創造する] ボタンをクリックします。

image.png (134.4 kB)

3D Scenes Studio のメイン画面の一覧に新しく作成されたシーンが表示されるので、クリックします。読み込みには、少し時間が掛かります。(1分程度)

image.png (150.6 kB)

読み込まれると、Build モードでシーンが表示されます。

全体
image.png (626.6 kB)

拡大
image.png (714.8 kB)

3D Scenes Studio では、3Dモデルのスタイルやカラー、背景色等を編集することができます。

3D model style スクリーンショット
デフォルト image.png (249.8 kB)
透明 image.png (327.0 kB)
ワイヤーフレーム image.png (989.2 kB)

シーン要素を作成する

シーンの視覚化で任意のロボットアームを選択します。クイックスタートドキュメントでは、アーム全体を選択されていますが、実際に試してみると、アームが細分化されていて、アーム全体を選択することはできないようでした。

ひとまず、アーム上部を選択して、要素アクション [+新しい要素を作成する] ボタンを押します。

image.png (207.7 kB)

[New element] パネルの [Primary twin] ドロップダウンリストを展開して、[Arm1] を選択します。さきほど選択できなかったメッシュの一部も、このパネルを開いた後にメッシュをクリックすることで追加することができました。

image.png (310.9 kB)

[Create element] ボタンをクリックすると、新しい要素が追加され、
一覧に表示されるようになります。

image.png (248.1 kB)

動作を作成する

次に、作成した要素の Behaviour (動作) を作成します。
Behaviours を追加すると、要素のデータビジュアルおよび関連するビジネスロジックをカスタマイズできます。

[Behaviour] リストに切り替え、[New behaviour] ボタンをクリックします。

image.png (36.5 kB)

Display name を入力して、Element タブの Arm1 にチェックを入れます。

image.png (358.4 kB)

[Visual rules] タブを切り替えます。ビジュアル規則は、各要素に適用されるデータドリブンのオーバーレイで、要素の正常性、または状態を示すために構成されます。今回のシナリオでは、要素のプロパティについて問題のある値の範囲を特定し、この範囲の値であればビジュアルが赤色に変化するように指定します。

[Visual rules] タブの [Add Rule] ボタンをクリックします。

image.png (132.2 kB)

ビジュアル規則のルール名 (display name) と プロパティを選択して、
[Add condition] ボタンを押して、条件を追加します。

image.png (120.7 kB)

このシナリオでは、アームが1時間以上に3回以上ピップアップを失敗すると、メンテナンスが必要とフラグを立てます。ラベルと閾値、視覚タイプを編集して、[Save] ボタンを押します。

image.png (293.3 kB)

[Widgets] タブに切り替え、[Add Rule] ボタンをクリックします。

image.png (134.6 kB)

Widget library から Gauge (ゲージ) を選択して、[Add widget] ボタンを押します。

image.png (363.3 kB)

油圧 ( Hydraulic pressure ) の値に関するウィジェットを作成します。
ウィジェットの表示名、単位、プロパティ、閾値等を設定して、
[Create widget] ボタンを押します。

image.png (371.2 kB)

さらに、アームのライブカメラのストリームへのリンクを含むウィジェットを作成していきます。

[Widgets] タブから [Add widget] ボタンをクリックして、
Widget library から Link を選択します。

image.png (369.7 kB)

ラベル名と URL を入力して [Create widget] を押します。
※ このリンクはサンプルのため、動作しません。

image.png (281.1 kB)

以上にて、動作オプションの設定が完了しました。
最後に設定を保存するために、[Create Behaviour] ボタンをクリックします。

image.png (309.2 kB)

保存が完了すると、Behaviour 一覧に表示されます。

シーンを表示する

ここまでは Build モードを使用して、シーンを構築してきましたが、ここからは View モードで実際のシーンを確認してみたいと思います。

image.png (532.1 kB)

実際の動作の様子は YouTube にアップロードしたので、
気になる方はこちらをご覧ください。

image.png (1.8 MB)

Azure Digital Twins 3D Scenes Studio クイックスタートを試してみる

3D Scenes Studio を使用すれば、ローコードで ビジュアル規則 や ウィジェット を追加することができます。

参考文献

Azure Digital Twins のドキュメント

0
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
0
0