--- ray/src/common/bsdf_t.h 2011/08/21 22:38:12 3.9 +++ ray/src/common/bsdf_t.h 2015/04/05 01:32:01 3.12 @@ -1,4 +1,4 @@ -/* RCSid $Id: bsdf_t.h,v 3.9 2011/08/21 22:38:12 greg Exp $ */ +/* RCSid $Id: bsdf_t.h,v 3.12 2015/04/05 01:32:01 greg Exp $ */ /* * bsdf_t.h * @@ -29,14 +29,15 @@ typedef struct SDNode_s { } u; /* subtrees or values (extends struct) */ } SDNode; -#define SD_UFRONT 0x1 /* flag for BSDF uses front side */ -#define SD_UBACK 0x2 /* flag for BSDF uses back side */ -#define SD_XMIT 0x3 /* combine the two for transmission */ +#define SD_FREFL 1 /* component reflects off front side */ +#define SD_BREFL 2 /* component reflects off back side */ +#define SD_FXMIT 3 /* component transmits through front side */ +#define SD_BXMIT 4 /* component transmits through back side */ /* Variable-resolution BSDF holder */ typedef struct { - int sidef; /* transmitted component? */ - SDNode *st; /* BSDF tree */ + int sidef; /* which component */ + SDNode *stc[3]; /* BSDF (Y,u,v) trees */ } SDTre; /* Holder for cumulative distribution (sum of BSDF * projSA) */ @@ -45,13 +46,13 @@ typedef struct SDTreCDst_s { SD_CDIST_BASE(SDTreCDst_s); double clim[2][2]; /* input coordinate limits */ double max_psa; /* maximum projected solid angle */ - short sidef; /* which side(s) to use */ + short sidef; /* which mode is in play */ short isodist; /* isotropic distribution? */ int calen; /* cumulative array length */ struct { unsigned hndx; /* hilbert index */ unsigned cuml; /* cumulative value */ - } carr[1]; /* cumulative array (extends struct) */ + } carr[1]; /* cumulative array (extends struct) */ } SDTreCDst; #ifdef _EZXML_H