--- ray/src/rt/ambient.c 2014/05/07 01:16:03 2.86 +++ ray/src/rt/ambient.c 2014/05/09 23:08:50 2.88 @@ -1,5 +1,5 @@ #ifndef lint -static const char RCSid[] = "$Id: ambient.c,v 2.86 2014/05/07 01:16:03 greg Exp $"; +static const char RCSid[] = "$Id: ambient.c,v 2.88 2014/05/09 23:08:50 greg Exp $"; #endif /* * ambient.c - routines dealing with ambient (inter-reflected) component. @@ -165,7 +165,7 @@ setambient(void) /* initialize calculation */ initambfile(0); /* file exists */ lastpos = ftell(ambfp); while (readambval(&amb, ambfp)) - avinsert(avstore(&amb)); + avstore(&amb); nambshare = nambvals; /* share loaded values */ if (readonly) { sprintf(errmsg, @@ -443,10 +443,9 @@ sumambient( /* get interpolated ambient value */ /* * Ambient level test */ - if (av->lvl > al) /* list sorted, so this works */ + if (av->lvl > al || /* list sorted, so this works */ + (av->lvl == al) & (av->weight < 0.9*r->rweight)) break; - if (av->weight < 0.9*r->rweight) - continue; /* * Direction test using unperturbed normal */ @@ -608,7 +607,9 @@ avinsert( /* insert ambient value in our tree */ } avh.next = at->alist; /* order by increasing level */ for (ap = &avh; ap->next != NULL; ap = ap->next) - if (ap->next->lvl >= av->lvl) + if ( ap->next->lvl > av->lvl || + (ap->next->lvl == av->lvl) & + (ap->next->weight <= av->weight) ) break; av->next = ap->next; ap->next = (AMBVAL*)av; @@ -721,10 +722,9 @@ sumambient( /* get interpolated ambient value */ /* * Ambient level test. */ - if (av->lvl > al) /* list sorted, so this works */ + if (av->lvl > al || /* list sorted, so this works */ + (av->lvl == al) & (av->weight < 0.9*r->rweight)) break; - if (av->weight < 0.9*r->rweight) - continue; /* * Ambient radius test. */ @@ -906,7 +906,9 @@ avinsert( /* insert ambient value in our tree */ } avh.next = at->alist; /* order by increasing level */ for (ap = &avh; ap->next != NULL; ap = ap->next) - if (ap->next->lvl >= av->lvl) + if ( ap->next->lvl > av->lvl || + (ap->next->lvl == av->lvl) & + (ap->next->weight <= av->weight) ) break; av->next = ap->next; ap->next = (AMBVAL*)av; @@ -958,7 +960,7 @@ avsave( /* insert and save an ambient value */ AMBVAL *av ) { - avinsert(avstore(av)); + avstore(av); if (ambfp == NULL) return; if (writambval(av, ambfp) < 0) @@ -973,7 +975,7 @@ writerr: static AMBVAL * -avstore( /* allocate memory and store aval */ +avstore( /* allocate memory and save aval */ AMBVAL *aval ) { @@ -991,6 +993,7 @@ avstore( /* allocate memory and store aval */ avsum += log(d); navsum++; } + avinsert(av); /* insert in our cache tree */ return(av); } @@ -1273,7 +1276,7 @@ ambsync(void) /* synchronize ambient file */ error(WARNING, errmsg); break; } - avinsert(avstore(&avs)); + avstore(&avs); n -= AMBVALSIZ; } lastpos = flen - n;