ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/ray/src/common/bsdf_t.h
Revision: 3.6
Committed: Sun Apr 24 19:39:21 2011 UTC (13 years ago) by greg
Content type: text/plain
Branch: MAIN
Changes since 3.5: +20 -1 lines
Log Message:
Partial implementation of variable-resolution BSDFs

File Contents

# Content
1 /* RCSid $Id: bsdf_t.h,v 3.5 2011/04/19 21:31:22 greg Exp $ */
2 /*
3 * bsdf_t.h
4 *
5 * Support for variable-resolution BSDF trees.
6 * Assumes "bsdf.h" already included.
7 * Include after "ezxml.h" for SDloadTre() declaration.
8 *
9 * Created by Greg Ward on 2/2/11.
10 *
11 */
12
13 #ifndef _BSDF_T_H_
14 #define _BSDF_T_H_
15
16 #ifdef __cplusplus
17 extern "C" {
18 #endif
19
20 #define SD_MAXDIM 4 /* maximum expected # dimensions */
21
22 /* Basic node structure for variable-resolution BSDF data */
23 typedef struct SDNode_s {
24 short ndim; /* number of dimensions */
25 short log2GR; /* log(2) of grid resolution (< 0 for tree) */
26 union {
27 struct SDNode_s *t[1]; /* subtree pointers */
28 float v[1]; /* scattering value(s) */
29 } u; /* subtrees or values (extends struct) */
30 } SDNode;
31
32 /* Variable-resolution BSDF holder */
33 typedef struct {
34 int isxmit; /* transmitted component? */
35 SDNode *st; /* BSDF tree */
36 } SDTre;
37
38 /* Holder for cumulative distribution (sum of BSDF * projSA) */
39 typedef struct {
40 SD_CDIST_BASE; /* base fields; must come first */
41 double clim[2][2]; /* input coordinate limits */
42 double max_psa; /* maximum projected solid angle */
43 int isxmit; /* transmitted component? */
44 int calen; /* cumulative array length */
45 struct {
46 unsigned hndx; /* hilbert index */
47 unsigned cuml; /* cumulative value */
48 } carr[1]; /* cumulative array (extends struct) */
49 } SDTreCDst;
50
51 #ifdef _EZXML_H
52 /* Load a variable-resolution BSDF tree from an open XML file */
53 extern SDError SDloadTre(SDData *sd, ezxml_t wtl);
54 #endif
55
56 /* Our matrix handling routines */
57 extern SDFunc SDhandleTre;
58
59 #ifdef __cplusplus
60 }
61 #endif
62 #endif /* ! _BSDF_T_H_ */