ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/ray/src/rt/ray.h
Revision: 1.6
Committed: Thu Jun 20 13:29:31 1991 UTC (32 years, 10 months ago) by greg
Content type: text/plain
Branch: MAIN
Changes since 1.5: +5 -0 lines
Log Message:
added revf member to ray structure for dynamic evaluation

File Contents

# User Rev Content
1 greg 1.4 /* Copyright (c) 1990 Regents of the University of California */
2 greg 1.1
3     /* SCCSid "$SunId$ LBL" */
4    
5     /*
6     * ray.h - header file for routines using rays.
7     *
8     * 8/7/85
9     */
10    
11     #include "standard.h"
12    
13     #include "object.h"
14    
15     #include "color.h"
16    
17     /* ray type flags */
18     #define PRIMARY 01 /* original ray */
19     #define SHADOW 02 /* ray to light source */
20     #define REFLECTED 04 /* reflected ray */
21     #define REFRACTED 010 /* refracted (bent) ray */
22     #define TRANS 020 /* transmitted/transferred ray */
23     #define AMBIENT 040 /* ray scattered for interreflection */
24    
25     /* reflected ray types */
26     #define RAYREFL (SHADOW|REFLECTED|AMBIENT)
27    
28     typedef struct ray {
29     long rno; /* unique ray number */
30     int rlvl; /* number of reflections for this ray */
31     float rweight; /* cumulative weight of this ray */
32     short rtype; /* ray type */
33     short crtype; /* cumulative ray type */
34     struct ray *parent; /* ray this originated from */
35     FVECT rorg; /* origin of ray */
36     FVECT rdir; /* normalized direction of ray */
37     int rsrc; /* source we're aiming for */
38     OBJECT *clipset; /* set of objects currently clipped */
39     OBJECT *newcset; /* next clipset, used for transmission */
40 greg 1.6 int (*revf)(); /* evaluation function for this ray */
41 greg 1.1 OBJREC *ro; /* intersected object */
42     double rot; /* distance to object */
43     FVECT rop; /* intersection point */
44     FVECT ron; /* intersection surface normal */
45     double rod; /* -DOT(rdir, ron) */
46 greg 1.4 FULLXF *rox; /* object transformation */
47 greg 1.1 FVECT pert; /* surface normal perturbation */
48     COLOR pcol; /* pattern color */
49     COLOR rcol; /* returned ray value */
50 greg 1.3 double rt; /* returned effective ray length */
51 greg 1.1 } RAY;
52    
53 greg 1.6 extern int raytrace();
54    
55 greg 1.1 extern double raynormal();
56 greg 1.5
57     extern int dimlist[]; /* dimension list for distribution */
58     extern int ndims; /* number of dimensions so far */
59     extern int samplendx; /* index for this sample */
60    
61     #define MAXDIM 16 /* maximum number of dimensions */
62 greg 1.6
63     #define rayvalue(r) (*(r)->revf)(r)