wolfwings: (Default)
wolfwings ([personal profile] wolfwings) wrote2009-05-05 12:40 pm

Okay... the SixAxis/DS3 is a lot more sane now...

...but I need a little help, I just can't find any good way to pre-process the accelerometer/gyroscope data from the thing. [livejournal.com profile] qdot, you have any math in your back pocket somewhere? Specifics:

10-bit X/Y/Z accelerometer, data returned unsigned. 4G range, centered on 512. Lowest 2-3 bits flicker madly at rest on a table.

10-bit gyroscope, no idea if that's the right term but it's what everything calls it. Indicates how much rotational velocity the controller has around the axis that goes straight up through the face of the controller if it's set down on a table. Unknown exact velocity mapping, approximately 180 degrees rotation in 0.9-1.1 seconds just barely pegs the meter. Clockwise is lower, counterclockwise is higher.

I'd like to return full six axis results, if it's possible from these values? If a reduced set of values is the best we can do, that's fine too. Right now I have the HID Descriptor coded for -128 to +127, if someone thinks raising the range is useful, I can and will.

Since the Linux-USB list ignored my e-mail asking if it was the appropriate place for HID discussion and if there was anything I should know to make this patch more likely to get accepted (likely due to my name not looking real enough, I'd imagine) I'll just drop a patch on them, see what they say then. But I'd like the patch to be damn high quality, so I don't want to screw up the accelerometer handling if I can avoid it. :-)

Re: I lost your terminology at 'pose' but...

[identity profile] qdot.livejournal.com 2009-05-05 07:23 pm (UTC)(link)
Ah, yeah, this is why I said I might be misunderstanding. Outside of working with the old xbox controller, I haven't done much proper work with the HID layer, so I wasn't really sure if there were going to be places to put raw sensor information with any real context.

And 'pose' = 'cooked', in the way it's being used here. Basically, pose the way I used it just means position and rotation as estimated by sensors (with some estimation of error, if you want to be nice :) ). For instance, with the novint falcon, all I get back is the pure encoder ticks from the motors. I then have to run that through a kinematics framework to get the relation of encoder values to arm angles to end effector position in cartesian coordinates. However, I provide access to both the raw encoder values and the kinematics system, and allow the user to snap in their own kinematics if they'd like. That's sort of the design position I was describing.

Have you checked out how the WiiMote deals with its HID reports in terms of accelerometer information? I've done a little bit of work with it (like, 2 years ago, so I don't remember much :) ) and was getting back what I thought was raw readings.

Re: I lost your terminology at 'pose' but...

[identity profile] wolfwings.livejournal.com 2009-05-05 07:51 pm (UTC)(link)
No direct relation, unfortunately. The WiiMote lacks a USB tethered mode, so it doesn't return a "HID Report Descriptor" as far as I've been able to find. The entire thing is low-level interfaces only, with various 'cooked' API's being returned.

PS3 SixAxis/Dual Shock 3? USB Tethered it "Just Works" once you send it one magic 'init message' as a normal USB HID Gamepad device. Thus why I was trying to stick to USB Gamepad mneumonics for interfacing the accelerometers. =^.^=

Off to do laundry, feel free to ring if you want to gap about this stuff over voice. Or SMS, I'll be off-line for about 2-3 hours.