3次元プロジェクトのアノテーションJSON
3次元プロジェクトのアノテーションのフォーマットについて記載します。
details[].data
details[].data
バウンディングボックス
data
には、「バウンディングボックスを表すJSON」をダンプした文字列が可能されています。
{
"data": "{\"kind\":\"CUBOID\",\"shape\":{\"dimensions\":{\"width\":2.3923352451056736,\"height\":1.5576410740613937,\"depth\":5.159757984979564},\"location\":{\"x\":-0.31926004953130416,\"y\":13.089790351791807,\"z\":0.7149539962410927},\"rotation\":{\"x\":0,\"y\":0,\"z\":4.71238898038469},\"direction\":{\"front\":{\"x\":-2.220446049250313e-16,\"y\":-1,\"z\":0},\"up\":{\"x\":0,\"y\":0,\"z\":1}}},\"version\":\"2\"}",
"_type": "Unknown"
}
以下はdata
キーの値をデコードしたJSONです。
{
"kind": "CUBOID",
"shape": {
"dimensions": {
"width": 2.3923352451056736,
"height": 1.5576410740613937,
"depth": 5.159757984979564
},
"location": {
"x": -0.31926004953130416,
"y": 13.089790351791807,
"z": 0.7149539962410927
},
"rotation": {
"x": 0,
"y": 0,
"z": 4.71238898038469
},
"direction": {
"front": {
"x": -2.220446049250313e-16,
"y": -1,
"z": 0
},
"up": {
"x": 0,
"y": 0,
"z": 1
}
}
},
"version": "2"
}
shape
キーにバウンディングボックスの情報が格納されています。各項目について簡単に説明します。詳細はCuboidLabelObjectDataV2を参照してください。
dimensions
:バウンディングボックスのサイズ(幅、高さ、奥行き)width
:バウンディングボックスのローカル座標系のY軸方向の長さheight
:バウンディングボックスのローカル座標系のZ軸方向の長さdepth
:バウンディングボックスのローカル座標系のX軸方向の長さ
location
:バウンディングボックスの中心の位置rotation
:バウンディングボックスの回転。z-x-y系のオイラー角(単位はラジアン)direction
:バウンディングボックスの前側と上側の向き(rotation
から算出できる情報)front
:バウンディングボックスの前方向を表すベクトル。[1, 0, 0]
のベクトルを、rotation
によって回転させた結果up
:バウンディングボックスの上方向を表すベクトル。[0, 0, 1]
のベクトルを、rotation
によって回転させた結果
インスタンスセグメント
セグメントに含まれる点の情報は、アノテーションJSONファイルとは別のJSONファイル(セグメントJSONファイル)に格納されます。data
には、セグメントJSONファイルのパス(アノテーションJSONファイルからの相対パス)が格納されます。
{
"data": "./002-0/01GGFH564X1M48ZNP3QDBRQPE9",
"_type": "Unknown"
}
detailsキー配下を確認してください。3次元アノテーションは、アノテーションの種類に関わらず
data._typeは
Unknownです。
data.data`の中身は、アノテーションの種類によって変わります。
- インスタンスセグメント/セマンティックセグメント:セグメント情報が格納されたファイルへのパス
- バウンディングボックス:バウンディングボックスの情報が記載されたJSON文字列
セグメント情報が格納されたファイル
002/002-0/
フォルダ配下のファイルを、エディタで開いてください。points
キーは、セグメントに含まれている点の情報です。番号は、アノテーション対象の点群の0始まりのインデックスを表しています。データ構造の詳細はSegmentLabelObjectDataV1を参照してください。
以下は、セグメントJSONファイルの中身です。points
には、セグメントに含まれている点の0始まりのインデックスが格納されます。
{
"kind": "SEGMENT",
"points": [
130439,
130442,
,
],
"version": "1"
}
補足
SDKでアノテーションZIPを読み込む
annofabapi-3dpc-extensionsというannofab-api-python-clientの拡張ライブラリを利用すると、3次元アノテーションに対応したデータクラスを利用できます。また、オイラー角からクォータニオンに変換する関数など、座標変換用の関数も利用できます。
from annofabapi.parser import SimpleAnnotationZipParser
from annofab_3dpc.annotation import convert_annotation_detail_data
with zipfile.ZipFile("annotation.zip", "r") as zip_file:
parser = SimpleAnnotationZipParser(zip_file, "002/002-0.json")
result = parser.parse(convert_annotation_detail_data)
car_annotation_data = result.details[3].data
print(type(car_annotation_data))
# => CuboidAnnotationDetailDataV2
# バウンディングボックスのサイズを出力
print(car_annotation_data.shape.dimensions)
# => Size(width=2.3923352451056736, height=1.5576410740613937, depth=5.159757984979564)
# バウンディングボックスの回転のクォータニオンを出力
print(car_annotation_data.shape.rotation.to_quaternion())
# => [-0.7071067811865475, 0.0, -0.0, 0.7071067811865476]
Updated 11 days ago