 
  
  
  
  
The transformations needed for stereo viewing are simple rotations and translations. Computationally, the stereo viewing transforms happen last, after the viewing transform has been applied to put the viewer at the origin. Since the matrix order is the reverse of the order of operations, the viewing matricies should be applied to the modelview matrix stack first.
The order of matrix operations should be:
glMatrixMode(GL_MODELVIEW); glLoadIdentity(); /* the default matrix */ glPushMatrix() glDrawBuffer(GL_BACK_LEFT) glTranslatef(-IOD/2.f, 0, 0) glRotatef(-angle, 0.f, 1.f, 0.f) <viewing transforms> <modeling transforms> draw() glPopMatrix(); glPushMatrix() glDrawBuffer(GL_BACK_RIGHT) glTranslatef(IOD/2, 0., 0.) glRotatef(angle, 0.f, 1.f, 0.f) <viewing transforms> <modeling transforms> draw() glPopMatrix()
Where angle is the inverse tangent of the ratio between
the fusion distance and half of the interocular distance. 
 Each viewpoint is rotated towards the centerline halfway between the two
viewpoints.
Each viewpoint is rotated towards the centerline halfway between the two
viewpoints.
Another approach to implementing stereo transforms is to change the viewing tranform directly. Instead of adding an extra rotation and translation, use a separate call to gluLookAt() for each eye view. Move fusion distance along the viewing direction from the viewer position, and use that point for the center of interest of both eyes. Translate the eye position to the appropriate eye, then render the stereo view for the corresponding buffer.
The difficulty with this technique is finding the left/right eye axis to translate along from the viewer position to find the left and right eye viewpoints. Since your now computing the left/right eye axis in object space, it is no longer constrained to be the X axis. Find the left/right eye axis in object space by taking the cross product of the direction of view and the up vector.