Side of the Plane

Let’s suppose that we have a plane Ax + By + Cz + D = 0. It’s normal is (A,B,C). Which side do we assume to be ‘inside’ halfspace given by this plane ? Points which are on the side pointed by the normal (distance to plane is positive) or points on the other side of normal (distance to plane[1] is negative) ?
At first it was natural for me that points with positive distance (pointed to by normal) are ‘inside’. But then I started to wonder - if you look at the plane as part of mesh, ‘inside’ of mesh is probably in opposite direction to normal…

My question for ‘wise heads’ here: Which way I should use for all computations ? For a point to be between number of planes, should it’s distance[1] from every one be negative or positive ?

[1] distance = Ax+By+Cx+D for point (x,y,z)

There is no definitive answer to that. It really depends on what you are trying to achieve. I can easily picture two scenarios which will need positive and negative normals.

  1. positive - Wanna use plane to "see’ what is inside space enclosed by planes (since you mentiones halh-space case)
    2 negative - say lighting normals for box from outside

This is case dependent scenario .

If you make this change then please refactor the polygon clipping code, it was a bitch to get working and depends on the halfspaces as they currently work.

OpenGL has a function that deals with planes and halfspaces - glClipPlane(…). Description of this function says:

[quote]If the dot product of the eye coordinates of a vertex with the stored plane equation components is positive or zero, the vertex is in with respect to that clipping plane. Otherwise, it is out.
[/quote]
Here is a description from http://wwwcsif.cs.ucdavis.edu/~jankunm/175/WOGL_clipping_functions.html:

[quote]Clipping Planes
A clipping plane divides space into two, half on one side of the plane, half on the other. The plane has a front and a back side, the front side is the one with the plane’s normal vector. So space gets divided into a front halfspace and a back halfspace. Let’s define “inside” to mean something is in the front halfspace. In 3D space, the one we’re used to, a plane is defined by this plane equation.
Ax + By + Cz + D = 0
We can store the plane coefficients in a vector (A,B,C,D). To determine whether or not a point is inside the front halfspace of a plane, we find the distance from the point (xo, yo, zo) to the plane (A,B,C,D).
distance = Axo + Byo + Czo + D
If the distance is positive, the point is in the front halfspace, inside. If the distance is zero, the point lies on the plane. If the distance is negative, the points lies in the back halfspace, outside.

In 4D homogeneous space, planes are specified by equations of this form.
Px + Qy + Rz + Sw = 0
Again, we can store the plane coefficients as vectors (P,Q,R,S). To see if a point (xo, yo, zo, wo) is in the front halfspace, on the plane, or in the back halfspace, we take the dot product of the point and the plane’s coefficient vector. This number isn’t really a distance, but at times it might help to think of it as such.
dot product = Pxo + Qyo + Rzo + Swo
Again, inside is > 0, on the plane = 0, outside is < 0.
[/quote]
I think we should choose definition of In/Out from OpenGL specs just to aboid one more difference and be able to point peolpe to OpenGL docs.

Yuri