When one circle is touching
I have implemented the sphere collision point algorithm that is in http://nehe.gamedev.net/data/lessons/les...?lesson=30 for two circles that have equal masses. I took the momentum code from post 8 in http://www.phy.ntnu.edu.tw/ntnujava/index.php?topic=4.
This works well except that when one circle is touching both walls of a corner and its velocity is 0, and the other circle is pushing against this circle (after coming to rest on it after several bounces), it slowly sinks into it and becomes attached to it. How to correct this problem?
Code:
 (void) collision {
float relativeX = (ball.ballX + ball.ballSpeedX*deltaTime)  (ball2.ballX + ball2.ballSpeedX*deltaTime);
float relativeY = (ball.ballY + ball.ballSpeedY*deltaTime)  (ball2.ballY + ball2.ballSpeedY*deltaTime);
double elasticity = 1;
int step = 200;
if (sqrt(pow(relativeX, 2) + pow(relativeY, 2)) <= 2*RADIUS_FRACTION){
for (int i = 0; i < step; i++) {
if (sqrt(pow(relativeX*(i/step), 2) + pow(relativeY*(i/step), 2)) <= 2*RADIUS_FRACTION) {
ball.ballX += ball.ballSpeedX*deltaTime*((i1)/step);
ball.ballY += ball.ballSpeedY*deltaTime*((i1)/step);
ball2.ballY += ball2.ballSpeedX*deltaTime*((i1)/step);
ball2.ballX += ball2.ballSpeedY*deltaTime*((i1)/step);
}
}
double dx = ball.ballXball2.ballX, dy = ball.ballYball2.ballY;
double distance = sqrt(dx*dx+dy*dy);
double ax=dx/distance, ay=dy/distance;
double va1=(ball.ballSpeedX*ax+ball.ballSpeedY*ay), vb1=(ball.ballSpeedX*ay+ball.ballSpeedY*ax);
double va2=(ball2.ballSpeedX*ax+ball2.ballSpeedY*ay), vb2=(ball2.ballSpeedX*ay+ball2.ballSpeedY*ax);
double vaP1=va1 + (1+elasticity)*(va2va1)/2;
double vaP2=va2 + (1+elasticity)*(va1va2)/2;
ball.ballSpeedX=vaP1*axvb1*ay; ball.ballSpeedY=vaP1*ay+vb1*ax;
ball2.ballSpeedX=vaP2*axvb2*ay; ball2.ballSpeedY=vaP2*ay+vb2*ax;
}
}
Sounds like floating point error, which is a classic physics simulation problem. Too hard to explain in a forum post, but if that's the problem then you basically wind up adding a constant but small amount of opposite force (friction/drag/etc) to stabilize the integration against the floating point error.
[Adding] There are lots of good books on this topic, which are probably better to work with than stitching online tutorials together. Or you might use a thirdparty physics library like chipmunk to do the deed for you.
[Adding] There are lots of good books on this topic, which are probably better to work with than stitching online tutorials together. Or you might use a thirdparty physics library like chipmunk to do the deed for you.
A tutorial would be nicer, as I could not find any books about floatingpoint errors. I found some books about computational physics which might have this topic, but it is not nice to buy a book just to correct this small problem (the game is working well otherwise).
Quote:I could not find any books about floatingpoint errorsThis is where it helps to have a basic fundamental knowledge of computer science. If you want to understand why floating point numbers are not 100% precise in all cases, I suggest reading http://en.wikipedia.org/wiki/Floating_point for at least a basic understanding
I understand.
Quote:In base2 only rationals with denominators that are powers of 2 (such as 1/2 or 3/16) are terminating. Any rational with a denominator that has a prime factor other than 2 will have an infinite binary expansion. This means that numbers which appear to be short and exact when written in decimal format may need to be approximated when converted to binary floatingpoint.However, the variables have such high magnitude in my game that floatingpoint errors do not have an effect on it. I think that the problem is that when one circle is next to a wall and the other collides with it, it gains the other's momentum and penetrates the wall, so that its position gets updated as 2*penetration. Its new position is partly inside the other circle, as this has stayed at the collision point. Could you point to a tutorial about proper collision detection so that I could solve this problem, or is the best thing to read Game Physics Engine Development, Game Physics or RealTime Collision Detection? (which is best?)
I've read Game Physics Engine Development. It's for 3D, although you'll find a lot of the information applicable to 2D. I don't know if I'd recommend it for what you're trying to do, but I can say it's a pretty good book. The projects are in C++ but it's one of those rare occasions where the author does a decent job of keeping the code fairly clean and straightfoward and relatively portable. I haven't read the other ones.
Possibly Related Threads...
Thread:  Author  Replies:  Views:  Last Post  
Ball Bouncing in a circle  strikerjax  6  8,193 
Jul 6, 2009 02:39 PM Last Post: strikerjax 

2D reflecting a point off a circle  Joseph Duchesne  1  4,022 
Oct 23, 2004 08:05 PM Last Post: MattDiamond 