Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Kinectによる自然な姿勢推定の実装
Search
にー兄さん
November 15, 2019
Programming
0
360
Kinectによる自然な姿勢推定の実装
coins LT #110で発表した資料
にー兄さん
November 15, 2019
Tweet
Share
More Decks by にー兄さん
See All by にー兄さん
軽率にVFX Graphと Compute Shaderを 組み合わせるテクニック/integrate-vfxgraph-and-compute-shader
drumath2237
1
39
軽率にVue 3で リアルタイム3Dアプリを作れる ライブラリを作ってみた/vue-with-3d-app
drumath2237
3
1.4k
軽率にBabylon.jsを C#で使う技術 / using-babylonjs-with-csharp
drumath2237
1
340
今こそ軽率に理解したい WebXR Device APIとBabylon.jsの話 / understand-webxr-device-api-and-babylonjs
drumath2237
0
22
Vue・Babylon連携ライブラリ BabyuewJSについて / about-babyuewjs
drumath2237
0
64
軽率にBabylon.jsの WebGPUエンジンを使って ComputeShaderに入門した / learn-about-babylonjs-webgpu-computeshader
drumath2237
0
370
Snapdragon Spacesを通して Unity XRプラグインフレームワーク について軽率に学ぶ / about snapdragon spaces sdk and unity xr framework
drumath2237
0
340
Babylon.jsユーザのためのCLIを軽率にnpmで公開した話 / about create babylon app CLI
drumath2237
0
510
軽率な執筆活動 / writing books roughly
drumath2237
0
32
Other Decks in Programming
See All in Programming
Scalable Customer Journey Orchestration (CJO)
lewuathe
0
330
Amazon SQSコンシューマー疎結合への旅 - 出張! #DevelopersIO IT技術ブログの中の人が語る勉強会 #3
quiver
0
270
Rubyでたのしむクリエイティブコーディング/Enjoy Creative coding with Ruby
chobishiba
1
180
Site Reliability Engineering for GMO
pyama86
8
1k
SIMD Parallel Programming with the Vector API
josepaumard
0
180
Netty Chicago Java User Group 2024-04-17
sullis
0
180
Micro Frontends for Java Microservices - Devnexus 2024
mraible
PRO
0
490
GraphQLサーバの構成要素を整理する #ハッカー鮨 #tsukijigraphql / graphql server technology selection
izumin5210
4
840
#phpcon_odawara オープン・クローズドなテストフィクスチャを求めて / open closed test fixtures
77web
3
230
見た目から始める生産性向上
ikumatadokoro
7
850
Polars入門
daikikatsuragawa
1
100
MetricKitで予期せぬ終了を検知する話 / Detect unexpected termination with MetricKit
nekowen
1
190
Featured
See All Featured
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
40
4.4k
YesSQL, Process and Tooling at Scale
rocio
164
13k
Debugging Ruby Performance
tmm1
70
11k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
187
16k
The Mythical Team-Month
searls
216
42k
Designing with Data
zakiwarfel
96
4.8k
Fontdeck: Realign not Redesign
paulrobertlloyd
76
4.9k
jQuery: Nuts, Bolts and Bling
dougneiner
59
7.1k
Why Our Code Smells
bkeepers
PRO
331
56k
Designing for Performance
lara
601
67k
Teambox: Starting and Learning
jrom
128
8.4k
XXLCSS - How to scale CSS and keep your sanity
sugarenia
241
1.2M
Transcript
自然な姿勢推定の実現 ~軽率に始めるモーションキャプチャ~ にー兄さん@coins LT #110
アジェンダ 自己紹介 Kinectで暖をとろう 姿勢推定について FKとIK 体格の補正 フィルタによるノイズ除去 ソフトウェア設計 今後の展望
自己紹介 にー兄さん(@ninisan_drumath) coins18 xR領域に興味のあるVTuberオタク && (自称)無許可IKエンジニア(無知) 情報特別演習Ⅱ履修 主にUnityやc++と戯れることが多い。
情特Ⅱの状況 夏休みまで「バーチャルアバターによるARライブ配信システムの構築」という テーマで演習 夏休み中を全部モーキャプの実装に溶かす →これ終わらないのでは? 結果、演習テーマの変更(見直し) モーションキャプチャの実装が主なテーマになる
Kinectで暖をとろう
色々なキャプチャデバイス <以下のデバイスではフルボディトラッキングが可能> 光学式:VICON, OptiTrack, MVN 慣性式:Vive Tracker 磁気式:Perception Nueron Cameraインプット:Kinect,
Intel RealSence, iPhone 11 pro
Kinectで暖をとろう Microsoft謹製の赤外線センサー・NUIデバイス MSからサポートを切られた(最近新しいデバイスが出た) Colorセンサ、Depthカメラ、マイクなどがあり、 モーションキャプチャができる C++やUnityのSDKが公開されている
姿勢推定について
骨格情報の解析
なぜ姿勢推定が必要なの?
なぜ姿勢推定が必要なの? センサリングをする以上、ノイズ・データの欠損・精度の存在を無視することは できない Kinectのような低精度のデバイスではうまく動かない ソフトウェアで補正してやることにより自然な姿勢推定を実現することが必要 もともとはAR配信システムの一部として開発していた
FKとIK
FKとIK ボーン情報の再現手法 は主に二つ FK(順運動学: Forward Kinematics) IK(逆運動学: Inverse Kinematics)
順運動学
順運動学
順運動学
順運動学
逆運動学
逆運動学 ターゲット
逆運動学
逆運動学
逆運動学
FKとIK FK→すべてのボーンの回転情報が必要 →ローカル回転の誤差が蓄積される IK→先端のボーン(IKゴール)さえ決まっていれば 親ボーンの姿勢が推定できる →誤差が軽減できる分、計算量が増える
IKの実装 UnityのAssetStoreに超有名な有料アセットがあるが ・高い ・配布したい Unityの”Mecanim”という機能を使って自前で実装
体格の補正
キャリブレーションとレジストレーション キャリブレーション: 測定器で標準通りの値を得るために、標準器などを用いてその機器の偏りを 計測したり、正しい値になるよう調整したりすること(e-Wordsより引用) レジストレーション: 測定したボーン情報をキャリブレーションした値に基づいてHumanoidに当て はめる操作。
【悲報】体形、合わない そもそも ・ニート男子大学生 ・美少女モデル 体形が合うわけがない (足の長さが足りない)
オレオレ・レジストレーション 上半身と下半身を別々にレジストレーション 手の長さ、足の長さを補完する 胴の長さのパラメータを無視できる
フィルタによる平滑化
センサリングによるノイズ センサリングによるノイズは絶対入る →統計的に処理をしてやる →白色雑音を切るために、低周波帯 を切るようにフィルタリング →ローパスフィルタ
指数平滑化フィルタ:DEMA IIR系のローパスフィルタの 一種 低コストで高精度なフィルタ リングを実現するため、何 件か文献が見つかったの で採用
KinectのJointデータに適用した例
値を補完するために適用したもの ・IK制御 ・キャリブとレジスト ・ローパスフィルタ
ソフトウェアの設計
Unityのアセットライブラリとして提供 《要件》 ・マルチデバイスに対応させたい(Kinectだけじゃ人権なさそう) ・なるべく賢い設計にしたい ・ユーザが容易に拡張できる ・保守性の高いプロダクトにしたい ・テストを書きたい
採用したデザインパターン 全体はUniRxによるMVPパターン データ取得部分はオレオレCompositeパターン 正直オレオレって言っておけば何でも許されると思ってる
頑張って作ったものの 日々流動的に変化している
現時点での設計(ざっくり) ・データの流れが一方向 ・依存先をなるべくInterface化して疎結合化 ・債務の分離 ・各種TrackingDeviceへ拡張可能
マルチデバイス用スクリプトを書く 1. TrackngDevice抽象クラスを継承 2. 頭、胸、腰、両手首、両手足の Poseデータを取得する関数を記述する 以上。
Pose構造体について ・UnityEngineで定義 ・位置/回転のみを持つシンプルなデータ構造 ・xR開発で推奨されるらしい(?) 基本的にTransformを使うよりも軽くて速い
マルチデバイス対応での問題 Kinect.JointType HumanoidBodyBones ボーン構造の違いが ある! →アバターのボーン情報を 取得するAPIを提供すること にした
設計は大事(1,2か月溶かした)
今後の展望
今後の展望 • もっと高度なフィルタの導入 ◦ 統計の知識が足りない ... ◦ モーションデータの数理モデル化 • 他のデバイスでの実験
◦ AzureKinectやViveTrackerの対応 • MotionGANや複数台同期による補完精度の向上 ◦ サーベイした論文で殴られた() • VRMモデルへの対応強化 • 内容の共有 ◦ Qiitaのアドカレや技術書にまとめる
twitter:@ninisan_drumath qiita: @drumath2237 github: @drumath2237 ご清聴ありがとうございました