CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

Quaternions.... Again...

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
curt2go



Joined: 21 Nov 2003
Posts: 200

View user's profile Send private message

Quaternions.... Again...
PostPosted: Sat Oct 22, 2016 7:34 pm     Reply with quote

Well I am still very stuck. I am able to calculate quaternions in my code from euler angles. I am using the XL and gyro to do this. I have been able to prove the quaternions with an online simulator. My problem is that I need to know direction of travel, angle of travel between the 2 quaternions, so I can see what angle the player is swinging at and if their angle and speed is changing during the swing. I have been struggling with this issue for 3 weeks now. I know its not totally a code question but that will come next when I need to code it.

For those of you who don't know what i am doing i am tracking a bat. The real problem is the batter will never hold the bat the same way. They can rotate it in their hand (rotating x) and then my zgyro and ygyro readings don't mean the same things.

Maybe quaternions is not the best way to go. If anyone can help I am at a loss here. Thank you, Thank you , Thank you to anyone who can shed some light.

24EP256GP206 running at 140MHz.
Ttelmah



Joined: 11 Mar 2010
Posts: 19552

View user's profile Send private message

PostPosted: Sun Oct 23, 2016 2:54 am     Reply with quote

What you are looking for is an IMU path generator. This is what takes feeds from an IMU unit (which at heart is what you have), and then works out how the IMU has physically moved.

Now before this you will need filtering.

I'd suggest starting with the code here:

<http://www.instk.org/Tk/index.html>

Particularly the path generators.

Provided you have some way of triggering a 'start', so the operations are only over a very short time, the results may well be acceptable.

However 'beware'. This is why projects like the Micro-PNT, take a long time to come to fruition. To make this work requires a lot of computation at very short intervals, and will drift quite rapidly on most sensors. Applications wanting such measurements at present, generally either have a physical reference for the position (so systems like 'glove' controllers for robots), or use imaging techniques to give an absolute position in space (systems like the 3D locators used by animation studios). Ones using just inertial sensing will always currently add another input that can give a reference (can just be magnetometers, or ultrasonic, IR, or radio references).

Big problem is integration error. To go from the 'rate of change' figures from the accelerometers and gyros, you integrate to get velocity, then have to integrate again to get position. Tiny errors at the first level, get compounded. These solid state sensors are not actually that accurate, and the results therefore will not be that good. You also need to know the initial conditions (position and velocity at the start). Sensors with lower drift, tend to be larger and more expensive...

For some references to various levels of project doing this, look at:

<http://www.intorobotics.com/accelerometer-gyroscope-and-imu-sensors-tutorials/>

The sheer amount of work, is why the Micro-PNT project was trying to integrate this into a single module, and why it has taken so long.....
curt2go



Joined: 21 Nov 2003
Posts: 200

View user's profile Send private message

PostPosted: Sun Oct 23, 2016 9:54 am     Reply with quote

I do believe I have everything working. I can run it all in real time and get many samples per second. I am integrating and combining with Accelerometer data with complimentary filter. My issue is that i have quaternions calculated but don't really know how to equate that to a movement. I can put multiple quaternions from a swing into the simulator and see the swing happen so I know my data is right but I don't know how to actually get that data out of the swing in to z movement( parallel to the ground) and y movement( perpendicular to the ground, up and down ) of the swing. Is this where the multiplication of quaternions comes in?

The big issue at the end of the day is knowing z and y regardless of how the batter is holding the bat and rotating it in his hands while swinging. Maybe i am over complicating things by using the quaternions. Let me know what you guys think. Thanks for any input.
Ttelmah



Joined: 11 Mar 2010
Posts: 19552

View user's profile Send private message

PostPosted: Sun Oct 23, 2016 12:10 pm     Reply with quote

Quaternions just specify rotations. This is why you need an initial position. You multiply the quaternions to give the 'total' rotation, and then use the initial direction vector, and rotate this by the final quaternion, to get the final direction.
curt2go



Joined: 21 Nov 2003
Posts: 200

View user's profile Send private message

PostPosted: Sun Oct 23, 2016 12:40 pm     Reply with quote

I have an initial position. Then I have the bat moving in different position but each time it moves the last position becomes the position that I compare to.

But the vectors and such you talk about are part of the stuff I am struggling with so you have suggestions but I need the math to figure this stuff out. Sorry for not knowing a lot here but its not my strength. Let me know if you can set me up with some math to figure this out. Maybe using quaternions is not the right approach to this for what I need. Thanks for any input.

Here is some raw data I am collecting Q1[0.45,0.88,-0.07,-0.05](initial position) Q2[0.44,0.86,0.04,-0.23](swung to the left) . I am checking the positional information with a simulator at a site http://quaternions.online/ which is really awesome because I just put them in and can see the exact orientation of my bat. Each quaternion shows me the position I am in at that time very accurately.

I need to be able from 2 quaternions like this 1) The direction of travel 2) The angle of travel 3) how far it rotated on the z axis 4) if it moved up or down on the y axis.
Ttelmah



Joined: 11 Mar 2010
Posts: 19552

View user's profile Send private message

PostPosted: Mon Oct 24, 2016 12:24 am     Reply with quote

Which is why I said you need a path generator.

The point about Quaternions, is that they are a small way of storing/handling rotations, with the marvellous feature that they allow multiple ones to be combined by simply multiplying. So you can have a list of ten (say), multiply them together to give a single quaternion, that defines the total rotation. Brilliant way of handling multiple rotations.

The path generator, is designed to take a number of motions from a IMU, and give the actual motion path, which is what you appear to want;.
curt2go



Joined: 21 Nov 2003
Posts: 200

View user's profile Send private message

PostPosted: Mon Oct 24, 2016 8:53 am     Reply with quote

Thanx. It seems I have some more work ahead of me.
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group