point3.h File Reference

#include "GeomExport.h"
#include "maxheap.h"
#include "gfloat.h"
#include "assert1.h"
#include "point2.h"
#include <math.h>

Classes

class  Point3
 
class  Ray
 

Typedefs

typedef Point3 UVVert
 
typedef Point3 VertColor
 

Functions

float Length (const Point3 &)
 
float FLength (const Point3 &)
 
float LengthSquared (const Point3 &)
 
int MaxComponent (const Point3 &)
 
int MinComponent (const Point3 &)
 
Point3 Normalize (const Point3 &)
 
Point3 FNormalize (const Point3 &)
 
Point3 CrossProd (const Point3 &a, const Point3 &b)
 
__forceinline Point3 operator* (float f, const Point3 &a)
 
__forceinline Point3 operator* (const Point3 &a, float f)
 
__forceinline Point3 operator/ (const Point3 &a, float f)
 
__forceinline Point3 operator+ (const Point3 &a, float f)
 
__forceinline float DotProd (const Point3 &a, const Point3 &b)
 

Typedef Documentation

typedef Point3 UVVert
typedef Point3 VertColor

Function Documentation

float Length ( const Point3 v)
inline
Remarks
Returns the 'Length' of the point (vector). This is:

sqrt(v.x*v.x+v.y*v.y+v.z*v.z)
247  {
248  return v.Length();
249  }
float Length() const
Definition: point3.h:235
float FLength ( const Point3 v)
inline
Remarks
Returns the 'Length' of the point (vector) using a faster assembly language implementation for square root. This is:

Sqrt(v.x*v.x+v.y*v.y+v.z*v.z)
251  {
252  return v.FLength();
253  }
float FLength() const
Definition: point3.h:239
__forceinline float LengthSquared ( const Point3 v)
Remarks
The 'Length' squared of the point. This is v.x*v.x+v.y*v.y+v.z*v.z.
255  {
256  return v.LengthSquared();
257  }
float LengthSquared() const
Definition: point3.h:243
int MaxComponent ( const Point3 )
Remarks
Returns the component with the maximum absolute value. 0=x, 1=y, 2=z.
int MinComponent ( const Point3 )
Remarks
Returns the component with the minimum absolute value. 0=x, 1=y, 2=z.
Point3 Normalize ( const Point3 )
Remarks
Returns a normalized unit vector. This is a Point3 with each component divided by the point Length().
Point3 FNormalize ( const Point3 )
Remarks
Returns a normalized unit vector using faster assembly language code than that used by Normalize(). This is a Point3 with each component divided by the point Length().
Point3 CrossProd ( const Point3 a,
const Point3 b 
)
Remarks
This returns the cross product of the specified Point3's (vectors). The cross product of two vectors is a third vector, perpendicular to the plane formed by the two vectors.
__forceinline Point3 operator* ( float  f,
const Point3 a 
)
Remarks
Returns a Point3 that is the specified Point3 multiplied by the specified float.
319  {
320  return(Point3(a.x*f, a.y*f, a.z*f));
321  }
float y
Definition: point3.h:55
Definition: point3.h:51
float z
Definition: point3.h:55
float x
Definition: point3.h:55
__forceinline Point3 operator* ( const Point3 a,
float  f 
)
Remarks
Returns a Point3 that is the specified Point3 multiplied by the specified float.
325  {
326  return(Point3(a.x*f, a.y*f, a.z*f));
327  }
float y
Definition: point3.h:55
Definition: point3.h:51
float z
Definition: point3.h:55
float x
Definition: point3.h:55
__forceinline Point3 operator/ ( const Point3 a,
float  f 
)
Remarks
Returns a Point3 that is the specified Point3 divided by the specified float.
331  {
332  DbgAssert(f != 0.0f);
333  return(Point3(a.x/f, a.y/f, a.z/f));
334  }
float y
Definition: point3.h:55
Definition: point3.h:51
float z
Definition: point3.h:55
float x
Definition: point3.h:55
#define DbgAssert(expr)
Definition: assert1.h:74
__forceinline Point3 operator+ ( const Point3 a,
float  f 
)
Remarks
Returns a Point3 that is the specified Point3 with the specified floating point valued added to each component x, y, and z.
338  {
339  return(Point3(a.x+f, a.y+f, a.z+f));
340  }
float y
Definition: point3.h:55
Definition: point3.h:51
float z
Definition: point3.h:55
float x
Definition: point3.h:55
__forceinline float DotProd ( const Point3 a,
const Point3 b 
)
Remarks
Returns the dot product of two Point3s. This is the sum of each of the components multiplied together, element by element a.x*b.x+a.y*b.y+a.z*b.z

The dot product has the property of equaling the product of the magnitude (length) of the two vector times the cosine of the angle between them.
347  {
348  return(a.x*b.x+a.y*b.y+a.z*b.z);
349  }
float y
Definition: point3.h:55
float z
Definition: point3.h:55
float x
Definition: point3.h:55