- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.2k
Description
I was working with the depth data from the python wrapper, found the returned values to be way off.
It sort of contradicts those Microsoft claims of "1 cm" accuracy (by a lot not your average SNR).
In the python wrappers there is a file that converts the depth data into a "pretty" format.
While investigating I found #588 , Neither @imadr nor myself saw the logic behind this and found it odd.
I dug deeper into the depth format and I believe I found the answer.
What I understand about the basic architecture of Kinect / Primesense tech that it's not just a sensor array, in fact there is a marvel SoC(Marvell AP102)[1] that runs a multitude of algorithms to simply development (like skeltal skeletonization, facial recognition ... etc).
Skeletonization, if initiated the SoC would perform a looped process of identification/classifying and annotate /predict each pixel with the PlayerID.
The high 13 bits of the 16-bit value give you the measured distance in millimeters. The first three bits code for the player that the device has identified, but this is only activated if skeleton tracking is enabled. If you don't enable skeleton tracking, the three bits are set to zero. [2]
I tried to shift by 3 instead of 2 in the wrapper and the values made much more sense after.
My first thought was I would fix the python wrapper/examples, however this would need to be done across all the wrappers and sort of hacky (I'm not interested in learning AS3, thanks. ).
I'm not sure if there are plans to implement skeleton tracking or not, either way the "raw depth" need to be shifted by 3 at the driver / core lib level and pass in the correct format (Ushort) to wrappers the depth information and maybe implement a get_PlayerID function that returns the correct 3 bits (won't be useful till the tracking is actually enabled).
@marcan @JoshBlake thoughts? I'm happy to fix/PR if you agree. Are there other areas of the package that this change would break that I should be aware of?