ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/ray/src/common/rtmath.h
Revision: 3.12
Committed: Thu Mar 10 18:56:34 2016 UTC (8 years, 2 months ago) by schorsch
Content type: text/plain
Branch: MAIN
CVS Tags: rad5R2, rad5R1, rad5R3
Changes since 3.11: +1 -7 lines
Log Message:
everybody seems to have erf() and erfc() nowadays.

File Contents

# User Rev Content
1 schorsch 3.12 /* RCSid $Id: rtmath.h,v 3.11 2016/03/10 18:24:49 schorsch Exp $ */
2 greg 3.1 /*
3     * Header for Radiance vector and math routines
4     */
5    
6     #ifndef _RAD_RTMATH_H_
7     #define _RAD_RTMATH_H_
8    
9     #include <math.h>
10    
11 greg 3.4 #include "tiff.h" /* needed for int32, etc. */
12 schorsch 3.3 #include "mat4.h"
13 greg 3.1
14 schorsch 3.3 #ifdef __cplusplus
15     extern "C" {
16     #endif
17 greg 3.1 /* regular transformation */
18     typedef struct {
19     MAT4 xfm; /* transform matrix */
20     RREAL sca; /* scalefactor */
21     } XF;
22     /* complemetary tranformation */
23     typedef struct {
24     XF f; /* forward */
25     XF b; /* backward */
26     } FULLXF;
27    
28     #ifndef PI
29     #ifdef M_PI
30     #define PI ((double)M_PI)
31     #else
32     #define PI 3.14159265358979323846
33     #endif
34     #endif
35 greg 3.6 /* defined in tcos.c */
36     extern double tcos(double x);
37     extern double atan2a(double y, double x);
38 greg 3.1
39 greg 3.7 #ifdef __FAST_MATH__
40 greg 3.1 #define tcos cos
41     #define tsin sin
42     #define ttan tan
43     #else
44     /* table-based cosine approximation */
45     #define tsin(x) tcos((x)-(PI/2.))
46     #define ttan(x) (tsin(x)/tcos(x))
47     #endif
48 greg 3.8
49 greg 3.1 /* defined in xf.c */
50     extern int xf(XF *ret, int ac, char *av[]);
51     extern int invxf(XF *ret, int ac, char *av[]);
52     extern int fullxf(FULLXF *fx, int ac, char *av[]);
53     /* defined in zeroes.c */
54 schorsch 3.2 extern int quadratic(double *r, double a, double b, double c);
55 greg 3.1 /* defined in dircode.c */
56     extern int32 encodedir(FVECT dv);
57     extern void decodedir(FVECT dv, int32 dc);
58     extern double dir2diff(int32 dc1, int32 dc2);
59     extern double fdir2diff(int32 dc1, FVECT v2);
60    
61     #ifdef __cplusplus
62     }
63     #endif
64     #endif /* _RAD_RTMATH_H_ */
65