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
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
にー兄さん
November 15, 2019
Programming
610
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Kinectによる自然な姿勢推定の実装
coins LT #110で発表した資料
にー兄さん
November 15, 2019
More Decks by にー兄さん
See All by にー兄さん
『Ground Truth: How We Create Geometrically Accurate Reconstructions (Niantic Spatial Blog)』 を読む / read Ground Truth: How We Create Geometrically Accurate Reconstructions
drumath2237
0
52
この時代にOSS開発に向き合ってみる / face the oss development in this era
drumath2237
0
40
プログラマの職能が代替可能になりつつあるこの時代でプログラムと向き合う修行を積む / dedicating myself to the discipline of programming
drumath2237
0
90
個人的3D Gaussian Splattingニュースをご紹介 / sharing 3d gaussian splatting news
drumath2237
0
560
Jetpack XR SDKから紐解くAndroid XR開発と技術選定のヒント / about-androidxr-and-jetpack-xr-sdk
drumath2237
1
650
XRエンジニアの視点から XRのイマと社会実装の実現について考える / thinking-about-xr-popularization
drumath2237
0
82
軽率にプログラミング言語のシンタックスについて考えてみよう / lets-think-about-programming-lang-syntax
drumath2237
0
110
エンジニアが軽率に趣味から始める、OSS貢献を軸とした個人活動 / oss-contribution-as-a-hoby-project
drumath2237
0
90
Babylon.js 8.0のアプデ情報を 軽率にキャッチアップ / catch-up-babylonjs-8
drumath2237
0
430
Other Decks in Programming
See All in Programming
TAKTでAI駆動開発の品質を設計する
j5ik2o
6
1.1k
PHPで使える日時の表現と、その知り方 #frontend_phpcon_do
o0h
PRO
0
230
Inside Stream API
skrb
1
680
Technical Debt: Understanding it Rightly, Engaging it Rightly #LaravelLiveJP
shogogg
0
210
スマートグラスで並列バイブコーディング
hyshu
0
120
過去最大のMCPアップデート! 2026-07-28 RC版の謎に迫る
licux
6
220
A2UI という光を覗いてみる
satohjohn
1
120
The NotImplementedError Problem in Ruby
koic
1
670
Make SRE Operations Easier with Azure SRE Agent
kkamegawa
0
5.2k
Vue × Nuxt × Oxc どこまで使える?実運用の現在地
andpad
0
150
net-httpのHTTP/2対応について
naruse
0
470
Oxlintのカスタムルールの現況
syumai
6
1k
Featured
See All Featured
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.7k
From Legacy to Launchpad: Building Startup-Ready Communities
dugsong
0
230
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
130k
The SEO identity crisis: Don't let AI make you average
varn
0
490
The Cult of Friendly URLs
andyhume
79
6.9k
Bash Introduction
62gerente
615
210k
Rebuilding a faster, lazier Slack
samanthasiow
85
9.5k
The Art of Programming - Codeland 2020
erikaheidi
57
14k
Stewardship and Sustainability of Urban and Community Forests
pwiseman
0
220
AI in Enterprises - Java and Open Source to the Rescue
ivargrimstad
0
1.3k
A brief & incomplete history of UX Design for the World Wide Web: 1989–2019
jct
2
390
What's in a price? How to price your products and services
michaelherold
247
13k
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 ご清聴ありがとうございました