What does this error mean?

A place to discuss everything related to Newton Dynamics.

Moderators: Sascha Willems, walaber

What does this error mean?

Postby FSA » Thu Sep 27, 2012 1:45 pm

When i set a matrix with NewtonBodySetMatrix (RotationMatrix) I get an error:
dgBody.h Line 738
Expression: dgAbsf(val-1.0f) < 1.0e-5f
What does it mean?
User avatar
FSA
 
Posts: 322
Joined: Wed Dec 21, 2011 9:47 am

Re: What does this error mean?

Postby JoeJ » Thu Sep 27, 2012 3:25 pm

Either the axis you give are of nonuniform length, or the axis ar not perpendicular to each other.
Mostly this happens because nonuniform scale, see viewtopic.php?f=9&t=7334&start=15 for too much details about that :)
User avatar
JoeJ
 
Posts: 1494
Joined: Tue Dec 21, 2010 6:18 pm

Re: What does this error mean?

Postby FSA » Fri Sep 28, 2012 8:30 am

Oh. You're right...
That's my matrix
-1.#IO -1.#IO -1.#IO 0.000
-1.#IO -1.#IO -1.#IO 0.000
-1.#IO -1.#IO -1.#IO 0.000
0.000 0.000 0.000 1.000
:D I will chek where the error occurs...
User avatar
FSA
 
Posts: 322
Joined: Wed Dec 21, 2011 9:47 am

Re: What does this error mean?

Postby FSA » Fri Sep 28, 2012 9:42 am

Ok. My code to calculate the RotationMatrix:
Code: Select all
Vector3 m_vYAxis, m_vZAxis, m_vXAxis;
   m_vYAxis = Vector3(0.0f,1.0f,0.0f);
   m_vZAxis = Vector3(0.0f, 0.0f, 1.0f);
   m_vXAxis = Vector3(1.0f, 0.0f, 0.0f);

   // Rotation um die x-Achse
   Matrix mRotation( MatrixRotationX( rot.x ) );
   m_vYAxis = Vector3TransformNormal( m_vYAxis, mRotation );
   m_vZAxis = Vector3Cross( m_vXAxis, m_vYAxis );

   // Rotation um die y-Achse
   mRotation = MatrixRotationY( rot.y );
   m_vXAxis = Vector3TransformNormal( m_vXAxis, mRotation );
   m_vZAxis = Vector3Cross( m_vXAxis, m_vYAxis );

   // Rotation um die z-Achse
   mRotation = MatrixRotationZ( rot.z );
   m_vXAxis = Vector3TransformNormal( m_vXAxis, mRotation );
   m_vYAxis = Vector3TransformNormal( m_vYAxis, mRotation );

   return MatrixAxes( Vector3Normalize(m_vXAxis), Vector3Normalize(m_vYAxis), Vector3Normalize(m_vZAxis) );


Vector3TransformNormal:
Code: Select all
FF_API Vector3 Vector3TransformNormal( const Vector3& v,
                                    const Matrix& m )
{
   const float fLength = Vector3Length( v );
   if( fLength == 0.0f ) return v;

   const Matrix mTransform( MatrixTranspose( MatrixInvert( m ) ) );

   return Vector3Normalize( Vector3( v.x * mTransform.m11 + v.y * mTransform.m21 + v.z * mTransform.m31,
                                      v.x * mTransform.m12 + v.y * mTransform.m22 + v.z * mTransform.m32,
                              v.x * mTransform.m13 + v.y * mTransform.m23 + v.z * mTransform.m33 ) )
         * fLength;
}


MatrixRotationX/Y/Z create a Rotation Matrix. Vectro3Cross is the crossproduct.

Newton Crash when I change the Z Rotation.
Matrix:
0.997 0.000 0.075 0.000
0.000 0.989 0.149 0.000
-0.074 -0.149 0.986 0.000
0.000 0.000 0.000 1.000

Tanks
User avatar
FSA
 
Posts: 322
Joined: Wed Dec 21, 2011 9:47 am

Re: What does this error mean?

Postby JoeJ » Sat Sep 29, 2012 6:59 am

So what you want is to build a MAtrix from Euler Angles?
I assume your code produces a right handed instead of a left handed coordinate system (or vice versa) - or theres another error in it.
At least it's clear that it's very inefficient.

Try to replace it with code from here:
viewtopic.php?f=9&t=7237&p=49723&hilit=euler+angles#p49723
The order seems to be 0x012 for your case.

If you work with public engine (irrlicht ?), can you tell which one and what order is right?
At lot of people have trouble with that issue.
User avatar
JoeJ
 
Posts: 1494
Joined: Tue Dec 21, 2010 6:18 pm

Re: What does this error mean?

Postby FSA » Sun Nov 11, 2012 2:01 pm

I have let this problem be a problem :D
I have a new problem(with core 300).
In the picture you can see it. It happens when i pick a body and turn around with the body. To pick a body I add force and torque to the body. What is the problem? It hasn't happened with core 200.
Attachments
Error.png
Error.png (13.72 KiB) Viewed 34099 times
User avatar
FSA
 
Posts: 322
Joined: Wed Dec 21, 2011 9:47 am

Re: What does this error mean?

Postby Julio Jerez » Sun Nov 11, 2012 2:08 pm

that a really bad bug that should never ever happens. what are you doing to get that?

It means a body was at rest but somehow after it was deemed to be resting somehow places in the simulation.
I have never seem it happens?
Julio Jerez
Moderator
Moderator
 
Posts: 12452
Joined: Sun Sep 14, 2003 2:18 pm
Location: Los Angeles

Re: What does this error mean?

Postby FSA » Sun Nov 11, 2012 2:32 pm

Here a video: https://www.dropbox.com/s/t648v0gn3jyusni/Error.avi
I picked a body, walk with it, put it on an other body an then the error occurs.

2nd question: Is the friction set by default so high that bodys "glue" together? Video: https://www.dropbox.com/s/ijw3v9m821otbus/Record2.avi

And somtimes i get these errors(pictures). Next post the other Picture.
Attachments
Error2.PNG
Error2.PNG (19.09 KiB) Viewed 34095 times
User avatar
FSA
 
Posts: 322
Joined: Wed Dec 21, 2011 9:47 am

Re: What does this error mean?

Postby FSA » Sun Nov 11, 2012 2:32 pm

Next picture.

Here is my code:
Code: Select all
/*Callback*/
void BodyCallback (const NewtonBody* body, dFloat timestep, int threadIndex)
{
   NewtonBodyAddForce (body, g_vLinear);
   NewtonBodyAddTorque(body, g_vTorque);
}


I calculate force an torque with formula from JoeJ. I think it is the right calculation because with core 200 it worked.
Attachments
Error3.PNG
Error3.PNG (15.99 KiB) Viewed 34095 times
User avatar
FSA
 
Posts: 322
Joined: Wed Dec 21, 2011 9:47 am

Re: What does this error mean?

Postby Julio Jerez » Sun Nov 11, 2012 2:52 pm

No any of those error should be happening, something is very wrong. I you get an lru pout of sync then not else will work.
island row coun will fal because it will add more bodies than were not support to be consired. I cannot imagine how that happened, It is not possible unless you run the engine straight for over 200 years

when you say "I pick a body and walk with it" from where are you doing that? what ever it is is not right.

an not the friction in the get is 0.6 like is has always being the defualt in all version of the engine. I do not know what could that be.
Julio Jerez
Moderator
Moderator
 
Posts: 12452
Joined: Sun Sep 14, 2003 2:18 pm
Location: Los Angeles

Re: What does this error mean?

Postby FSA » Sun Nov 11, 2012 3:00 pm

I give you my code to calculate the force I add with NewtonBodyAddForce.
Code: Select all
if(m_pBody)
   {
      if(m_bFirstFrame)
      {
         m_bFirstFrame = false;
         m_mOffsetMatrix = MatrixIdentity();
         NewtonBodyGetMatrix(m_pBody, m_mOffsetMatrix);
         m_fCameraOffsetX = CamHandler->GetCameraAngleX();
      }

      // Body modification
      NewtonBodySetForceAndTorqueCallback(m_pBody, BodyCallback);
      NewtonBodySetContinuousCollisionMode(m_pBody, 1);

      //******************************
      // Translation
      Vector3      vVelocity;
      Vector3      vBodyPosition;
      Vector3      vCameraDir;
      Vector3      vCameraPos;
      Matrix      mMatrix;
      float      fMass, fA, fB, fC;

      NewtonBodyGetVelocity   (m_pBody, vVelocity);
      NewtonBodyGetMatrix      (m_pBody, mMatrix);
      NewtonBodyGetMassMatrix   (m_pBody, &fMass, &fA, &fB, &fC);
      vBodyPosition =   MatrixGetPosition(mMatrix);
      vCameraDir = CamHandler->GetCameraDir();
      vCameraPos = CamHandler->GetCameraPos();
      vCameraPos += vCameraDir * 25.0f;

      m_vLinear = ( (vCameraPos - vBodyPosition) * 20.0f - vVelocity ) * (fMass / fTime);

m_vLinear is the force i apply.(NewtonBodyAddForce (body, m_vLinear);

With "I move with it" I mean, when I walk the body is always on the same distance(see code).

Thank you for reading this and be so patient :)
User avatar
FSA
 
Posts: 322
Joined: Wed Dec 21, 2011 9:47 am

Re: What does this error mean?

Postby Julio Jerez » Sun Nov 11, 2012 3:05 pm

maybe set continue collsion have a bug, try not using that see if it work.
Julio Jerez
Moderator
Moderator
 
Posts: 12452
Joined: Sun Sep 14, 2003 2:18 pm
Location: Los Angeles

Re: What does this error mean?

Postby FSA » Sun Nov 11, 2012 3:24 pm

Yes that solved the problem! The problem with the high friction is also solved! So continues collision mode has a bug?
User avatar
FSA
 
Posts: 322
Joined: Wed Dec 21, 2011 9:47 am

Re: What does this error mean?

Postby Julio Jerez » Sun Nov 11, 2012 3:26 pm

Ha, so there must be a bug in CCD that is changes the LRU sincronization between the Collision system and the dynamics system.

can you send me a demo that I can try, one that I can turn CCD on and off?
Julio Jerez
Moderator
Moderator
 
Posts: 12452
Joined: Sun Sep 14, 2003 2:18 pm
Location: Los Angeles

Re: What does this error mean?

Postby FSA » Sun Nov 11, 2012 3:46 pm

Yes give me a moment...
User avatar
FSA
 
Posts: 322
Joined: Wed Dec 21, 2011 9:47 am

Next

Return to General Discussion

Who is online

Users browsing this forum: No registered users and 367 guests