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

SCM Repository

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

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

Parent Directory Parent Directory | Revision Log Revision Log


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

1 : jhr 1115 /*! \file inline-vec4.h
2 :     *
3 :     * \author John Reppy
4 :     *
5 :     * \brief inline functions for 4D 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_VEC4_H_
14 :     #define _DIDEROT_INLINE_VEC4_H_
15 :    
16 :     #ifndef _DIDEROT_TYPES_H_
17 :     #include "Diderot/types.h"
18 :     #endif
19 :    
20 :     STATIC_INLINE vec4f_t vec4f (float a, float b, float c, float d)
21 :     {
22 :     return __extension__ (vec4f_t){ a, b, c, d };
23 :     }
24 :    
25 :     STATIC_INLINE vec4i_t vec4ftoi (vec4f_t v)
26 :     {
27 :     union4f_t u;
28 :     u.v = v;
29 :     return __extension__ (vec4i_t){ (int32_t)u.r[0], (int32_t)u.r[1], (int32_t)u.r[2], (int32_t)u.r[3] };
30 :     }
31 :    
32 :     STATIC_INLINE vec4f_t vec4itof (vec4i_t v)
33 :     {
34 :     union4i_t u;
35 :     u.v = v;
36 :     return __extension__ (vec4f_t){ (float)u.i[0], (float)u.i[1], (float)u.i[2], (float)u.i[3] };
37 :     }
38 :    
39 :     STATIC_INLINE vec4f_t scale4f (float s, vec4f_t v)
40 :     {
41 :     return vec4f(s, s, s, s) * v;
42 :     }
43 :    
44 : jhr 1295 STATIC_INLINE vec4f_t clamp4f (vec4f_t lo, vec4f_t hi, vec4f_t v)
45 :     {
46 :     // FIXME: there is probably a vectorized way to compute this
47 :     union4f_t a, b, c;
48 :     a.v = lo; b.v = hi; c.v = v;
49 :     return vec4f(
50 :     clampf(a.r[0], b.r[0], c.r[0]),
51 :     clampf(a.r[1], b.r[1], c.r[1]),
52 :     clampf(a.r[2], b.r[2], c.r[2]),
53 :     clampf(a.r[3], b.r[3], c.r[3]));
54 :     }
55 :    
56 : jhr 1115 STATIC_INLINE vec4f_t lerp4f (vec4f_t a, vec4f_t b, float t)
57 :     {
58 :     return a + scale4f(t, b - a);
59 :     }
60 :    
61 :     STATIC_INLINE vec4f_t floor4f (vec4f_t v)
62 :     {
63 :     union4f_t u;
64 :     u.v = v;
65 :     return vec4f(floorf(u.r[0]), floorf(u.r[1]), floorf(u.r[2]), floorf(u.r[3]));
66 :     }
67 :    
68 :     STATIC_INLINE vec4i_t truncToInt4f (vec4f_t v)
69 :     {
70 :     union4f_t t;
71 :     t.v = v;
72 :     return __extension__ (vec4i_t){
73 :     (int32_t)truncf(t.r[0]),
74 :     (int32_t)truncf(t.r[1]),
75 :     (int32_t)truncf(t.r[2]),
76 :     (int32_t)truncf(t.r[4]) };
77 :     }
78 :    
79 :     STATIC_INLINE float dot4f (vec4f_t u, vec4f_t v)
80 :     {
81 :     union4f_t uv = __extension__ (union4f_t)(u*v);
82 :     return uv.r[0] + uv.r[1] + uv.r[2] + uv.r[3];
83 :     }
84 :    
85 :     STATIC_INLINE float length4f (vec4f_t v)
86 :     {
87 :     return sqrtf(dot4f(v, v));
88 :     }
89 :    
90 :     STATIC_INLINE vec4f_t normalize4f (vec4f_t v)
91 :     {
92 :     return scale4f(1.0 / length4f(v), v);
93 :     }
94 :    
95 :     #endif /* !_DIDEROT_INLINE_VEC4_H_ */

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