A place to discuss everything related to Newton Dynamics.
	Moderators: Sascha Willems, walaber
	
		
		
			
			
			 by Gianluca » Fri Sep 05, 2008 4:53 am
by Gianluca » Fri Sep 05, 2008 4:53 am 
			
			Hello everybody,
probably I use the NewtonConvexCollisionCalculateInertialMatrix in the wrong way... this is the code:
- Code: Select all
-    real inertia[3];
 real centre[3] = { 0, 0, 0 };
 NewtonConvexCollisionCalculateInertialMatrix( priv->collision, inertia, centre );
 NewtonBodySetMassMatrix( priv->body, mass, inertia[0], inertia[1], inertia[2] );
 
mass is calculated manually... because objects are small it vary within [0.1, 1.0].
Also the dimensions of the objects are quite small.
I tried also to scale dimensions and masses by 10 ... but the problem persists.
The problem is that with inertia calculate above the joint behaves very strange (often the simulation is near to explode)
but if I set the inertia to 1.0 for all values
- Code: Select all
-    NewtonBodySetMassMatrix( priv->body, mass, 1.0, 1.0, 1.0 );
 
It behaves correctly.
Suggestions ???
Thanks,
Gianluca
 
		
			
			- 
				Gianluca
			
-  
- Posts: 53
- Joined: Fri Nov 11, 2005 4:37 am
- Location: Rome - Italy
- 
				
			
 
	 
	
	
		
		
			
			
			 by Julio Jerez » Fri Sep 05, 2008 9:19 am
by Julio Jerez » Fri Sep 05, 2008 9:19 am 
			
			can you post a sample of one objects?
			
		 
		
			
			- 
				Julio Jerez
			
- Moderator
  
-  
- Posts: 12452
- Joined: Sun Sep 14, 2003 2:18 pm
- Location: Los Angeles
- 
				
			
 
	 
	
	
		
		
			
			
			 by Gianluca » Mon Sep 08, 2008 6:55 am
by Gianluca » Mon Sep 08, 2008 6:55 am 
			
			Yes, of course.
This is the code when I create an object:
- Code: Select all
-    priv->collision = NewtonCreateSphere( worldpriv->world, radiusv, radiusv, radiusv, 0 );
 priv->body = NewtonCreateBody( worldpriv->world, priv->collision );
 NewtonBodySetAutoSleep( priv->body, 0 );
 real inertia[3];
 real centre[3] = { 0, 0, 0 };
 NewtonConvexCollisionCalculateInertialMatrix( priv->collision, inertia, centre );
 NewtonBodySetMassMatrix( priv->body, 1.0, inertia[0], inertia[1], inertia[2] );
 NewtonBodySetUserData( priv->body, this );
 NewtonBodySetLinearDamping( priv->body, 0.0 );
 wVector zero = wVector(0,0,0,0);
 NewtonBodySetAngularDamping( priv->body, &zero[0] );
 NewtonBodySetAutoSleep( priv->body, 0 );
 NewtonReleaseCollision( worldpriv->world, priv->collision );
 // Sets the signal-wrappers callback
 NewtonBodySetTransformCallback( priv->body, (PhyObjectPrivate::setTransformHandler) );
 NewtonBodySetForceAndTorqueCallback( priv->body, (PhyObjectPrivate::applyForceAndTorqueHandler) );
 
The only row that changes when I create different object is the first.
Thank you,
Gianluca.
 
		
			
			- 
				Gianluca
			
-  
- Posts: 53
- Joined: Fri Nov 11, 2005 4:37 am
- Location: Rome - Italy
- 
				
			
 
	 
	
	
		
		
			
			
			 by agi_shi » Wed Dec 24, 2008 4:47 pm
by agi_shi » Wed Dec 24, 2008 4:47 pm 
			
			Not sure, but I do NewtonBodySetMassMatrix(body, mass, i[0] * mass, i[1] * mass, i[2] * mass) (that is, multiply the inertia by the pass) - does that change anything?
			
		 
		
			
			- 
				agi_shi
			
-  
- Posts: 263
- Joined: Fri Aug 17, 2007 6:54 pm
 
	 
	
	
		
		
			
			
			 by Julio Jerez » Wed Dec 24, 2008 4:55 pm
by Julio Jerez » Wed Dec 24, 2008 4:55 pm 
			
			this is the correct way
 NewtonBodySetMassMatrix( priv->body, mass, mass * inertia[0], mass * inertia[1], mass * inertia[2] );
			
		 
		
			
			- 
				Julio Jerez
			
- Moderator
  
-  
- Posts: 12452
- Joined: Sun Sep 14, 2003 2:18 pm
- Location: Los Angeles
- 
				
			
 
	 
	
	
	
	Return to General Discussion
	
	Who is online
	Users browsing this forum: No registered users and 428 guests