A place to discuss everything related to Newton Dynamics.
	Moderators: Sascha Willems, walaber
	
		
		
			
			
			 by Executor » Sat Sep 05, 2009 6:10 pm
by Executor » Sat Sep 05, 2009 6:10 pm 
			
			Ok, i create another complex example tomorrow. It will show that compound collide fine, but convex cast not be work.
			
		 
		
			
			- 
				Executor
			
-  
- Posts: 25
- Joined: Fri Sep 04, 2009 7:01 am
 
	 
	
	
		
		
			
			
			 by Julio Jerez » Sat Sep 05, 2009 7:45 pm
by Julio Jerez » Sat Sep 05, 2009 7:45 pm 
			
			Ok, i see now. It looks like there is a bug, but I can not figure out what it is.
you are right if I make the compound with just one box teh convex cast fail, I do not know why teh collision do no fail.
I iwll invertigate more.
I am guessing it is because som how teh matrix on teh compound shape is no updated atteh tiem of the convex cast call, but It doe no look lihe that 
anyway I will find out and let you know.
			
		 
		
			
			- 
				Julio Jerez
			
- Moderator
  
-  
- Posts: 12452
- Joined: Sun Sep 14, 2003 2:18 pm
- Location: Los Angeles
- 
				
			
 
	 
	
	
		
		
			
			
			 by Julio Jerez » Sat Sep 05, 2009 10:09 pm
by Julio Jerez » Sat Sep 05, 2009 10:09 pm 
			
			Wow you discovered the biggest bug I can think off in the engine.
for what i can see this bug was there since I added the mutithreaded code.
This will cause a lot of collision problem on amost any collison shape with a rotation matrix that was no identity.
not only that in sone case rare case it will generate bad collision.
This happen because when I added the mutithreade code, I collect all of the collion pair in a list.
then I divide them in groups of more or less equal size and each group is solved independetly in a thread.
however this can cause a problems, say that a body is collidon with another body and that pair is in one group, but the same bopdy is also colliding with another body and it is in another group.
if this is the case, when the collision is solved the global matrix of the collision shape must be calculted, and I caculate them in the body.
here is the Bug, if a shape is a compound then matrix will be mutiply by the offset and it willcshage value in one thread.
to solve that, I use a proxi body that copy the values that are used in the collision from the body before calling teh contact solver, then those valuse can be modifired at will.
however In the contact solver, I still was reading the matrix from the body and not from the proxi. 
In this case the code was reading the matrix of the parent shape and not from the child shape, even though the matrix of the child shape is correct in the proxi.
I fixed but I need to test it well before I release this.
Because I still do not beleive that such huge bug was there and no body notices.
			
		 
		
			
			- 
				Julio Jerez
			
- Moderator
  
-  
- Posts: 12452
- Joined: Sun Sep 14, 2003 2:18 pm
- Location: Los Angeles
- 
				
			
 
	 
	
	
		
		
			
			
			 by Executor » Sun Sep 06, 2009 2:41 am
by Executor » Sun Sep 06, 2009 2:41 am 
			
			A new example is canceled. 

I am glad that we found a reason of the problem.
Waiting for a solution in next releases... 

Thanks.
P.S. There is a problem with raycast too, but I still dont know about Newton already had this bug or I did it. I will announce later until I understand.
 
		
			
			- 
				Executor
			
-  
- Posts: 25
- Joined: Fri Sep 04, 2009 7:01 am
 
	 
	
	
		
		
			
			
			 by Julio Jerez » Sun Sep 06, 2009 9:04 am
by Julio Jerez » Sun Sep 06, 2009 9:04 am 
			
			No this do not affect ray cast.
			
		 
		
			
			- 
				Julio Jerez
			
- Moderator
  
-  
- Posts: 12452
- Joined: Sun Sep 14, 2003 2:18 pm
- Location: Los Angeles
- 
				
			
 
	 
	
	
		
		
			
			
			 by Executor » Thu Sep 10, 2009 1:45 pm
by Executor » Thu Sep 10, 2009 1:45 pm 
			
			In 2.09 all ok! Cool! 

Thanks.
 
		
			
			- 
				Executor
			
-  
- Posts: 25
- Joined: Fri Sep 04, 2009 7:01 am
 
	 
	
	
	
	Return to General Discussion
	
	Who is online
	Users browsing this forum: No registered users and 417 guests