ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/ray/src/common/rtmath.h
Revision: 3.13
Committed: Fri Dec 3 16:50:05 2021 UTC (2 years, 10 months ago) by greg
Content type: text/plain
Branch: MAIN
Changes since 3.12: +5 -1 lines
Log Message:
chore: added declarations for disk2square to rtmath.h

File Contents

# Content
1 /* RCSid $Id: rtmath.h,v 3.12 2016/03/10 18:56:34 schorsch Exp $ */
2 /*
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 #include "tiff.h" /* needed for int32, etc. */
12 #include "mat4.h"
13
14 #ifdef __cplusplus
15 extern "C" {
16 #endif
17 /* 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 /* defined in tcos.c */
36 extern double tcos(double x);
37 extern double atan2a(double y, double x);
38
39 #ifdef __FAST_MATH__
40 #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
49 /* defined in disk2square.c */
50 extern void SDsquare2disk(double ds[2], double seedx, double seedy);
51 extern void SDdisk2square(double sq[2], double diskx, double disky);
52
53 /* defined in xf.c */
54 extern int xf(XF *ret, int ac, char *av[]);
55 extern int invxf(XF *ret, int ac, char *av[]);
56 extern int fullxf(FULLXF *fx, int ac, char *av[]);
57 /* defined in zeroes.c */
58 extern int quadratic(double *r, double a, double b, double c);
59 /* defined in dircode.c */
60 extern int32 encodedir(FVECT dv);
61 extern void decodedir(FVECT dv, int32 dc);
62 extern double dir2diff(int32 dc1, int32 dc2);
63 extern double fdir2diff(int32 dc1, FVECT v2);
64
65 #ifdef __cplusplus
66 }
67 #endif
68 #endif /* _RAD_RTMATH_H_ */
69