Rotation help

A place to discuss everything related to Newton Dynamics.

Moderators: Sascha Willems, walaber

Rotation help

Postby Mark » Tue May 12, 2009 5:22 pm

I've attached a picture showing my problem. The cubes keeps resting with this small tilt on the pitch. Any ideas why is is? Value is between -10 -20.
You can also notice intersection between the cubes upon simulation.

Settings the trans matrix
Code: Select all
dMatrix matrix (dgPitchMatrix(0.0f * 3.1416f / 180.0f));
matrix = matrix * dgRollMatrix(0.0f * 3.1416f / 180.0f);
NewtonBodySetMatrix (rigidBodyBox[i], &matrix[0][0]);


Then later get the euler angles from newton
Code: Select all
dFloat eulerangles[3];
dFloat currentMatrix[16];
NewtonBodyGetMatrix(rigidBody, currentMatrix);
NewtonGetEulerAngle(currentMatrix, eulerangles);


I then straight apply them in my 3D world which is XYZ HPB right hand. Solver is set to "best". Otherwise the calculation is ok.

Any ideas?
Attachments
pic.jpg
pic.jpg (45.66 KiB) Viewed 3403 times
Mark
 
Posts: 10
Joined: Fri Mar 06, 2009 10:30 am

Re: Rotation help

Postby Julio Jerez » Tue May 12, 2009 10:17 pm

That thing shopudl never happens, there could be many reasonn for that,
-the inetial of the matrix is wrong and the box is action like a spherical body. Use teh funtion Calculate Inertia matrix or use the correct formula for the Box.
-you have a problems with euler angles.
use the matrix if you can.
If you engine uses quaternion, you can just use the function NetwonBodyGetRotation to get the quaternion instead of using eules.
also the debug display should show if the shape is oriented correctly
Julio Jerez
Moderator
Moderator
 
Posts: 12452
Joined: Sun Sep 14, 2003 2:18 pm
Location: Los Angeles

Re: Rotation help

Postby Mark » Wed May 13, 2009 4:06 am

Thanks Julio

Will try your suggestions and report back.
For the inertia I set it to 1.0f on xyz but will now test to calculate.
The wierd thing is, if I drop a cube on to my plane it rest fine, problem occurs when it has been rotating a bit.
Mark
 
Posts: 10
Joined: Fri Mar 06, 2009 10:30 am

Re: Rotation help

Postby Julio Jerez » Wed May 13, 2009 9:18 am

Mark wrote:For the inertia I set it to 1.0f on xyz but will now test to calculate..

I think that could be a problem, because depending on what the mass values and the box size is.
if the mass is to high then the box will look like a point mass (a black hold) that will resist spining very hard.
basically that object will resist to transfer its potencial energy acumulatted in the origin to kenetic linear and rotational energy.

if the mass is too low then it will look like a thin spherical shell and will rotate very eassy.
my guess is the you are using a heavy mass, and the body is a black hole.
you need to set a mass and and inertia that correlale more of less to the shape you are using.
use the funtion calculateintertia to get a unit inertia that you only need to scale by the mass.
see the demos.
Julio Jerez
Moderator
Moderator
 
Posts: 12452
Joined: Sun Sep 14, 2003 2:18 pm
Location: Los Angeles

Re: Rotation help

Postby Mark » Wed May 13, 2009 3:43 pm

Tried the calculation of the inertia, the rotation issue is still there but the simulation is better.

When tipping over on +X everything looks great. There's no intersection and good sim. Otherwise when tipping over on Z heading seems to go behave wrong and intersection.
I'm transfering from geteuler[0] into 3d engine X, geteuler[1] into 3d engine Y and geteuler[2] into 3d engine Z.
Found a Quat to euler conversion thing on the net from a graphics gem book but couldnt make it happen.
1.jpg
1.jpg (11.6 KiB) Viewed 3346 times

2.jpg
2.jpg (12.61 KiB) Viewed 3347 times

3.jpg
3.jpg (28.01 KiB) Viewed 3348 times
Mark
 
Posts: 10
Joined: Fri Mar 06, 2009 10:30 am

Re: Rotation help

Postby Julio Jerez » Thu May 14, 2009 7:34 am

I never seen that king of problem, but with newton.
you definitley have a bug in the matrix to euler convertion

do your engine uses euler angle?
do you patrices hae scale factors?

cann't you just use the matrix, or the quaternion you get for the Netwon Body?
Julio Jerez
Moderator
Moderator
 
Posts: 12452
Joined: Sun Sep 14, 2003 2:18 pm
Location: Los Angeles

Re: Rotation help

Postby Mark » Tue Jun 30, 2009 9:20 am

Julio Jerez wrote:I never seen that king of problem, but with newton.
you definitley have a bug in the matrix to euler convertion

do your engine uses euler angle?
do you patrices hae scale factors?

cann't you just use the matrix, or the quaternion you get for the Netwon Body?



Sorry for late reply!

I need to go to euler rotation order YXZ
As I understand euler in newton is XYZ?

Most likely here the problem lies?
Mark
 
Posts: 10
Joined: Fri Mar 06, 2009 10:30 am

Re: Rotation help

Postby Julio Jerez » Tue Jun 30, 2009 9:26 am

Mark wrote:I need to go to euler rotation order YXZ
As I understand euler in newton is XYZ?
Most likely here the problem lies?


yes definitlly that's the problem,
Is there a reason why you cannot use the 4 x4 Matrix, or the quaternion/position?
Using euler is a legacy that almost so one use anymore.
Julio Jerez
Moderator
Moderator
 
Posts: 12452
Joined: Sun Sep 14, 2003 2:18 pm
Location: Los Angeles

Re: Rotation help

Postby Mark » Tue Jun 30, 2009 11:11 am

That's the only input I can work with I'm afraid :(
Mark
 
Posts: 10
Joined: Fri Mar 06, 2009 10:30 am

Re: Rotation help

Postby JernejL » Tue Jun 30, 2009 12:41 pm

well, you could use a custom routine that converts matrix to angles in your desired order.
Help improving the Newton Game Dynamics WIKI
User avatar
JernejL
 
Posts: 1587
Joined: Mon Dec 06, 2004 2:00 pm
Location: Slovenia


Return to General Discussion

Who is online

Users browsing this forum: No registered users and 398 guests

cron