Home My Page Projects Code Snippets Project Openings diderot
Summary Activity Tracker Tasks SCM

SCM Repository

[diderot] Annotation of /branches/lamont/src/include/Diderot/inline-vec2.h
ViewVC logotype

Annotation of /branches/lamont/src/include/Diderot/inline-vec2.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2418 - (view) (download) (as text)

1 : jhr 1115 /*! \file inline-vec2.h
2 :     *
3 :     * \author John Reppy
4 :     *
5 :     * \brief inline functions for 2D vectors
6 :     */
7 :    
8 :     /*
9 :     * COPYRIGHT (c) 2011 The Diderot Project (http://diderot-language.cs.uchicago.edu)
10 :     * All rights reserved.
11 :     */
12 :    
13 :     #ifndef _DIDEROT_INLINE_VEC2_H_
14 :     #define _DIDEROT_INLINE_VEC2_H_
15 :    
16 :     #ifndef _DIDEROT_TYPES_H_
17 :     #include "Diderot/types.h"
18 :     #endif
19 :    
20 : jhr 1640 STATIC_INLINE Diderot_vec2_t vec2 (Diderot_real_t a, Diderot_real_t b)
21 : jhr 1115 {
22 :     #ifdef VEC2_OK
23 : jhr 1640 return __extension__ (Diderot_vec2_t){ a, b };
24 : jhr 1115 #else
25 : jhr 1640 return __extension__ (Diderot_vec2_t){ a, b, 0.0, 0.0 };
26 : jhr 1115 #endif
27 :     }
28 : lamonts 2162 STATIC_INLINE Diderot_ivec2_t vec2i (Diderot_int_t x, Diderot_int_t y)
29 :     {
30 :     #ifdef VEC2_OK
31 :     return __extension__ (Diderot_ivec2_t){x,y};
32 :     #else
33 :     return __extension__ (Diderot_ivec2_t){x,y, 0, 0 };
34 :     #endif
35 :     }
36 : jhr 1640 STATIC_INLINE Diderot_ivec2_t vec2rtoi (Diderot_vec2_t v)
37 : jhr 1115 {
38 : jhr 1640 Diderot_union2_t u;
39 : jhr 1115 u.v = v;
40 :     #ifdef VEC2_OK
41 : jhr 1640 return __extension__ (Diderot_ivec2_t){ (Diderot_int_t)u.r[0], (Diderot_int_t)u.r[1] };
42 : jhr 1115 #else
43 : jhr 1640 return __extension__ (Diderot_ivec2_t){ (Diderot_int_t)u.r[0], (Diderot_int_t)u.r[1], 0, 0 };
44 : jhr 1115 #endif
45 :     }
46 :    
47 : jhr 1640 STATIC_INLINE Diderot_vec2_t vec2itor (Diderot_ivec2_t v)
48 : jhr 1115 {
49 :     union2i_t u;
50 :     u.v = v;
51 :     #ifdef VEC2_OK
52 : jhr 1640 return __extension__ (Diderot_vec2_t){ (Diderot_real_t)u.i[0], (Diderot_real_t)u.i[1] };
53 : jhr 1115 #else
54 : jhr 1640 return __extension__ (Diderot_vec2_t){ (Diderot_real_t)u.i[0], (Diderot_real_t)u.i[1], (Diderot_real_t)u.i[2], 0 };
55 : jhr 1115 #endif
56 :     }
57 :    
58 : jhr 1640 STATIC_INLINE Diderot_vec2_t scale2 (Diderot_real_t s, Diderot_vec2_t v)
59 : jhr 1115 {
60 : jhr 1640 return vec2(s, s) * v;
61 : jhr 1115 }
62 :    
63 : jhr 1640 STATIC_INLINE Diderot_vec2_t clamp2 (Diderot_vec2_t lo, Diderot_vec2_t hi, Diderot_vec2_t v)
64 : jhr 1295 {
65 :     // FIXME: there is probably a vectorized way to compute this
66 : jhr 1640 Diderot_union2_t a, b, c;
67 : jhr 1295 a.v = lo; b.v = hi; c.v = v;
68 : jhr 1640 return vec2(
69 :     clamp(a.r[0], b.r[0], c.r[0]),
70 :     clamp(a.r[1], b.r[1], c.r[1]));
71 : jhr 1295 }
72 :    
73 : jhr 1640 STATIC_INLINE Diderot_vec2_t lerp2 (Diderot_vec2_t a, Diderot_vec2_t b, Diderot_real_t t)
74 : jhr 1115 {
75 : jhr 1640 return a + scale2(t, b - a);
76 : jhr 1115 }
77 :    
78 : jhr 1640 STATIC_INLINE Diderot_vec2_t floor2 (Diderot_vec2_t v)
79 : jhr 1115 {
80 : jhr 1640 Diderot_union2_t u;
81 : jhr 1115 u.v = v;
82 : jhr 1640 return vec2(FLOOR(u.r[0]), FLOOR(u.r[1]));
83 : jhr 1115 }
84 :    
85 : jhr 1640 STATIC_INLINE Diderot_ivec2_t truncToInt2 (Diderot_vec2_t v)
86 : jhr 1115 {
87 : jhr 1640 Diderot_union2_t t;
88 : jhr 1115 t.v = v;
89 :     #ifdef VEC2_OK
90 : jhr 1640 return __extension__ (Diderot_ivec2_t){
91 :     (Diderot_int_t)TRUNC(t.r[0]),
92 :     (Diderot_int_t)TRUNC(t.r[1]) };
93 : jhr 1115 #else
94 : jhr 1640 return __extension__ (Diderot_ivec2_t){
95 :     (Diderot_int_t)TRUNC(t.r[0]),
96 :     (Diderot_int_t)TRUNC(t.r[1]),
97 : jhr 1370 0,
98 :     0 };
99 : jhr 1115 #endif
100 :     }
101 :    
102 : jhr 1640 STATIC_INLINE Diderot_real_t dot2 (Diderot_vec2_t u, Diderot_vec2_t v)
103 : jhr 1115 {
104 : jhr 1640 Diderot_union2_t uv = __extension__ (Diderot_union2_t)(u*v);
105 : jhr 1115 return uv.r[0] + uv.r[1];
106 :     }
107 :    
108 : jhr 2418 STATIC_INLINE Diderot_real_t lengthSq2 (Diderot_vec2_t v)
109 :     {
110 :     return dot2(v, v);
111 :     }
112 :    
113 : jhr 1640 STATIC_INLINE Diderot_real_t length2 (Diderot_vec2_t v)
114 : jhr 1115 {
115 : jhr 2418 return SQRT(lengthSq2(v));
116 : jhr 1115 }
117 :    
118 : jhr 2418 STATIC_INLINE Diderot_real_t dist2 (Diderot_vec2_t u, Diderot_vec2_t v)
119 :     {
120 :     return length2(v-u);
121 :     }
122 :    
123 : jhr 1640 STATIC_INLINE Diderot_vec2_t normalize2 (Diderot_vec2_t v)
124 : jhr 1115 {
125 : jhr 1640 return scale2(1.0 / length2(v), v);
126 : jhr 1115 }
127 :    
128 :     #endif /* !_DIDEROT_INLINE_VEC2_H_ */

root@smlnj-gforge.cs.uchicago.edu
ViewVC Help
Powered by ViewVC 1.0.0