Vector3.mesa
Michael Plass, August 4, 1982 11:58 am
Doug Wyatt, July 3, 1984 12:27:42 pm PDT
DIRECTORY
Real USING [SqRt];
Vector3: CEDAR DEFINITIONS
IMPORTS Real
~ BEGIN
VEC: TYPE ~ RECORD[x, y, z: REAL];
Add: PROC[a, b: VEC] RETURNS[VEC];
InlineAdd: PROC[a, b: VEC] RETURNS[VEC] ~ INLINE { RETURN[[a.x+b.x, a.y+b.y, a.z+b.z]] };
Vector sum, a+b.
Sub: PROC[a, b: VEC] RETURNS[VEC];
InlineSub: PROC[a, b: VEC] RETURNS[VEC] ~ INLINE { RETURN[[a.x-b.x, a.y-b.y, a.z-b.z]] };
Vector difference, a-b.
Neg: PROC[a: VEC] RETURNS[VEC];
InlineNeg: PROC[a: VEC] RETURNS[VEC] ~ INLINE { RETURN[[-a.x, -a.y, -a.z]] };
Vector complement, -a.
Mul: PROC[a: VEC, s: REAL] RETURNS[VEC];
InlineMul: PROC[a: VEC, s: REAL] RETURNS[VEC] ~ INLINE { RETURN[[a.x*s, a.y*s, a.z*s]] };
Product of vector a and scalar s.
Div: PROC[a: VEC, s: REAL] RETURNS[VEC];
InlineDiv: PROC[a: VEC, s: REAL] RETURNS[VEC] ~ INLINE { RETURN[[a.x/s, a.y/s, a.z/s]] };
Equivalent to Mul[a, 1/s].
SqrMag: PROC[a: VEC] RETURNS[REAL];
InlineSqrMag: PROC[a: VEC] RETURNS[REAL] ~ INLINE { RETURN[a.x*a.x+a.y*a.y+a.z*a.z] };
Square of the magnitude of a.
Mag: PROC[a: VEC] RETURNS[REAL];
InlineMag: PROC[a: VEC] RETURNS[REAL] ~ INLINE { RETURN[Real.SqRt[InlineSqrMag[a]]] };
Magnitude of a.
Dot: PROC[a, b: VEC] RETURNS[REAL];
InlineDot: PROC[a, b: VEC] RETURNS[REAL] ~ INLINE { RETURN[a.x*b.x+a.y*b.y+a.z*b.z] };
Dot (inner) product of a and b.
Cross: PROC[a, b: VEC] RETURNS[VEC];
Cross (outer) product of a and b.
Unit: PROC[a: VEC] RETURNS[VEC];
InlineUnit: PROC[a: VEC] RETURNS[VEC] ~ INLINE { RETURN[InlineDiv[a, InlineMag[a]]] };
Unit vector in the direction of a.
END.