ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/ray/src/rt/ambient.c
(Generate patch)

Comparing ray/src/rt/ambient.c (file contents):
Revision 1.7 by greg, Tue Sep 5 09:46:17 1989 UTC vs.
Revision 1.8 by greg, Fri Jan 12 11:30:59 1990 UTC

# Line 17 | Line 17 | static char SCCSid[] = "$SunId$ LBL";
17  
18   #include  "octree.h"
19  
20 + #include  "otypes.h"
21 +
22   #include  "random.h"
23  
24   #define  OCTSCALE       0.5     /* ceil((valid rad.)/(cube size)) */
# Line 32 | Line 34 | extern int  ambounce;          /* number of ambient bounces */
34   extern char  *amblist[];        /* ambient include/exclude list */
35   extern int  ambincl;            /* include == 1, exclude == 0 */
36  
37 < OBJECT  ambset[128];            /* ambient include/exclude set */
37 > OBJECT  ambset[256]={0};        /* ambient include/exclude set */
38  
39   double  maxarad;                /* maximum ambient radius */
40   double  minarad;                /* minimum ambient radius */
# Line 74 | Line 76 | setambient(afile)                      /* initialize calculation */
76   char  *afile;
77   {
78          long  ftell();
77        char  **amblp;
79          OBJECT  obj;
80          AMBVAL  amb;
81 <                                        /* set up ambient set */
81 <        ambset[0] = 0;
82 <        for (amblp = amblist; *amblp != NULL; amblp++) {
83 <                if ((obj = modifier(*amblp)) == OVOID) {
84 <                        sprintf(errmsg, "unknown %s modifier \"%s\"",
85 <                                ambincl ? "include" : "exclude", *amblp);
86 <                        error(WARNING, errmsg);
87 <                        continue;
88 <                }
89 <                if (!inset(ambset, obj))
90 <                        insertelem(ambset, obj);
91 <        }
81 >
82          maxarad = thescene.cusize / 2.0;                /* maximum radius */
83                                                          /* minimum radius */
84          minarad = ambres > 0 ? thescene.cusize/ambres : 0.0;
# Line 105 | Line 95 | char  *afile;
95                          sprintf(errmsg, "cannot open ambient file \"%s\"",
96                                          afile);
97                          error(SYSTEM, errmsg);
98 +                }
99 + }
100 +
101 +
102 + ambnotify(obj)                  /* record new modifier */
103 + OBJECT  obj;
104 + {
105 +        register OBJREC  *o = objptr(obj);
106 +        register char  **amblp;
107 +
108 +        if (!ismodifier(o->otype))
109 +                return;
110 +        for (amblp = amblist; *amblp != NULL; amblp++)
111 +                if (!strcmp(o->oname, *amblp)) {
112 +                        insertelem(ambset, obj);
113 +                        return;
114                  }
115   }
116  

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines