please dont rip this site

Method IO Graphics PART01.SH

# ! /bin/sh
# This is a shell archive.  Remove anything before this line, then unpack
# it by saving it into a file and typing "sh file".  To overwrite existing
# files, type "sh file -c".  You can also feed this as standard input via
# unshar, or by typing "sh <file", e.g..  If this archive is complete, you
# will see the following message at the end:
#		"End of archive 1 (of 5)."
# Contents:  2DClip 2DClip/Makefile 2DClip/box.h 2DClip/line.h AALines
#   AALines/00README AALines/AALines.h AALines/AAMain.c
#   AALines/LongConst.h AALines/Makefile AALines/utah.h BinRec.c
#   CircleRect.c DigitalLine.c FastJitter.c FixedTrig.c HSLtoRGB.c
#   Hash3D.c HypotApprox.c MANIFEST MatrixOrtho.c PixelInteger.c
#   PolyScan PolyScan/Makefile README RGBTo4Bits.c RayBox.c
#   RayPolygon.c Sturm Sturm/Makefile Sturm/solve.h Sturm/util.c
#   TransBox.c ViewTrans.c
# Wrapped by craig@weedeater on Wed Dec 12 20:45:12 1990
PATH=/bin:/usr/bin:/usr/ucb ; export PATH
if test ! -d '2DClip' ; then
    echo shar: Creating directory \"'2DClip'\"
    mkdir '2DClip'
fi
if test -f '2DClip/Makefile' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'2DClip/Makefile'\"
else
echo shar: Extracting \"'2DClip/Makefile'\" \(212 characters\)
sed "s/^X//" >'2DClip/Makefile' <<'END_OF_FILE'
XLIBFILE = ../gemslib.a
X
XCFLAGS = $(GENCFLAGS) -I..
X
XOFILES = clip.o bio.o cross.o
X
X$(LIBFILE): $(OFILES)
X	ar rcs $(LIBFILE) $(OFILES)
X
Xclean:
X	/bin/rm -f clip.o bio.o cross.o
X
X$(OFILES): line.h ../GraphicsGems.h
END_OF_FILE
if test 212 -ne `wc -c <'2DClip/Makefile'`; then
    echo shar: \"'2DClip/Makefile'\" unpacked with wrong size!
fi
# end of '2DClip/Makefile'
fi
if test -f '2DClip/box.h' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'2DClip/box.h'\"
else
echo shar: Extracting \"'2DClip/box.h'\" \(186 characters\)
sed "s/^X//" >'2DClip/box.h' <<'END_OF_FILE'
X
X/* 
X * file box.h
X *	a short include file is better then no include file
X */
Xtypedef	struct	{		/* guess what this is		*/
X	long	_lowx;
X	long	_lowy;
X	long	_highx;
X	long	_highy;
X} BOX;
X
X 
END_OF_FILE
if test 186 -ne `wc -c <'2DClip/box.h'`; then
    echo shar: \"'2DClip/box.h'\" unpacked with wrong size!
fi
# end of '2DClip/box.h'
fi
if test -f '2DClip/line.h' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'2DClip/line.h'\"
else
echo shar: Extracting \"'2DClip/line.h'\" \(1795 characters\)
sed "s/^X//" >'2DClip/line.h' <<'END_OF_FILE'
X
X/*
XTwo-Dimensional Clipping: A Vector Based Approach
Xby Hans Spoelder and Fons Ullings
Xfrom "Graphics Gems", Academic Press, 1990
X*/
X
X
X/*
X * file line.h
X * 	contains major definitions for the clipping routines
X *
X */
X#define	NFAC		10		/* discrete measure	*/
X	
X#define	SCALE		(1 << NFAC)	/* 1024 points/cm	*/
X#define	TO_INT(X)	((int)((X)*SCALE))
X#define	TO_FLT(X)	(((float)(X))/SCALE)
X
X#define	COINCIDE		1		/* what do the lines do	*/
X#define	PARALLEL		2
X#define	CROSS		3
X#define	NO_CROSS		4
X
X#define	STD			0		/* crossing types	*/
X#define	DELAY		1
X
X#define	CLIP_NORMAL	1
X
Xtypedef	struct	{		/* holds a point	*/
X	long	_x;			/* holds x coordinate	*/
X	long	_y;			/* holds y coordinate	*/
X} POINT;
X
Xtypedef	struct	{		/* holds a cross point	*/
X	POINT	_p;			/* holds the solution	*/
X	short	_type;		/* more information	*/
X} CLIST;
X	
Xstruct	segment	{			/* holds a segment	*/
X	POINT	_from;			/* start coordinates	*/
X	POINT	_to;			/* stop coordinates	*/
X	struct	segment	*_next;
X	struct	segment	*_prev;
X};
X
X
X#define	SEGMENT		struct segment
X
Xstruct	contour {			/* holds a contour	*/
X	short	_no;			/* contour counter	*/
X	short	_status;			/* holds information	*/
X	short	_cnt;			/* number of elements	*/
X	SEGMENT	*_s;			/* the segments		*/
X	struct	contour *_next;	/* linked list		*/
X	long	_minx;			/* coordinates of box	*/
X	long	_miny;
X	long	_maxx;
X	long	_maxy;
X};
X
X#define	CONTOUR		struct contour
X
X#define	ACTIVE		01		/* polygon attributes	*/
X#define	NORMAL		02
X
X#define	SET_ON(p)	((p)->_status |=  ACTIVE)
X#define	SET_NORMAL(p)	((p)->_status |= NORMAL)
X
X#define	SET_OFF(p)	((p)->_status &= ~ACTIVE)
X#define	SET_INVERSE(p)	((p)->_status &= ~NORMAL)
X
X#define	IS_ON(p)	((p)->_status & ACTIVE)
X#define	IS_NORMAL(p)	((p)->_status & NORMAL)
X
Xextern	CONTOUR	*CL;
X
XCONTOUR	*get_contour_ptr();
X
Xextern	short	C_COUNT;
X 
END_OF_FILE
if test 1795 -ne `wc -c <'2DClip/line.h'`; then
    echo shar: \"'2DClip/line.h'\" unpacked with wrong size!
fi
# end of '2DClip/line.h'
fi
if test ! -d 'AALines' ; then
    echo shar: Creating directory \"'AALines'\"
    mkdir 'AALines'
fi
if test -f 'AALines/00README' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'AALines/00README'\"
else
echo shar: Extracting \"'AALines/00README'\" \(1074 characters\)
sed "s/^X//" >'AALines/00README' <<'END_OF_FILE'
XThis group of files is a simple demonstration of an anti-aliased line
Xrenderer from _Grahpics_Gems_.  Files in the release are:
X
X  00README -- This information file.
X
X  Makefile -- Makefile for creating the demo executable.
X
X  AALines.h -- Include file for demo source files.
X
X  AALines.c -- Rendering code from _Grahpics_Gems_ pages 690-693.
X
X  AATables.c -- Initialization code for frame buffer and lookup tables.
X
X  AAMain.c -- Calling routine for the renderer.
X
X  utah.h -- Include file for friendly Utah RLE front end.
X
X  utah.c -- Source for friendly Utah RLE front end.
X
XAs it is written, the program dumps its frame buffer to a Utah RLE
Xfile.  You need to obtain the Utah RLE library from another source;
Xtry the following FTP sites:
X
X        cs.utah.edu (128.110.4.21)
X        weedeater.math.yale.edu (130.132.23.17)
X        freebie.engin.umich.edu (35.2.68.23)
X
XIt should be fairly easy to dump the frame buffer to another type
Xof file, or straight to a display device.  See AAMain.c.
X
XHave fun.
X
X    -- Kelvin Thompson, 18 August 1990
X       kelvin@cs.utexas.edu
END_OF_FILE
if test 1074 -ne `wc -c <'AALines/00README'`; then
    echo shar: \"'AALines/00README'\" unpacked with wrong size!
fi
# end of 'AALines/00README'
fi
if test -f 'AALines/AALines.h' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'AALines/AALines.h'\"
else
echo shar: Extracting \"'AALines/AALines.h'\" \(1371 characters\)
sed "s/^X//" >'AALines/AALines.h' <<'END_OF_FILE'
X/*  FILENAME:  AALines.h  [revised 17 AUG 90]
X
X    AUTHOR:  Kelvin Thompson
X
X    DESCRIPTION:  Symbols and globals for the anti-aliased line
X      renderer.
X
X    #INCLUDED IN:
X      AAMain.c -- Calling routine for renderer.
X      AATables.c -- Initialization routines for lookup tables.
X      AALines.c -- Rendering code.
X*/
X
X/* frame buffer to hold the anti-aliased line */
X#define xpix 60
X#define ypix 60
Xextern char *fbuff;
X
X/* macros to access the frame buffer */
X#define PIXADDR(xx,yy) (fbuff+(yy)*xpix+(xx))
X#define PIXINC(dx,dy)  ((dy)*xpix+(dx))
X
X/* fixed-point data types and macros */
Xtypedef int FX;
Xtypedef unsigned int UFX;
X#define FX_FRACBITS 16  /* bits of fraction in FX format */
X#define FX_0        0   /* zero in fixed-point format */
X#define FLOAT_TO_FX(flt)  ((FX)((flt)*(1<<FX_FRACBITS)+0.5))
X
X/* some important constants */
X#define PI      3.1415926535897932384626433832795028841971693993751
X#define SQRT_2  1.4142135623730950488016887242096980785696718753769
X
X/* square-root function globals */
Xextern UFX *sqrtfunc;
Xextern int sqrtcells;
Xextern int sqrtshift;
X#define SQRTFUNC(fxval)  (sqrtfunc[ (fxval) >> sqrtshift ])
X
X/* AA globals */
Xextern float line_r;  /* line radius */
Xextern float pix_r;   /* pixel radius */
Xextern FX *coverage;
Xextern int covercells;
Xextern int covershift;
X#define COVERAGE(fxval) (coverage[ (fxval) >> covershift ])
END_OF_FILE
if test 1371 -ne `wc -c <'AALines/AALines.h'`; then
    echo shar: \"'AALines/AALines.h'\" unpacked with wrong size!
fi
# end of 'AALines/AALines.h'
fi
if test -f 'AALines/AAMain.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'AALines/AAMain.c'\"
else
echo shar: Extracting \"'AALines/AAMain.c'\" \(1578 characters\)
sed "s/^X//" >'AALines/AAMain.c' <<'END_OF_FILE'
X/*  FILENAME:  AAMain.c  [revised 17 AUG 90]
X
X    AUTHOR:  Kelvin Thompson
X
X    DESCRIPTION:  Calling routine for anti-aliased line renderer.
X      This routine calls the line renderer to draw a single
X      anti-aliased line into a small frame buffer.  The
X      routine then dumps the frame buffer to a Utah RLE file
X      'anti.rle'.
X
X    LINK WITH:
X      utah.h -- Definitions for friendly Utah RLE front end.
X      AALines.h -- Shared tables, symbols, etc. for renderer.
X      AALines.c -- Rendering code.
X      AATables.c -- Table initialization.
X*/
X
X#include <stdio.h>
X#include <math.h>
X#include "AALines.h"
X#include "utah.h"
X
X
X
Xmain ( argc, argv )
Xint argc;
Xchar *argv[];
X{
Xint i;
Xchar *scanptr;
Xint x1,y1,x2,y2;
X
X/* initialize frame buffer and look-up tables */
XAnti_Init();
X
X/* set line endpoints */
Xx1 =  2;  y1 =  2;
Xx2 = 25;  y2 = 55;
X
X/* render anti-aliased line to a frame buffer */
XAnti_Line( x1,y1, x2,y2 );
X
X
X/* The code below dumps the frame buffer to a Utah RLE file.
X** It should be pretty easy to rewrite so that it dumps to
X** any other kind of output file...or straight to a display
X** device.  The frame buffer is an array of characters
X** starting at 'fbuff' with size 'xpix' by 'ypix'.  */
X
X  {
X  /* thanks to A.T. Campbell for the friendly front end */
X  UTAH_FILE *picout;
X  picout = utah_write_init( "anti.rle", xpix, ypix );
X  if ( picout == NULL )
X    { perror("anti.rle");  exit(1); }
X  for ( i=0; i<ypix; i++ )
X    {
X    scanptr = &fbuff[i*xpix];
X    utah_write_rgb( picout, scanptr, scanptr, scanptr );
X    }
X  utah_write_close(picout);
X  }
X}
END_OF_FILE
if test 1578 -ne `wc -c <'AALines/AAMain.c'`; then
    echo shar: \"'AALines/AAMain.c'\" unpacked with wrong size!
fi
# end of 'AALines/AAMain.c'
fi
if test -f 'AALines/LongConst.h' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'AALines/LongConst.h'\"
else
echo shar: Extracting \"'AALines/LongConst.h'\" \(1701 characters\)
sed "s/^X//" >'AALines/LongConst.h' <<'END_OF_FILE'
X/*  FILENAME:   LongConst.h  [revised 18 AUG 90]
X
X    AUTHOR:  Kelvin Thompson
X
X    DESCRIPTION:  High-precision constants.  If this file is included
X      in the same file as GraphicsGems.h, this file must come *after*
X      GraphicsGems.h.  (It's okay to use this file without GraphicsGems.h.)
X
X        The standard _Graphics_Gems_ include file has some constants
X      that do not have full double-precision accuracy.  This file
X      has the constants to a ridiculously high precision.  See pages
X      434-435 of _Graphics_Gems_.  I got the constants from Mathematica.
X      
X        Also, this file has a constant and macro for finding the base-two
X      logarithm of a number.
X*/
X
X/* prevent multiple inclusion */
X#ifndef __LONGCONST_H__
X#define __LONGCONST_H__
X
X/* first get rid of stuff from GraphicsGems.h */
X#undef PI
X#undef PITIMES2
X#undef PIOVER2
X#undef E
X#undef SQRT2
X#undef SQRT3
X#undef GOLDEN
X#undef DTOR
X#undef RTOD
X
X/* re-define basic constants with high precision */
X#define PI     3.141592653589793238462643383279502884197169399375105820975
X#define E      2.718281828459045235360287471352662497757247093699959574967
X#define SQRT2  1.414213562373095048801688724209698078569671875376948073177
X#define SQRT3  1.732050807568877293527446341505872366942805253810380628056
X#define GOLDEN 1.618033988749894848204586834365638117720309179805762862135
X
X/* re-define derived constants */
X#define PITIMES2  (2.0*PI)
X#define PIOVER2   (0.5*PI)
X#define DTOR      (PI/180.0)
X#define RTOD      (180.0/PI)
X
X/* macro and constant for base 2 logarithm */
X#define LN2    0.693147180559945309417232121458176568075500134360255254121
X#define LOG2(val) (log(val)*(1.0/LN_2))
X
X#endif  /* __LONGCONST_H__ */
END_OF_FILE
if test 1701 -ne `wc -c <'AALines/LongConst.h'`; then
    echo shar: \"'AALines/LongConst.h'\" unpacked with wrong size!
fi
# end of 'AALines/LongConst.h'
fi
if test -f 'AALines/Makefile' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'AALines/Makefile'\"
else
echo shar: Extracting \"'AALines/Makefile'\" \(462 characters\)
sed "s/^X//" >'AALines/Makefile' <<'END_OF_FILE'
X# FILENAME:  Makefile  [revised 18 AUG 90]
X# 
X# AUTHOR:  Kelvin Thompson
X# 
X# DESCRIPTION:  Makefile for anti-aliased line rendering demo.
X
X# locations of Utah RLE information
XUTAH_RLE_INCLUDE_DIR = /public/graphics/rle/include
XUTAH_RLE_LIB_FILE = /p/lib/librle.a
X
XCFLAGS = -I$(UTAH_RLE_INCLUDE_DIR)
X
XOBJS = AAMain.o AALines.o AATables.o utah.o
X
X%.o : %.c
X	$(CC) -c $(CFLAGS) $(CPPFLAGS) $<
X
XAALine : $(OBJS)
X	cc $(CFLAGS) -o $@ $(OBJS) $(UTAH_RLE_LIB_FILE) -lm
END_OF_FILE
if test 462 -ne `wc -c <'AALines/Makefile'`; then
    echo shar: \"'AALines/Makefile'\" unpacked with wrong size!
fi
# end of 'AALines/Makefile'
fi
if test -f 'AALines/utah.h' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'AALines/utah.h'\"
else
echo shar: Extracting \"'AALines/utah.h'\" \(877 characters\)
sed "s/^X//" >'AALines/utah.h' <<'END_OF_FILE'
X/*
X	file:		utah.h
X	description:	interface to Utah RLE toolkit
X	author:		A. T. Campbell
X	date:		October 30, 1989
X*/
X
X#ifndef UTAH_H
X#define UTAH_H
X
X/******************************************************************************/
X
X/* include files */
X#include "svfb_global.h"
X
X/******************************************************************************/
X
X/* type definitions */
Xtypedef struct sv_globals UTAH_FILE;
X
X/******************************************************************************/
X
X/* return values */
Xextern int		utah_read_close();
Xextern UTAH_FILE	*utah_read_init();
Xextern int		utah_read_pixels();
Xextern int		utah_read_rgb();
Xextern int		utah_write_close();
Xextern UTAH_FILE	*utah_write_init();
Xextern int		utah_write_pixels();
Xextern int		utah_write_rgb();
X
X/******************************************************************************/
X
X#endif UTAH_H
END_OF_FILE
if test 877 -ne `wc -c <'AALines/utah.h'`; then
    echo shar: \"'AALines/utah.h'\" unpacked with wrong size!
fi
# end of 'AALines/utah.h'
fi
if test -f 'BinRec.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'BinRec.c'\"
else
echo shar: Extracting \"'BinRec.c'\" \(1171 characters\)
sed "s/^X//" >'BinRec.c' <<'END_OF_FILE'
X/*
X * Recording Animation in Binary Order for Progressive Temporal Refinement
X * by Paul Heckbert
X * from "Graphics Gems", Academic Press, 1990
X */
X
X/*
X * binrec.c: demonstrate binary recording order
X *
X * Paul Heckbert	Jan 90
X */
X
X#include <stdio.h>
X
Xmain(ac, av)
Xint ac;
Xchar **av;
X{
X    int nframes, i, start_frame, repeat_count;
X    if (ac!=2) {
X	fprintf(stderr, "Usage: binrec <nframes>\n");
X	exit(1);
X    }
X    nframes = atoi(av[1]);
X
X    printf("step startframe repeatcount\n");
X    for (i=0; i<nframes; i++) {
X	inside_out(nframes, i, &start_frame, &repeat_count);
X	printf(" %2d     %2d          %2d\n", i, start_frame, repeat_count);
X    }
X}
X
X/*
X * inside_out: turn a number "inside-out": a generalization of bit-reversal.
X * For n = power of two, this is equivalent to bit-reversal.
X *
X * Turn the number a inside-out, yielding b.  If 0<=a<n then 0<=b<n.
X * Also return r = min(n-b, largest power of 2 dividing b)
X */
X
Xinside_out(n, a, b, r)
Xint n, a, *b, *r;
X{
X    int k, m;
X
X    *r = m = n;
X    for (*b=0, k=1; k<n; k<<=1)
X	if (a<<1>=m) {
X	    if (*b==0) *r = k;
X	    *b += k;
X	    a -= m+1>>1;
X	    m >>= 1;
X	}
X	else m = m+1>>1;
X    if (*r>n-*b) *r = n-*b;
X}
END_OF_FILE
if test 1171 -ne `wc -c <'BinRec.c'`; then
    echo shar: \"'BinRec.c'\" unpacked with wrong size!
fi
# end of 'BinRec.c'
fi
if test -f 'CircleRect.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'CircleRect.c'\"
else
echo shar: Extracting \"'CircleRect.c'\" \(1513 characters\)
sed "s/^X//" >'CircleRect.c' <<'END_OF_FILE'
X/* 
XFast Circle-Rectangle Intersection Checking
Xby Clifford A. Shaffer
Xfrom "Graphics Gems", Academic Press, 1990
X*/
X
X#include "GraphicsGems.h"
X
Xboolean Check_Intersect(R, C, Rad)
X
X/* Return TRUE iff rectangle R intersects circle with centerpoint C and
X   radius Rad. */
X Box2 *R;
X Point2 *C;
X double Rad;
X{
X double Rad2;
X
X Rad2 = Rad * Rad;
X /* Translate coordinates, placing C at the origin. */
X R->max.x -= C->x;  R->max.y -= C->y;
X R->min.x -= C->x;  R->min.y -= C->y;
X
X if (R->max.x < 0) 			/* R to left of circle center */
X   	if (R->max.y < 0) 		/* R in lower left corner */
X     		return ((R->max.x * R->max.x + R->max.y * R->max.y) < Rad2);
X   	else if (R->min.y > 0) 	/* R in upper left corner */
X     		return ((R->max.x * R->max.x + R->min.y * R->min.y) < Rad2);
X   	else 					/* R due West of circle */
X     		return(ABS(R->max.x) < Rad);
X 	else if (R->min.x > 0)  	/* R to right of circle center */
X   		if (R->max.y < 0) 	/* R in lower right corner */
X     			return ((R->min.x * R->min.x) < Rad2);
X   	else if (R->min.y > 0)  	/* R in upper right corner */
X     		return ((R->min.x * R->min.x + R->min.y + R->min.y) < Rad2);
X   	else 				/* R due East of circle */
X     		return (R->min.x < Rad);
X 	else				/* R on circle vertical centerline */
X   		if (R->max.y < 0) 	/* R due South of circle */
X     		return (ABS(R->max.y) < Rad);
X   	else if (R->min.y > 0)  	/* R due North of circle */
X     		return (R->min.y < Rad);
X   	else 				/* R contains circle centerpoint */
X     		return(TRUE);
X} 	
END_OF_FILE
if test 1513 -ne `wc -c <'CircleRect.c'`; then
    echo shar: \"'CircleRect.c'\" unpacked with wrong size!
fi
# end of 'CircleRect.c'
fi
if test -f 'DigitalLine.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'DigitalLine.c'\"
else
echo shar: Extracting \"'DigitalLine.c'\" \(943 characters\)
sed "s/^X//" >'DigitalLine.c' <<'END_OF_FILE'
X/*
X * Digital Line Drawing
X * by Paul Heckbert
X * from "Graphics Gems", Academic Press, 1990
X */
X
X/*
X * digline: draw digital line from (x1,y1) to (x2,y2),
X * calling a user-supplied procedure at each pixel.
X * Does no clipping.  Uses Bresenham's algorithm.
X *
X * Paul Heckbert	3 Sep 85
X */
X
X#include "GraphicsGems.h"
X
Xdigline(x1, y1, x2, y2, dotproc)
Xint x1, y1, x2, y2;
Xvoid (*dotproc)();
X{
X    int d, x, y, ax, ay, sx, sy, dx, dy;
X
X    dx = x2-x1;  ax = ABS(dx)<<1;  sx = SGN(dx);
X    dy = y2-y1;  ay = ABS(dy)<<1;  sy = SGN(dy);
X
X    x = x1;
X    y = y1;
X    if (ax>ay) {		/* x dominant */
X	d = ay-(ax>>1);
X	for (;;) {
X	    (*dotproc)(x, y);
X	    if (x==x2) return;
X	    if (d>=0) {
X		y += sy;
X		d -= ax;
X	    }
X	    x += sx;
X	    d += ay;
X	}
X    }
X    else {			/* y dominant */
X	d = ax-(ay>>1);
X	for (;;) {
X	    (*dotproc)(x, y);
X	    if (y==y2) return;
X	    if (d>=0) {
X		x += sx;
X		d -= ay;
X	    }
X	    y += sy;
X	    d += ax;
X	}
X    }
X}
END_OF_FILE
if test 943 -ne `wc -c <'DigitalLine.c'`; then
    echo shar: \"'DigitalLine.c'\" unpacked with wrong size!
fi
# end of 'DigitalLine.c'
fi
if test -f 'FastJitter.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'FastJitter.c'\"
else
echo shar: Extracting \"'FastJitter.c'\" \(1720 characters\)
sed "s/^X//" >'FastJitter.c' <<'END_OF_FILE'
X/*
X * Efficient Generation of Sampling Jitter Using Look-up Tables
X * by Joseph M. Cychosz
X * from "Graphics Gems", Academic Press, 1990
X */
X
X/*  	Jitter.c - Sampling jitter generation routines.  	    
X/*
X/*	Description:
X/*	    Jitter.c contains the routines for generation of sampling  
X/*	    jitter using look-up tables.
X/*
X/*	Contents:
X/*	    Jitter1	Generate random jitter function 1.
X/*	    Jitter2	Generate random jitter function 2.			
X/*	    JitterInit	Initialize look-up tables.
X/* */
X
X#define			NRAN	1024	/* Random number table length	*/
X
Xstatic	double	URANX[NRAN],		/* Random number tables		*/
X				URANY[NRAN];
Xstatic	int		IRAND[NRAN];	/* Shuffle table	*/
Xstatic	int		MASK = NRAN-1;	/* Mask for jitter mod function */
Xextern	double	xranf();		/* Random number generator pro- */
X					/* ducing uniform numbers 0 to 1 */
X
X/*  	Jitter1 - Generate random jitter. 	*/
X
Xvoid	Jitter1	(x,y,s,xj,yj)
X		int	x, y;		/* Pixel location	 */
X		int	s;		/* Sample number for the pixel */
X		double	*xj, *yj;	/* Jitter (x,y)	*/
X{
X		*xj = URANX[ (x + (y<<2) + IRAND[(x+s)&MASK]) & MASK ];
X		*yj = URANY[ (y + (x<<2) + IRAND[(y+s)&MASK]) & MASK ];
X}
X
X
X
X/*  	Jitter2 - Generate random jitter.  	*/
X
Xvoid	Jitter2	(x,y,s,xj,yj)
X		int	x, y;		/* Pixel location  */
X		int	s;		/* Sample number for the pixel */
X		double	*xj, *yj;	/* Jitter (x,y)	*/
X{
X		*xj = URANX[ ((x | (y<<2)) + IRAND[(x+s)&MASK]) & MASK ];
X		*yj = URANY[ ((y | (x<<2)) + IRAND[(y+s)&MASK]) & MASK ];
X}
X
X
X/*  	JitterInit - Initialize look-up tables.  	*/
X
Xvoid	JitterInit	()
X{
X		int	i;
X
X		for ( i = 0 ; i < NRAN ; i++ ) URANX[i] = xranf();
X		for ( i = 0 ; i < NRAN ; i++ ) URANY[i] = xranf();
X		for ( i = 0 ; i < NRAN ; i++ ) IRAND[i] = (int) (NRAN *
X						xranf());
X}
END_OF_FILE
if test 1720 -ne `wc -c <'FastJitter.c'`; then
    echo shar: \"'FastJitter.c'\" unpacked with wrong size!
fi
# end of 'FastJitter.c'
fi
if test -f 'FixedTrig.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'FixedTrig.c'\"
else
echo shar: Extracting \"'FixedTrig.c'\" \(1725 characters\)
sed "s/^X//" >'FixedTrig.c' <<'END_OF_FILE'
X/* 
XFixed-Point Trigonometry with CORDIC Iterations
Xby Ken Turkowski
Xfrom "Graphics Gems", Academic Press, 1990
X*/
X
X#define COSCALE 0x22c2dd1c /* 0.271572 */
X#define QUARTER ((int)(3.141592654 / 2.0 * (1 << 28)))
Xstatic long arctantab[32] = {  /* MS 4 integral bits for radians */
X	297197971, 210828714, 124459457, 65760959, 33381290, 16755422,
X	8385879, 4193963, 2097109, 1048571, 524287, 262144, 131072,
X	65536, 32768, 16384, 8192, 4096, 2048, 1024, 512, 256, 128, 64,
X	32, 16, 8, 4, 2, 1, 0, 0,
X};
X
XCordicRotate(px, py, theta)
Xlong *px, *py;
Xregister long theta;	/* Assume that abs(theta) <= pi */
X{
X	register int i;
X	register long x = *px, y = *py, xtemp;
X	register long *arctanptr = arctantab;
X
X	/* The -1 may need to be pulled out and done as a left shift */
X	for (i = -1; i <= 28; i++) {
X		if (theta < 0) {
X			xtemp = x + (y >> i);
X			y     = y - (x >> i);
X			x = xtemp;
X			theta += *arctanptr++;
X		} else {
X			xtemp = x - (y >> i);	
X			y     = y + (x >> i);
X			x = xtemp;	
X			theta -= *arctanptr++;
X		}
X	}
X
X	*px = frmul(x, COSCALE); /* Compensate for CORDIC enlargement */
X	*py = frmul(y, COSCALE); /* frmul(a,b)=(a*b)>>31, high part  */
X				 /* of 64-bit product */
X}
X
X
X
X
XCordicPolarize(argx, argy)
Xlong *argx, *argy;	/* We assume these are already in the */
X					/*  right half plane */
X{
X	register long theta, yi, i;
X	register long x = *argx, y = *argy;
X	register long *arctanptr = arctantab;
X	for (i = -1; i <= 28; i++) {
X		if (y < 0) {		/* Rotate positive */
X			yi = y + (x >> i);
X			x  = x - (y >> i);
X			y  = yi;
X			theta -= *arctanptr++;
X		} else { 		/* Rotate negative */
X			yi = y - (x >> i);
X			x  = x + (y >> i);
X			y  = yi;
X			theta += *arctanptr++;
X		}
X	}
X
X	*argx = frmul(x, COSCALE);
X	*argy = theta;
X}
END_OF_FILE
if test 1725 -ne `wc -c <'FixedTrig.c'`; then
    echo shar: \"'FixedTrig.c'\" unpacked with wrong size!
fi
# end of 'FixedTrig.c'
fi
if test -f 'HSLtoRGB.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'HSLtoRGB.c'\"
else
echo shar: Extracting \"'HSLtoRGB.c'\" \(1736 characters\)
sed "s/^X//" >'HSLtoRGB.c' <<'END_OF_FILE'
X/*
XA Fast HSL-to-RGB Transform
Xby Ken Fishkin
Xfrom "Graphics Gems", Academic Press, 1990
X*/
X
X#include <math.h>
X#include <stdio.h>
X#include "GraphicsGems.h"
X
X    /*
X     * RGB-HSL transforms.
X     * Ken Fishkin, Pixar Inc., January 1989.
X     */
X
X    /*
X    * given r,g,b on [0 ... 1],
X    * return (h,s,l) on [0 ... 1]
X    */
Xvoid
XRGB_to_HSL	(r,g,b,h,s,l)
Xdouble 	r,g,b;
Xdouble *h, *s, *l;
X{
X    double v;
X    double m;
X    double vm;
X    double r2, g2, b2;
X
X    v = MAX(r,g);
X    v = MAX(v,b);
X    m = MIN(r,g);
X    m = MIN(m,b);
X
X    if ((*l = (m + v) / 2.0) <= 0.0) return;
X    if ((*s = vm = v - m) > 0.0) {
X		*s /= (*l <= 0.5) ? (v + m ) :
X			(2.0 - v - m) ;
X    } else
X	return;
X
X
X    r2 = (v - r) / vm;
X    g2 = (v - g) / vm;
X    b2 = (v - b) / vm;
X
X    if (r == v)
X		*h = (g == m ? 5.0 + b2 : 1.0 - g2);
X    else if (g == v)
X		*h = (b == m ? 1.0 + r2 : 3.0 - b2);
X    else
X		*h = (r == m ? 3.0 + g2 : 5.0 - r2);
X
X    	*h /= 6;
X	}
X
X    /*
X     * given h,s,l on [0..1],
X     * return r,g,b on [0..1]
X     */
Xvoid
XHSL_to_RGB(h,sl,l,r,g,b)
Xdouble 	h,sl,l;
Xdouble 	*r, *g, *b;
X{
X    double v;
X
X    v = (l <= 0.5) ? (l * (1.0 + sl)) : (l + sl - l * sl);
X    if (v <= 0) {
X		*r = *g = *b = 0.0;
X    } else {
X		double m;
X		double sv;
X		int sextant;
X		double fract, vsf, mid1, mid2;
X
X		m = l + l - v;
X		sv = (v - m ) / v;
X		h *= 6.0;
X		sextant = h;	
X		fract = h - sextant;
X		vsf = v * sv * fract;
X		mid1 = m + vsf;
X		mid2 = v - vsf;
X		switch (sextant) {
X			case 0: *r = v; *g = mid1; *b = m; break;
X			case 1: *r = mid2; *g = v; *b = m; break;
X			case 2: *r = m; *g = v; *b = mid1; break;
X			case 3: *r = m; *g = mid2; *b = v; break;
X			case 4: *r = mid1; *g = m; *b = v; break;
X			case 5: *r = v; *g = m; *b = mid2; break;
X		}
X    }
X}
X
X
END_OF_FILE
if test 1736 -ne `wc -c <'HSLtoRGB.c'`; then
    echo shar: \"'HSLtoRGB.c'\" unpacked with wrong size!
fi
# end of 'HSLtoRGB.c'
fi
if test -f 'Hash3D.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'Hash3D.c'\"
else
echo shar: Extracting \"'Hash3D.c'\" \(1454 characters\)
sed "s/^X//" >'Hash3D.c' <<'END_OF_FILE'
X/*
XA 3D Grid Hashing Frunction
Xby Brian Wyvill
Xfrom "Graphics Gems", Academic Press, 1990
X*/
X
X/* Test Program for 3D hash function.
XIn C the hash function can be defined in a macro which
Xavoids a function call
Xand the bit operations are defined in the language.
X*/
X
X#include <stdio.h>
X#include <math.h>
X#include "GraphicsGems.h"		
X
X#define RANGE       256
X#define NBITS       4
X#define RBITS       4
X#define MASK        0360
X#define HASH(a,b,c) ((((a&MASK)<<NBITS|b&MASK)<<NBITS|c&MASK)>>RBITS)
X#define HSIZE       1<<NBITS*3
X#define IABS(x)     (int)((x) < 0 ? -(x) : (x))
X
Xtypedef struct {
X  double x,y,z;
X} Triple, *RefTriple;
X
Xtypedef struct {   /* linked list of objects to be stored */
X  Triple origin;
X  struct Object *link;
X} Object, *RefObject;
X
Xtypedef struct {  /* linked list of voxels (object pointers) */
X  RefObject objectList;
X  struct Voxel *link;
X} Voxel, *RefVoxel;
X
XRefVoxel table[HSIZE];  /* Table of pointers to Voxels */
X
X
Xcheckrange(z) double z;
X{
X  if (z < 0 || z >= RANGE)
X	fprintf(stderr,"%f out of range\n",z), 		exit();
X}
X
Xdouble getcoord()
X{
X  char buf[80];
X  double z;
X  scanf("%s",buf);
X  z = atof(buf);
X  checkrange(z);  
X  return z;
X}
X
Xmain()
X{
X  Triple a;
X  while (TRUE) {
X    printf("Enter object position x y z ===> ");
X    a.x = getcoord();
X    a.y = getcoord();
X    a.z = getcoord();
X    printf("\ncoord: %d %d %d Hashes to %d\n",IABS(a.x),IABS(a.y),IABS(a.z),
X	   HASH(IABS(a.x), IABS(a.y), IABS(a.z) ));
X  };  
X}
END_OF_FILE
if test 1454 -ne `wc -c <'Hash3D.c'`; then
    echo shar: \"'Hash3D.c'\" unpacked with wrong size!
fi
# end of 'Hash3D.c'
fi
if test -f 'HypotApprox.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'HypotApprox.c'\"
else
echo shar: Extracting \"'HypotApprox.c'\" \(1545 characters\)
sed "s/^X//" >'HypotApprox.c' <<'END_OF_FILE'
X/*
XA Fast Approximation to the Hypotenuse
Xby Alan Paeth
Xfrom "Graphics Gems", Academic Press, 1990
X*/
X
Xint idist(x1, y1, x2, y2)
X 	int x1, y1, x2, y2;
X	{
X/*
X * gives approximate distance from (x1,y1) to (x2,y2)
X * with only overestimations, and then never by more
X * than (9/8) + one bit uncertainty.
X */
X	if ((x2 -= x1) < 0) x2 = -x2;
X	if ((y2 -= y1) < 0) y2 = -y2;
X	return (x2 + y2 - (((x2>y2) ? y2 : x2) >> 1) );
X	}
X
Xint PntOnCirc(xp, yp, xc, yc, r)
X    int xp, yp, xc, yc, r;
X    {
X/* returns true IFF a test point (xp, yp) is to within a
X * pixel of the circle of center (xc, yc) and radius r.
X * "d" is an approximate length to circle's center, with
X * 1.0*r < dist < 1.12*r < (9/8)*r used for coarse testing.
X * The 9/8 ratio suggests the code: (x)<<3 and ((x)<<3)-(x).
X * Variables xp, yp, r and d should be of 32-bit precision.
X *
X * Note: (9/8) forms a very tight, proper inner bound but
X * must be slackened by one pixel for the outside test (#2)
X * to account for the -1/2 pixel absolute error introduced
X * when "idist" halves an odd integer; else rough clipping
X * will trim occasional points on the circle's perimeter.
X */
X    int d = idist(xp, yp, xc, yc);
X    if (  r >      d)   return(0);    /* far-in  */
X    if (9*r < 8*(d-1))  return(0);    /* far-out */
X/* full test: r < hypot(xp-xc,yp-yc) < r+1 */
X    xp -= xc;
X    yp -= yc;
X    d = xp*xp + yp*yp;
X    if (d < r*r) return(0);          /* near-in */
X    r += 1;
X    if (d > r*r) return(0);          /* near-out */
X    return(1);                       /* WITHIN */
X    }
END_OF_FILE
if test 1545 -ne `wc -c <'HypotApprox.c'`; then
    echo shar: \"'HypotApprox.c'\" unpacked with wrong size!
fi
# end of 'HypotApprox.c'
fi
if test -f 'MANIFEST' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'MANIFEST'\"
else
echo shar: Extracting \"'MANIFEST'\" \(4705 characters\)
sed "s/^X//" >'MANIFEST' <<'END_OF_FILE'
X   File Name		Archive #	Description
X-----------------------------------------------------------
X 2DClip                     1	2D Clipping: A Vector-Based Approach
X 2DClip/Makefile            1	Makefile	
X 2DClip/bio.c               2	Basic operations
X 2DClip/box.h               1	BOX definition
X 2DClip/clip.c              2	Clipping routines
X 2DClip/cross.c             4	Intersection calculation	
X 2DClip/line.h              1	Major definitions	
X AALines                    1	Rendering Anti-Aliased Lines
X AALines/00README           1	Information about AALines Gem
X AALines/AALines.c          4	Code to render an anti-aliased line
X AALines/AALines.h          1	Symbols & globals
X AALines/AAMain.c           1	Calling routine
X AALines/AATables.c         4	Initialization of tables and frame buffer
X AALines/FastMatMul.c       5	Fast routines to multiply 4x4 matrices
X AALines/LongConst.h        1	High-precision constants
X AALines/Makefile           1	Makefile
X AALines/utah.c             3	Interface to Utah Raster Toolkit
X AALines/utah.h             1	Declarations for URT interface
X AAPolyScan.c               4	Fast Anti_aliasing Polygon Scan Conversion	
X Albers.c                   3	Albers Equal-Area Conic Map Projection
X BinRec.c                   1	Recording Animation in Binary Order	
X BoundSphere.c              3	An Efficient Bounding Sphere	
X BoxSphere.c                2	Box-Sphere Intersection Checking
X CircleRect.c               1	Fast Circle-Rectangle Intersection Checking
X ConcaveScan.c              4	Concave Polygon Scan Conversion
X DigitalLine.c              1	Digital Line Drawing
X Dissolve.c                 3	A Digital "Dissolve" Effect
X DoubleLine.c               3	Symmetric Double Step Line Algorithm
X FastJitter.c               1	Efficient Generation of Sampling Jitter
X FitCurves.c                5	Automatically Fit Digitized Curves
X FixedTrig.c                1	Fixed-Point Trig with CORDIC Iterations
X Forms.c                    4	Forms, Vectors, and Transformations
X GGVecLib.c                 5	2D and 3D Vector C Library	
X GraphicsGems.h             3	Graphics Gems header file	
X HSLtoRGB.c                 1	A Fast HSL-to-RGB Transform
X Hash3D.c                   1	3D Grid Hashing Function
X HypotApprox.c              1	A Fast Approximation to the Hypotenuse	
X Interleave.c               4	Bit Interleaving for Quad- or Octrees
X Label.c                    2	Nice Numbers for Graph Labels
X LineEdge.c                 3	Fast Line-Edge Intersections on a Uniform Grid
X MANIFEST                   1	This shipping list
X Makefile                   2	Makefile for the whole shebang
X MatrixInvert.c             3	Matrix Inversion	
X MatrixOrtho.c              1	Matrix Orthogonalization
X MatrixPost.c               2	Efficient Post-Concatenation of Trans. Matrices	
X Median.c                   2	Median Finding on a 3x3 Grid
X NearestPoint.c             5	Nearest-Point-On-Curve and Bezier Root-Finder
X OrderDither.c              2	Ordered Dithering
X PixelInteger.c             1	Proper Treatment of Pixels As Integers
X PntOnLine.c                2	A Fast 2D Point-On-Line Test
X PolyScan                   1	Convex Polygon Scan Conversion & Clipping
X PolyScan/Makefile          1	Makefile
X PolyScan/fancytest.c       2	Phong-shading a Texture mapping test
X PolyScan/poly.c            2	Simple utilities for polygon data structure	
X PolyScan/poly.h            2	Definitions for polygon package
X PolyScan/poly_clip.c       3	Homogeneous 3D polygon clipper
X PolyScan/poly_scan.c       3	Convex polygon point-sampled scan conversion
X PolyScan/scantest.c        2	Gouraud shading and Z-buffer demo	
X Quaternions.c              2	Using Quaternions for Coding 3D Transformations	
X README                     1	General information
X RGBTo4Bits.c               1	Mapping RGB Triples Onto Four Bits	
X RayBox.c                   1	Fast Ray-Box Intersection
X RayPolygon.c               1	An Efficient Ray-Polygon Intersection
X Roots3And4.c               3	Cubic and Quartic Roots
X SeedFill.c                 2	A Seed Fill Algorithm
X SquareRoot.c               2	A High-Speed, Low-Precision Square Root
X Sturm                      1	Using Sturm Sequences to Bracket Real Roots
X Sturm/Makefile             1	Makefile
X Sturm/main.c               2	Sample driver program
X Sturm/solve.h              1	Useful constants and types
X Sturm/sturm.c              4	Functions to build and evaluate Sturm sequence
X Sturm/util.c               1	Root polishing and evaluating utilities
X TransBox.c                 1	Transforming Axis-Aligned Bounding Boxes
X TriPoints.c                2	Generating Random Points in Triangles
X ViewTrans.c                1	3D Viewing and Rotation using Orthonormal Bases
END_OF_FILE
if test 4705 -ne `wc -c <'MANIFEST'`; then
    echo shar: \"'MANIFEST'\" unpacked with wrong size!
fi
# end of 'MANIFEST'
fi
if test -f 'MatrixOrtho.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'MatrixOrtho.c'\"
else
echo shar: Extracting \"'MatrixOrtho.c'\" \(1335 characters\)
sed "s/^X//" >'MatrixOrtho.c' <<'END_OF_FILE'
X/* 
XMatrix Orthogonalization
XEric Raible
Xfrom "Graphics Gems", Academic Press, 1990
X*/
X
X/*
X * Reorthogonalize matrix R - that is find an orthogonal matrix that is
X * "close" to R by computing an approximation to the orthogonal matrix
X *
X *           T  -1/2
X *   RC = R(R R)
X *			        			 T      -1
X * [RC is orthogonal because (RC) = (RC) ]
X *				               	                    -1/2
X * To compute C, we evaluate the Taylor expansion of F(x) = (I + x)
X * (where x = C - I) about x=0.
X * This gives C = I - (1/2)x + (3/8)x^2 - (5/16)x^3 + ...
X */
X
X#include "GraphicsGems.h"
X
Xstatic float coef[10] = 			/* From mathematica */
X  { 1, -1/2., 3/8., -5/16., 35/128., -63/256.,
X    231/1024., -429/2048., 6435/32768., -12155/65536. };
X
XMATRIX_reorthogonalize (R, limit)
X     Matrix R;
X{
X  Matrix I, Temp, X, X_power, Sum;
X  int power;
X
X  limit = MAX(limit, 10);
X
X  MATRIX_transpose (R, Temp);		/* Rt */
X  MATRIX_multiply (Temp, R, Temp);	/* RtR */
X  MATRIX_identify (I);
X  MATRIX_subtract (Temp, I, X);	/* RtR - I */
X  MATRIX_identify (X_power);		/* X^0 */
X  MATRIX_identify (Sum);			/* coef[0] * X^0 */
X
X  for (power = 1; power < limit; ++power)
X    {
X      MATRIX_multiply (X_power, X, X_power);
X      MATRIX_constant_multiply (coef[power], X_power, Temp);
X      MATRIX_add (Sum, Temp, Sum);
X    }
X
X  MATRIX_multiply (R, Sum, R);
X}
END_OF_FILE
if test 1335 -ne `wc -c <'MatrixOrtho.c'`; then
    echo shar: \"'MatrixOrtho.c'\" unpacked with wrong size!
fi
# end of 'MatrixOrtho.c'
fi
if test -f 'PixelInteger.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'PixelInteger.c'\"
else
echo shar: Extracting \"'PixelInteger.c'\" \(1534 characters\)
sed "s/^X//" >'PixelInteger.c' <<'END_OF_FILE'
X/*
XProper Treatment of Pixels as Integers
Xby Alan Paeth
Xfrom "Graphics Gems", Academic Press, 1990
X*/
X
X#define Min     code[2]
X#define Med     code[1]
X#define Max     code[0]
X#define NCODE   3
X
X/*
X * A call to getplanes of the form:
X * getplanes(&red, &green, &blue, 256, "grb");
X *
X * fills the first three integer pointers with (near) identical
X * values which maximize red*green*blue <= 256. The final parameter
X * string defines tie-break order, here green>=red>=blue (the usual
X * default). The present code procedure calls "err(string, arg)"
X * given bad parameters; it is a simple task to rewrite the code as
X * a function which returns a success/failure code(s), as needed.
X *
X * In the example given above the code fills in the values
X * red = 6, green = 7, blue = 6.
X */
X
Xgetplanes(r, g, b, n, bias)
X    int *r, *g, *b;
X    char *bias;
X    {
X    int i, code[NCODE];
X    if(strlen(bias) != NCODE )
X        err("bias string \"%s\" wrong length",bias);
X    Min = Med = Max = 0;
X    *r = *g = *b = 0;
X    while(Min*Min*Min <= n) Min++;
X    Min--;
X    while(Med*Med*Min <= n) Med++;
X    Med--;
X    Max = n/(Min*Med);
X    for( i = 0; i < NCODE; i++ )
X	   {
X        switch(bias[i])
X            {
X            case 'r': case 'R': *r = code[i]; break;
X            case 'g': case 'G': *g = code[i]; break;
X            case 'b': case 'B': *b = code[i]; break;
X            default: err("bad bias character: \'%c\'",bias[i]); break;
X            }
X        }
X    if (!(*r && *g && *b)) err("bias string \"%s\" deficient", bias);
X    }
X    
END_OF_FILE
if test 1534 -ne `wc -c <'PixelInteger.c'`; then
    echo shar: \"'PixelInteger.c'\" unpacked with wrong size!
fi
# end of 'PixelInteger.c'
fi
if test ! -d 'PolyScan' ; then
    echo shar: Creating directory \"'PolyScan'\"
    mkdir 'PolyScan'
fi
if test -f 'PolyScan/Makefile' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'PolyScan/Makefile'\"
else
echo shar: Extracting \"'PolyScan/Makefile'\" \(380 characters\)
sed "s/^X//" >'PolyScan/Makefile' <<'END_OF_FILE'
X# Makefile for scantest, test program for generic convex polygon scan conversion
X#
X# Note: fancytest.c needs a main routine and several auxiliary routines
X# in order to be compiled.
X
XCFLAGS = $(GENCFLAGS)
X
Xscantest: scantest.o poly_scan.o poly.o
X	$(CC) $(CFLAGS) -o scantest scantest.o poly_scan.o poly.o -lm
X
Xclean:
X	/bin/rm -f scantest.o poly_clip.o poly_scan.o poly.o scantest
END_OF_FILE
if test 380 -ne `wc -c <'PolyScan/Makefile'`; then
    echo shar: \"'PolyScan/Makefile'\" unpacked with wrong size!
fi
# end of 'PolyScan/Makefile'
fi
if test -f 'README' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'README'\"
else
echo shar: Extracting \"'README'\" \(5838 characters\)
sed "s/^X//" >'README' <<'END_OF_FILE'
X[ This package last updated Wed Dec 12 20:45:09 EST 1990. ]
X
XREADME
X
XThis package contains the most up-to-date versions of the C source
Xfiles from the book "Graphics Gems" (Editor Andrew S. Glassner,
XAcademic Press, 1990 ISBM 0-12-286165-5, 833 pgs.).
X
XAll known bugs have been fixed, formatting problems have been
Xcorrected, and enchancements to some of the original Gems have
Xbeen made.
X
XMakefiles are provided that create stand-alone programs, many object
Xfiles, and "gemlib.a".  This Graphics Gem Library is created for
Xcompilation-testing only, and is not intended to be a usable library
X(although it may become so in the future).  Indeed, many of the Gems
Xwill not compile or run properly without the addition of functions,
Xtables, and the like.  See the book and the Makefile for more details.
X
XEach Gem is made available on an as-is basis; although 
Xconsiderable effort has been expended to check the programs 
Xas originally designed and their release in electronic form, 
Xthe authors and the publisher make no guarantees or 
Xwarrantees about the correctness of any of these programs or 
Xalgorithms.  
X
XThe authors and the publisher hold no copyright restrictions 
Xon any of these files; this source code is public domain, and 
Xis freely available to the entire computer graphics community 
Xfor study, use, and modification.  We do request that the 
Xcomment at the top of each file, identifying the original 
Xauthor and its original publication in the book Graphics 
XGems, be retained in all programs that use these files.
X
XAn archive of the most current versions of all the Gems is maintained
Xon weedeater.math.yale.edu (130.132.23.17) and is available via
Xanonymous ftp in pub/GraphicsGems/src.
X
XYou are encouraged to submit bug fixes, skeleton programs, and the like
Xto Craig Kolb (kolb@yale.edu).
X
XAndrew Glassner / Craig Kolb
X
X================
X
XThe table below gives the correspondence between each source
Xfile in this directory and the name of the Gem it implements.
XEach implementation illustrates one way to realize the
Xtechniques described by the accompanying Gem in the book. 
XThe files here contain only the source code for that 
Xrealization.  For a more complete description of the 
Xalgorithms and their applications see the Gems of the same 
Xname in the first 11 Chapters of the book.
X
X---------- header files ----------
XGraphicsGems.h         / Graphics Gems C Header File
X
X----------    C code    ----------
X2DClip/*               / Two-Dimensional Clipping: 
X                         A Vector-Based Approach
XAALines/*              / Rendering Anti-Aliased Lines
XAAPolyScan.c           / Fast Anti-Aliasing Polygon
X                         Scan Conversion
XAlbers.c               / Albers Equal-Area Conic Map
X                         Projection
XBinRec.c               / Recording Animation in Binary Order 
X                         For Progressive Temporal Refinement  
XBoundSphere.c          / An Efficient Bounding Sphere
XBoxSphere.c            / A Simple Method for Box-Sphere 
X                         Intersection Checking 
XCircleRect.c           / Fast Circle-Rectangle Intersection
X                         Checking 
XConcaveScan.c          / Concave Polygon Scan Conversion
XDigitalLine.c          / Digital Line Drawing
XDissolve.c 	       / A Digital "Dissolve" Effect
XDoubleLine.c           / Symmetric Double Step Line Algorithm
XFastJitter.c           / Efficient Generation of Sampling
X                         Jitter Using Look-up Tables
XFitCurves.c            / An Algorithm for Automatically 
X                         Fitting Digitized Curves
XFixedTrig.c            / Fixed-Point Trigonometry with 
X                         CORDIC Iterations
XForms.c                / Forms, Vectors, and Transforms
XGGVecLib.c             / 2D And 3D Vector C Library   
XHSLtoRGB.c             / A Fast HSL-to-RGB Transform
XHash3D.c               / 3D Grid Hashing Function
XHypotApprox.c          / A Fast Approximation to 
X                         the Hypotenuse
XInterleave.c           / Bit Interleaving for Quad- 
X                         or Octrees
XLabel.c                / Nice Numbers for Graph Labels
XLineEdge.c             / Fast Line-Edge Intersections On 
X                         A Uniform Grid   
XMatrixInvert.c         / Matrix Inversion
XMatrixOrtho.c          / Matrix Orthogonalization
XMatrixPost.c           / Efficient Post-Concatenation of 
X                         Transformation Matrices
XMedian.c               / Median Finding on a 3x3 Grid
XNearestPoint.c         / Solving the 
X                         Nearest-Point-On-Curve Problem
X                         and
X                         A Bezier Curve-Based Root-Finder
XOrderDither.c          / Ordered Dithering
XPixelInteger.c         / Proper Treatment of Pixels 
X                         As Integers
XPntOnLine.c            / A Fast 2D Point-On-Line Test
XPolyScan/*             / Generic Convex Polygon 
X                         Scan Conversion and Clipping
XQuaternions.c          / Using Quaternions for Coding 
X                         3D Transformations
XRGBTo4Bits.c           / Mapping RGB Triples Onto Four Bits
XRayBox.c               / Fast Ray-Box Intersection
XRayPolygon.c           / An Efficient Ray-Polygon 
X                         Intersection
XRoots3And4.c           / Cubic and Quartic Roots
XSeedFill.c             / A Seed Fill Algorithm
XSquareRoot.c           / A High-Speed, Low-Precision 
X                         Square Root
XSturm/*                / Using Sturm Sequences to Bracket 
X                         Real Roots of Polynomial Equations
XTransBox.c             / Transforming Axis-Aligned 
X                         Bounding Boxes
XTriPoints.c            / Generating Random Points 
X                         In Triangles   
XViewTrans.c            / 3D Viewing and Rotation Using
X                         Orthonormal Bases
END_OF_FILE
if test 5838 -ne `wc -c <'README'`; then
    echo shar: \"'README'\" unpacked with wrong size!
fi
# end of 'README'
fi
if test -f 'RGBTo4Bits.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'RGBTo4Bits.c'\"
else
echo shar: Extracting \"'RGBTo4Bits.c'\" \(1448 characters\)
sed "s/^X//" >'RGBTo4Bits.c' <<'END_OF_FILE'
X/*
XMapping RGB Triples onto Four Bits
Xby Alan Paeth
Xfrom "Graphics Gems", Academic Press, 1990
X*/
X
Xremap8(R, G, B, R2, G2, B2)
X    float R, G, B, *R2, *G2, *B2;
X    {
X/*
X * remap8 maps floating (R,G,B) triples onto quantized
X * (R2,B2,B2) triples and returns the code (vertex)
X * value/color table entry for the quantization. The
X * points (eight) are the vertices of the cube.
X */
X    int code;
X    *R2 = *G2 = *B2 = 0.0;
X    code = 0;
X    if (R >= 0.5) { *R2 = 1.0; code |= 1; }
X    if (G >= 0.5) { *G2 = 1.0; code |= 2; }
X    if (B >= 0.5) { *B2 = 1.0; code |= 4; }
X    return(code);
X    }
X
X/*
X * remap14 maps floating (R,G,B) triples onto quantized
X * (R2,B2,B2) triples and returns the code (vertex)
X * value/color table entry for the quantization. The
X * points (fourteen) are the vertices of the cuboctahedron.
X */
X
Xfloat rval[] = { 0.,.5 ,.5 , 1.,.0 , 0., 0.,.5,
X                .5 , 1., 1., 1., 0.,.5 ,.5 , 1.};
Xfloat gval[] = { 0.,.5 , 0., 0.,.5 , 1., 0.,.5,
X                .5 , 1., 0.,.5 , 1., 1.,.5 , 1.};
Xfloat bval[] = { 0., 0.,.5 , 0.,.5 , 0., 1.,.5,
X                .5 , 0., 1.,.5 , 1.,.5 , 1., 1.};
X
Xint remap14(R, G, B,  R2, G2, B2)
X    float R, G, B, *R2, *G2, *B2;
X    {
X    int code = 0;
X    if ( R + G + B > 1.5) code |= 8;
X    if (-R + G + B > 0.5) code |= 4;
X    if ( R - G + B > 0.5) code |= 2;
X    if ( R + G - B > 0.5) code |= 1;
X    *R2 = rval[code];
X    *G2 = gval[code];
X    *B2 = bval[code];
X    return(code);
X    }
END_OF_FILE
if test 1448 -ne `wc -c <'RGBTo4Bits.c'`; then
    echo shar: \"'RGBTo4Bits.c'\" unpacked with wrong size!
fi
# end of 'RGBTo4Bits.c'
fi
if test -f 'RayBox.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'RayBox.c'\"
else
echo shar: Extracting \"'RayBox.c'\" \(1793 characters\)
sed "s/^X//" >'RayBox.c' <<'END_OF_FILE'
X/* 
XFast Ray-Box Intersection
Xby Andrew Woo
Xfrom "Graphics Gems", Academic Press, 1990
X*/
X
X#include "GraphicsGems.h"
X
X#define NUMDIM	3
X#define RIGHT	0
X#define LEFT	1
X#define MIDDLE	2
X
Xchar HitBoundingBox(minB,maxB, origin, dir,coord)
Xdouble minB[NUMDIM], maxB[NUMDIM];		/*box */
Xdouble origin[NUMDIM], dir[NUMDIM];		/*ray */
Xdouble coord[NUMDIM];				/* hit point */
X{
X	char inside = TRUE;
X	char quadrant[NUMDIM];
X	register int i;
X	int whichPlane;
X	double maxT[NUMDIM];
X	double candidatePlane[NUMDIM];
X
X	/* Find candidate planes; this loop can be avoided if
X   	rays cast all from the eye(assume perpsective view) */
X	for (i=0; i<NUMDIM; i++)
X		if(origin[i] < minB[i]) {
X			quadrant[i] = LEFT;
X			candidatePlane[i] = minB[i];
X			inside = FALSE;
X		}else if (origin[i] > maxB[i]) {
X			quadrant[i] = RIGHT;
X			candidatePlane[i] = maxB[i];
X			inside = FALSE;
X		}else	{
X			quadrant[i] = MIDDLE;
X		}
X
X	/* Ray origin inside bounding box */
X	if(inside)	{
X		coord = origin;
X		return (TRUE);
X	}
X
X
X	/* Calculate T distances to candidate planes */
X	for (i = 0; i < NUMDIM; i++)
X		if (quadrant[i] != MIDDLE && dir[i] !=0.)
X			maxT[i] = (candidatePlane[i]-origin[i]) / dir[i];
X		else
X			maxT[i] = -1.;
X
X	/* Get largest of the maxT's for final choice of intersection */
X	whichPlane = 0;
X	for (i = 1; i < NUMDIM; i++)
X		if (maxT[whichPlane] < maxT[i])
X			whichPlane = i;
X
X	/* Check final candidate actually inside box */
X	if (maxT[whichPlane] < 0.) return (FALSE);
X	for (i = 0; i < NUMDIM; i++)
X		if (whichPlane != i) {
X			coord[i] = origin[i] + maxT[whichPlane] *dir[i];
X			if ((quadrant[i] == RIGHT && coord[i] < minB[i]) ||
X			   (quadrant[i] == LEFT && coord[i] > maxB[i]))
X			   return (FALSE);	/* outside box */
X			}else {
X				coord[i] = candidatePlane[i];
X			}
X	return (TRUE);				/* ray hits box */
X}	
X
END_OF_FILE
if test 1793 -ne `wc -c <'RayBox.c'`; then
    echo shar: \"'RayBox.c'\" unpacked with wrong size!
fi
# end of 'RayBox.c'
fi
if test -f 'RayPolygon.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'RayPolygon.c'\"
else
echo shar: Extracting \"'RayPolygon.c'\" \(1553 characters\)
sed "s/^X//" >'RayPolygon.c' <<'END_OF_FILE'
X/*
XAn Efficient Ray/Polygon Intersection
Xby Didier Badouel
Xfrom "Graphics Gems", Academic Press, 1990
X*/
X
X/* the value of t is computed.
X * i1 and i2 come from the polygon description.
X * V is the vertex table for the polygon and N the
X * associated normal vectors.
X */
XP[0] = ray.O[0] + ray.D[0]*t;
XP[1] = ray.O[1] + ray.D[1]*t;
XP[2] = ray.O[2] + ray.D[2]*t;
Xu0 = P[i1] - V[0][i1]; v0 = P[i2] - V[0][i2];
Xinter = FALSE; i = 2;
Xdo {
X    /* The polygon is viewed as (n-2) triangles. */
X    u1 = V[i-1][i1] - V[0][i1]; v1 = V[i-1][i2] - V[0][i2];
X    u2 = V[i  ][i1] - V[0][i1]; v2 = V[i  ][i2] - V[0][i2];
X
X    if (u1 == 0)    {
X        beta = u0/u2;
X        if ((beta >= 0.)&&(beta <= 1.)) {
X            alpha = (v0 - beta*v2)/v1;
X            inter = ((alpha >= 0.)&&(alpha+beta) <= 1.));
X        }
X    } else {
X        beta = (v0*u1 - u0*v1)/(v2*u1 - u2*v1);
X        if ((beta >= 0.)&&(beta <= 1.)) {
X            alpha = (u0 - beta*u2)/u1;
X            inter = ((alpha >= 0)&&((alpha+beta) <= 1.));
X        }
X    }
X} while ((!inter)&&(++i < poly.n));
X
Xif (inter) {
X    /* Storing the intersection point. */
X    ray.P[0] = P[0]; ray.P[1] = P[1]; ray.P[2] = P[2];
X    /* the normal vector can be interpolated now or later. */
X    if (poly.interpolate) {
X        gamma = 1 - (alpha+beta);
X        ray.normal[0] = gamma * N[0][0] + alpha * N[i-1][0] + 
X		beta * N[i][0];
X        ray.normal[1] = gamma * N[0][1] + alpha * N[i-1][1] +
X		 beta * N[i][1];
X        ray.normal[2] = gamma * N[0][2] + alpha * N[i-1][2] +
X		 beta * N[i][2];
X    }
X}
Xreturn (inter);
END_OF_FILE
if test 1553 -ne `wc -c <'RayPolygon.c'`; then
    echo shar: \"'RayPolygon.c'\" unpacked with wrong size!
fi
# end of 'RayPolygon.c'
fi
if test ! -d 'Sturm' ; then
    echo shar: Creating directory \"'Sturm'\"
    mkdir 'Sturm'
fi
if test -f 'Sturm/Makefile' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'Sturm/Makefile'\"
else
echo shar: Extracting \"'Sturm/Makefile'\" \(211 characters\)
sed "s/^X//" >'Sturm/Makefile' <<'END_OF_FILE'
X#
X# Makefile
X#
X#	command file for make to compile the solver.
X
Xsolve: main.o sturm.o util.o
X	cc -o solve main.o sturm.o util.o -lm
X
Xclean:
X	/bin/rm -f main.o sturm.o util.o solve
X
Xmain.o sturm.o util.o: solve.h
END_OF_FILE
if test 211 -ne `wc -c <'Sturm/Makefile'`; then
    echo shar: \"'Sturm/Makefile'\" unpacked with wrong size!
fi
# end of 'Sturm/Makefile'
fi
if test -f 'Sturm/solve.h' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'Sturm/solve.h'\"
else
echo shar: Extracting \"'Sturm/solve.h'\" \(710 characters\)
sed "s/^X//" >'Sturm/solve.h' <<'END_OF_FILE'
X
X/*
X * solve.h
X *
X *	some useful constants and types.
X */
X#define	 	MAX_ORDER  		12	
X/* maximum order for a polynomial */
X	
X#define	  	RELERROR	  		1.0e-14
X/* smallest relative error we want */
X
X#define	  	MAXPOW	    	32		
X/* max power of 10 we wish to search to */
X
X#define	  	MAXIT	     	800		
X/* max number of iterations */
X
X/* a coefficient smaller than SMALL_ENOUGH is considered to 
X   be zero (0.0). */
X
X#define	  	SMALL_ENOUGH		1.0e-12
X
X
X/*
X * structure type for representing a polynomial
X */
Xtypedef  	struct	p {
X		     int	ord;
X		     double	coef[MAX_ORDER];
X} poly;
X
Xextern 	int		modrf();
Xextern 	int		numroots();
Xextern 	int		numchanges();
Xextern 	int		buildsturm();
X
Xextern 	double	evalpoly();
X	
X
END_OF_FILE
if test 710 -ne `wc -c <'Sturm/solve.h'`; then
    echo shar: \"'Sturm/solve.h'\" unpacked with wrong size!
fi
# end of 'Sturm/solve.h'
fi
if test -f 'Sturm/util.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'Sturm/util.c'\"
else
echo shar: Extracting \"'Sturm/util.c'\" \(1768 characters\)
sed "s/^X//" >'Sturm/util.c' <<'END_OF_FILE'
X
X/*
X * util.c
X *
X *	some utlity functions for root polishing and evaluating
X * polynomials.
X */
X#include <math.h>
X#include <stdio.h>
X#include "solve.h"
X
X/*
X * evalpoly
X *
X *	evaluate polynomial defined in coef returning its value.
X */
Xdouble
Xevalpoly (ord, coef, x)
X	int		ord;
X	double	*coef, x;
X{
X	double	*fp, f;
X
X	fp = &coef[ord];
X	f = *fp;
X
X	for (fp--; fp >= coef; fp--)
X	f = x * f + *fp;
X
X	return(f);
X}
X
X
X/*
X * modrf
X *
X *	uses the modified regula-falsi method to evaluate the root
X * in interval [a,b] of the polynomial described in coef. The
X * root is returned is returned in *val. The routine returns zero
X * if it can't converge.
X */
Xint
Xmodrf(ord, coef, a, b, val)
X	int		ord;
X	double	*coef;
X	double	a, b, *val;
X{
X	int		its;
X	double	fa, fb, x, lx, fx, lfx;
X	double	*fp, *scoef, *ecoef;
X
X	scoef = coef;
X	ecoef = &coef[ord];
X
X	fb = fa = *ecoef;
X	for (fp = ecoef - 1; fp >= scoef; fp--) {
X		fa = a * fa + *fp;
X		fb = b * fb + *fp;
X	}
X
X	/*
X	 * if there is no sign difference the method won't work
X	 */
X	if (fa * fb > 0.0)
X		return(0);
X
X	if (fabs(fa) < RELERROR) {
X		*val = a;
X		return(1);
X	}
X
X	if (fabs(fb) < RELERROR) {
X		*val = b;
X		return(1);
X	}
X
X	lfx = fa;
X	lx = a;
X
X
X	for (its = 0; its < MAXIT; its++) {
X
X		x = (fb * a - fa * b) / (fb - fa);
X
X		fx = *ecoef;
X		for (fp = ecoef - 1; fp >= scoef; fp--)
X				fx = x * fx + *fp;
X
X		if (fabs(x) > RELERROR) {
X				if (fabs(fx / x) < RELERROR) {
X					*val = x;
X					return(1);
X				}
X		} else if (fabs(fx) < RELERROR) {
X				*val = x;
X				return(1);
X		}
X
X		if ((fa * fx) < 0) {
X				b = x;
X				fb = fx;
X				if ((lfx * fx) > 0)
X					fa /= 2;
X		} else {
X				a = x;
X				fa = fx;
X				if ((lfx * fx) > 0)
X					fb /= 2;
X		}
X
X		lx = x;
X		lfx = fx;
X	}
X
X	fprintf(stderr, "modrf overflow %f %f %f\n", a, b, fx);
X
X	return(0);
X}
X	
X
X
END_OF_FILE
if test 1768 -ne `wc -c <'Sturm/util.c'`; then
    echo shar: \"'Sturm/util.c'\" unpacked with wrong size!
fi
# end of 'Sturm/util.c'
fi
if test -f 'TransBox.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'TransBox.c'\"
else
echo shar: Extracting \"'TransBox.c'\" \(1672 characters\)
sed "s/^X//" >'TransBox.c' <<'END_OF_FILE'
X/*
XTransforming Axis-Aligned Bounding Boxes
Xby Jim Arvo
Xfrom "Graphics Gems", Academic Press, 1990
X*/
X
X#include "GraphicsGems.h"                                     
X/* Transforms a 3D axis-aligned box via a 3x3 matrix and a translation
X * vector and returns an axis-aligned box enclosing the result. */ 
X
Xvoid Transform_Box( M, T, A, B )
XMatrix3  M;  	/* Transform matrix.             */
XVector3  T;  	/* Translation matrix.           */
XBox3     A;  	/* The original bounding box.    */
XBox3    *B;  	/* The transformed bounding box. */
X    {
X    float  a, b;
X    float  Amin[3], Amax[3];
X    float  Bmin[3], Bmax[3];
X    int    i, j;
X
X    /*Copy box A into a min array and a max array for easy reference.*/
X
X    Amin[0] = A.min.x;  Amax[0] = A.max.x;
X    Amin[1] = A.min.y;  Amax[1] = A.max.y;
X    Amin[2] = A.min.z;  Amax[2] = A.max.z;
X
X    /* Take care of translation by beginning at T. */
X
X    Bmin[0] = Bmax[0] = T.x;
X    Bmin[1] = Bmax[1] = T.y;
X    Bmin[2] = Bmax[2] = T.z;
X
X    /* Now find the extreme points by considering the product of the */
X    /* min and max with each component of M.  */
X                     
X    for( i = 0; i < 3; i++ )
X    for( j = 0; j < 3; j++ )
X        {
X        a = M.element[i][j] * Amin[j];
X        b = M.element[i][j] * Amax[j];
X        if( a < b ) 
X
X            { 
X            Bmin[i] += a; 
X            Bmax[i] += b;
X            }
X        else 
X            { 
X            Bmin[i] += b; 
X            Bmax[i] += a;
X            }
X        }
X
X    /* Copy the result into the new box. */
X
X    B->min.x = Bmin[0];  B->max.x = Bmax[0];
X    B->min.y = Bmin[1];  B->max.y = Bmax[1];
X    B->min.z = Bmin[2];  B->max.z = Bmax[2];
X
X    } 
END_OF_FILE
if test 1672 -ne `wc -c <'TransBox.c'`; then
    echo shar: \"'TransBox.c'\" unpacked with wrong size!
fi
# end of 'TransBox.c'
fi
if test -f 'ViewTrans.c' -a "${1}" != "-c" ; then 
  echo shar: Will not clobber existing file \"'ViewTrans.c'\"
else
echo shar: Extracting \"'ViewTrans.c'\" \(1575 characters\)
sed "s/^X//" >'ViewTrans.c' <<'END_OF_FILE'
X/*
X3D Viewing and Rotation Using Orthonormal Bases
Xby Steve Cunningham
Xfrom "Grahics Gems", Academic Press, 1990
X*/
X
X/*
X * Transformations are presented as 4 by 3 matrices, omitting the
X * fourth column to save memory.
X *
X * Functions are used from the Graphics Gems vector C library
X */
X
X
X#include "GraphicsGems.h"		
X
Xtypedef float Transform[4][3];
X
Xvoid BuildViewTransform( VRP, EP, UP, T )
X	 Point3 VRP, EP, UP;
X	 Transform T;
X{
X	Vector3	U, V, N;
X	float	dot;
X
X	/*
X	 * Compute vector  N = EP - VRP  and normalize  N
X	 */
X	N.x = EP.x - VRP.x; N.y = EP.y - VRP.y; N.z = EP.z - VRP.z;
X	V3Normalize(&N);
X
X	/*
X	 * Compute vector  V = UP - VRP
X	 * Make vector  V  orthogonal to  N  and normalize  V
X	 */
X	V.x = UP.x - VRP.x; V.y = UP.y - VRP.y; V.z = UP.z - VRP.z;
X	dot = V3Dot(&V,&N);
X	V.x -= dot * N.x; V.y -= dot * N.y; V.z -= dot * N.z;
X	V3Normalize(&V);
X
X
X	/*
X	 * Compute vector  U = V x N  (cross product)
X	 */
X	V3Cross(&V,&N,&U);
X
X	/*
X	 * Write the vectors U, V, and N as the first three rows of the
X	 *       first, second, and third columns of  T, respectively
X	 */
X	T[0][0] = U.x;		/* column 1 , vector U */
X	T[1][0] = U.y;
X	T[2][0] = U.z;
X	T[0][1] = V.x;		/* column 2 , vector V */
X	T[1][1] = V.y;
X	T[2][1] = V.z;
X	T[0][2] = N.x;		/* column 3 , vector N */
X	T[1][2] = N.y;
X	T[2][2] = N.z;
X
X	/*
X	 * Compute the fourth row of  T  to include the translation of
X	 *       VRP  to the origin
X	 */
X	T[3][0] = - U.x * VRP.x - U.y * VRP.y - U.z * VRP.z;
X	T[3][1] = - V.x * VRP.x - V.y * VRP.y - V.z * VRP.z;
X	T[3][2] = - N.x * VRP.x - N.y * VRP.y - N.z * VRP.z;
X
X	return;
X}
X
X
END_OF_FILE
if test 1575 -ne `wc -c <'ViewTrans.c'`; then
    echo shar: \"'ViewTrans.c'\" unpacked with wrong size!
fi
# end of 'ViewTrans.c'
fi
echo shar: End of archive 1 \(of 5\).
cp /dev/null ark1isdone
MISSING=""
for I in 1 2 3 4 5 ; do
    if test ! -f ark${I}isdone ; then
	MISSING="${MISSING} ${I}"
    fi
done
if test "${MISSING}" = "" ; then
    echo You have unpacked all 5 archives.
    rm -f ark[1-9]isdone
else
    echo You still need to unpack the following archives:
    echo "        " ${MISSING}
fi
##  End of shell archive.
exit 0


file: /Techref/method/io/graphics/Part01.sh, 58KB, , updated: 1999/6/25 09:58, local time: 2025/1/3 00:25,
TOP NEW HELP FIND: 
18.191.171.121:LOG IN

 ©2025 These pages are served without commercial sponsorship. (No popup ads, etc...).Bandwidth abuse increases hosting cost forcing sponsorship or shutdown. This server aggressively defends against automated copying for any reason including offline viewing, duplication, etc... Please respect this requirement and DO NOT RIP THIS SITE. Questions?
Please DO link to this page! Digg it! / MAKE!

<A HREF="http://massmind.ecomorder.com/Techref/method/io/graphics/Part01.sh"> method io graphics Part01</A>

Did you find what you needed?

 

Welcome to ecomorder.com!

 

Welcome to massmind.ecomorder.com!

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  .