| 11 |  | #include "color.h" | 
| 12 |  | #include "setscan.h" | 
| 13 |  |  | 
| 14 | < | #define GLAREBR         10.0            /* glare source is this * avg. lum. */ | 
| 14 | > | #define GLAREBR         7.0             /* glare source is this * avg. lum. */ | 
| 15 |  |  | 
| 16 | < | #define SAMPDENS        50              /* default samples per unit in image */ | 
| 16 | > | #define SAMPDENS        75              /* default samples per unit in image */ | 
| 17 |  | #define TSAMPSTEP       10              /* sample step to compute threshold */ | 
| 18 |  |  | 
| 19 | < | #define SEPS            2               /* sources this close ==> contig. */ | 
| 19 | > | #define SEPS            1               /* sources this close ==> contig. */ | 
| 20 |  |  | 
| 21 | + | #define SAMIN           .005            /* minimum solid angle for source */ | 
| 22 | + | #define MAXBUDDY        (4.*sqrt(SAMIN/PI))     /* max separation for pairing */ | 
| 23 | + |  | 
| 24 | + | #define TOOSMALL(s)     ((s)->brt*(s)->dom < threshold*SAMIN) | 
| 25 | + |  | 
| 26 | + | #define SABIG           .025            /* solid angle of splittable source */ | 
| 27 | + | #define LCORR           .8              /* linearity of splittable source */ | 
| 28 | + |  | 
| 29 |  | extern VIEW     ourview;                /* our view */ | 
| 30 |  | extern VIEW     pictview;               /* picture view */ | 
| 31 |  | extern VIEW     leftview, rightview;    /* leftmost and rightmost views */ | 
| 40 |  | extern int      nglarangs; | 
| 41 |  | extern double   maxtheta;               /* maximum glare angle (in radians) */ | 
| 42 |  | extern int      hsize;                  /* horizontal size */ | 
| 35 | – | extern int      hlim;                   /* horizontal limit of central view */ | 
| 43 |  |  | 
| 44 |  | #define nglardirs       (2*nglarangs+1) | 
| 45 |  | #define vsize           (sampdens-1) | 
| 46 | < | #define h_theta(h)      (-(double)(h)/(double)sampdens) | 
| 46 | > | #define hscale(v)       sqrt((double)(sampdens*sampdens - (v)*(v))) | 
| 47 | > | #define hlim(v)         (int)(maxtheta*hscale(v)) | 
| 48 | > | #define h_theta(h,v)    (-(h)/hscale(v)) | 
| 49 |  |  | 
| 50 |  | extern struct illum { | 
| 51 |  | float   theta;          /* glare direction */ | 
| 52 |  | float   lcos, lsin;     /* cosine and sine to left view */ | 
| 53 |  | float   rcos, rsin;     /* cosine and sine to right view */ | 
| 54 |  | double  sum;            /* sum of indirect luminances */ | 
| 55 | < | int     n;              /* number of values in sum */ | 
| 55 | > | double  n;              /* number of values in sum */ | 
| 56 |  | } *indirect;            /* array of indirect illuminances */ | 
| 57 |  |  | 
| 58 |  | struct srcspan { | 
| 71 |  | } *donelist;                    /* finished sources */ | 
| 72 |  |  | 
| 73 |  | extern double   getviewpix(); | 
| 74 | + | extern double   pixsize(); | 
| 75 | + |  | 
| 76 | + | extern long     npixinvw;       /* number of samples in view */ | 
| 77 | + | extern long     npixmiss;       /* number of samples missing */ |