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

SCM Repository

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

Annotation of /trunk/src/include/Diderot/inline-vec2.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1115 - (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 :     STATIC_INLINE vec2f_t vec2f (float a, float b)
21 :     {
22 :     #ifdef VEC2_OK
23 :     return __extension__ (vec2f_t){ a, b };
24 :     #else
25 :     return __extension__ (vec2f_t){ a, b, 0.0, 0.0 };
26 :     #endif
27 :     }
28 :    
29 :     STATIC_INLINE vec2i_t vec2ftoi (vec2f_t v)
30 :     {
31 :     union2f_t u;
32 :     u.v = v;
33 :     #ifdef VEC2_OK
34 :     return __extension__ (vec2i_t){ (int32_t)u.r[0], (int32_t)u.r[1] };
35 :     #else
36 :     return __extension__ (vec2i_t){ (int32_t)u.r[0], (int32_t)u.r[1], 0, 0 };
37 :     #endif
38 :     }
39 :    
40 :     STATIC_INLINE vec2f_t vec2itof (vec2i_t v)
41 :     {
42 :     union2i_t u;
43 :     u.v = v;
44 :     #ifdef VEC2_OK
45 :     return __extension__ (vec2f_t){ (float)u.i[0], (float)u.i[1] };
46 :     #else
47 :     return __extension__ (vec2f_t){ (float)u.i[0], (float)u.i[1], (float)u.i[2], 0 };
48 :     #endif
49 :     }
50 :    
51 :     STATIC_INLINE vec2f_t scale2f (float s, vec2f_t v)
52 :     {
53 :     return vec2f(s, s) * v;
54 :     }
55 :    
56 :     STATIC_INLINE vec2f_t lerp2f (vec2f_t a, vec2f_t b, float t)
57 :     {
58 :     return a + scale2f(t, b - a);
59 :     }
60 :    
61 :     STATIC_INLINE vec2f_t floor2f (vec2f_t v)
62 :     {
63 :     union2f_t u;
64 :     u.v = v;
65 :     return vec2f(floorf(u.r[0]), floorf(u.r[1]));
66 :     }
67 :    
68 :     STATIC_INLINE vec2i_t truncToInt2f (vec2f_t v)
69 :     {
70 :     union2f_t t;
71 :     t.v = v;
72 :     #ifdef VEC2_OK
73 :     return __extension__ (vec2i_t){
74 :     (int32_t)truncf(t.r[0]),
75 :     (int32_t)truncf(t.r[1]) };
76 :     #else
77 :     return __extension__ (vec2i_t){
78 :     (int32_t)truncf(t.r[0]),
79 :     (int32_t)truncf(t.r[1]),
80 :     0,
81 :     0 };
82 :     #endif
83 :     }
84 :    
85 :     STATIC_INLINE float dot2f (vec2f_t u, vec2f_t v)
86 :     {
87 :     union2f_t uv = __extension__ (union2f_t)(u*v);
88 :     return uv.r[0] + uv.r[1];
89 :     }
90 :    
91 :     STATIC_INLINE float length2f (vec2f_t v)
92 :     {
93 :     return sqrtf(dot2f(v, v));
94 :     }
95 :    
96 :     STATIC_INLINE vec2f_t normalize2f (vec2f_t v)
97 :     {
98 :     return scale2f(1.0 / length2f(v), v);
99 :     }
100 :    
101 :     #endif /* !_DIDEROT_INLINE_VEC2_H_ */

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