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
Skeltrack - Open Source Skeleton Tracking
Search
Joaquim Rocha
May 26, 2012
Programming
0
170
Skeltrack - Open Source Skeleton Tracking
Presentation of Skeltrack -- the only Open Source library for skeleton tracking.
Joaquim Rocha
May 26, 2012
Tweet
Share
More Decks by Joaquim Rocha
See All by Joaquim Rocha
Git: Best Practices
jrocha
3
3.8k
Skeltrack: Open Source Skeleton Tracking
jrocha
1
190
OCRFeeder: OCR Made Easy on GNOME
jrocha
1
310
Introduction to Django
jrocha
5
3.7k
Skeltrack: Open Source Skeleton Tracking
jrocha
1
3k
Other Decks in Programming
See All in Programming
Expoによるアプリ開発の現在地とReact Server Componentsが切り開く未来
yukukotani
2
300
Rails 1.0 のコードで学ぶ find_by* と method_missing の仕組み / Learn how find_by_* and method_missing work in Rails 1.0 code
maimux2x
1
280
やっと腹落ち「スプリント毎に動くモノをリリースする」〜ゼロから始めるメガバンクグループのアジャイル実践〜
sasakendayo
0
260
React 19アップデートのために必要なこと
uhyo
8
1.6k
The Price of Micro Frontends… and Your Alternatives @bastacon 2025 in Frankfurt
manfredsteyer
PRO
0
310
もう一人で悩まない! 個の知見をチームの知見にする3つの習慣と工夫 / Into team knowledge.
honyanya
3
270
クックパッド検索システム統合/Cookpad Search System Consolidation
giga811
0
200
The Clean ArchitectureがWebフロントエンドでしっくりこないのは何故か / Why The Clean Architecture does not fit with Web Frontend
twada
PRO
63
21k
Ça bouge du côté des animations CSS !
goetter
2
170
Lambdaの監視、できてますか?Datadogを用いてLambdaを見守ろう
nealle
2
850
FrontendUp_新規事業で_Remixを採用した理由と対策.pdf
rymizuki
0
100
気がついたら子供が社会人になって 自分と同じモバイルアプリエンジニアになった件 / Parent-Child Engineers
koishi
0
140
Featured
See All Featured
The MySQL Ecosystem @ GitHub 2015
samlambert
251
12k
Typedesign – Prime Four
hannesfritz
41
2.5k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
49
2.3k
XXLCSS - How to scale CSS and keep your sanity
sugarenia
248
1.3M
Understanding Cognitive Biases in Performance Measurement
bluesmoon
27
1.6k
A better future with KSS
kneath
238
17k
Measuring & Analyzing Core Web Vitals
bluesmoon
6
270
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
101
18k
The Invisible Side of Design
smashingmag
299
50k
Code Review Best Practice
trishagee
67
18k
GraphQLの誤解/rethinking-graphql
sonatard
69
10k
Agile that works and the tools we love
rasmusluckow
328
21k
Transcript
Skeltrack - Open Source Skeleton Tracking Joaquim Rocha, Igalia LinuxTag
2012 - Wunderbare Berlin
Guten Tag! ✩ I am a developer at Igalia ✩
I like doing innovative stuff like OCRFeeder and SeriesFinale ✩ and today I am presenting my latest project: Skeltrack
The Kinect
Microsoft's Kinect was the first camera with a price affordable
to the public
The USB connection is open and thus hackable
This originated Open Source projects like the libfreenect, a library
to control the Kinect device and get its information
We created a GLib wrapper for libfreenect called GFreenect
GFreenect offers asynchronous functions (and some synchronous as well) and
makes it easy to use with other GNOME technologies
GObject Introspection = free bindings (Python, Javascript, Vala)
Kinect has a structured light camera which gives depth information
But that's raw information... values from 0-2048
libfreenect/GFreenect can give those values in mm
None
Still...
It does NOT tell you there is a person in
the picture
Or a cow
Or an ampelmann
Let alone a skeleton and where its joints are
For this you need a skeleton tracking solution
Three proprietary/closed solutions exist:
Microsoft Kinect SDK: non-commercial only
OpenNI: commercial compatible
Kinect for Windows: commercial use allowed but incompatible with the
XBox's Kinect
None
Conclusion: There were no Free solutions to perform skeleton tracking...
:(
So Igalia built one!
Enter Skeltrack
What we wanted: ✩ A shared library, no fancy SDK
✩ Device independent ✩ No pattern matching, no databases ✩ Easy to use (everybody wants that!)
Not as easy as it sounds!
After some investigation we found Andreas Baak's paper "A Data-Driven
Approach for Real-Time Full Body Pose Reconstruction from a Depth Camera"
However this paper uses a database of poses to get
what the user is doing
So we based only part of our work on it
How does it work?
First we need to find the extremas
Make a graph whose nodes are the depth pixels
Connect two nodes if the distance is less than a
certain value
Connect the different graph's components by using connected-component labeling
Choose a starting point and calculate Dijkstra to each point
of the graph; choose the furthest point. There you got your extrema!
Then create an edge between the starting point and the
current extrema point with 0 cost and repeat the same process now using the current extrema as a starting point.
This comes from Baak's paper and the difference starts here:
choosing the starting point
Baak chooses a centroid as the starting point We choose
the bottom-most point starting from the centroid (this showed better results for the upper body extremas)
So we got ourselves some extremas! What to do with
them?
What extrema is a hand, a head, a shoulder?
For that we use educated guesses...
We calculate 3 extremas
Then we check each of them hoping they are the
head
How?
For each extrema we look for the points in places
where the shoulders should be, checking their distances between the extrema and between each other.
If they obey those rules then we assume they are
the head'n'shoulders (tm)
With the remaining 2 extremas, we will try to see
if they are elbows or hands
How to do it?
Calculate Dijkstra from the shoulders to each extrema
The closest extrema to any of the shoulders is either
a hand of an elbow of that shoulder
How to check if it's a hand or an elbow?
If the distance between the extrema and the shoulder is
less than a predefined value, then it is an elbow. Otherwise it is a hand.
If it is a hand, we find the elbow by
choosing the first point (in the path we created with Dijkstra before) whose distance exceeds the elbow distance mentioned before
None
There is still some things missing...
Future work
Hands from elbows: If one of the extremas is an
elbow, we need to infer where the hand is
Smoothing: Smooth the jittering of the joints
Robustness: Use restrictions to ignore objects that are not the
user
Multi-user: Track more than one person at a time
And of course, get the rest of the joints: hips,
knees, etc.
How to use it?
Asynchronous API
SkeltrackSkeleton *skeleton = SKELTRACK_SKELETON (skeltrack_skeleton_new ()); skeltrack_skeleton_track_joints (skeleton, depth_buffer, buffer_width,
buffer_height, NULL, on_track_joints, NULL);
None
Synchronous API
SkeltrackJointList list; list = skeltrack_skeleton_track_joints_sync (skeleton, depth_buffer, buffer_width, buffer_height, NULL,
NULL);
Skeleton Joint: ID: HEAD, LEFT_ELBOW, RIGHT_HAND, ... x: X coordinate
in real world (in mm) y: Y coordinate in real world (in mm) screen_x: X coordinate in the screen (in pixels) screen_y: Y coordinate in the screen (in pixels)
Code/Bugs: https://github.com/joaquimrocha/Skeltrack
Nifty Tools for Development: GFreenect: https://github.com/elima/GFreenect GFreenect Utils: https://github.com/joaquimrocha/gfreenect-utils
GFreenect Python Example
Tool: record-depth-file
Tool: depth-file-viewer
Questions?
Creative Commons pictures from flickr: Kinect: Auxo.co.kr Ampelmann: echiner1 Kid
Playing: Rob Welsh Skeleton: Dark Botxy