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 3349 - (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 : jhr 3349 * This code is part of the Diderot Project (http://diderot-language.cs.uchicago.edu)
10 :     *
11 :     * COPYRIGHT (c) 2015 The University of Chicago
12 : jhr 1115 * All rights reserved.
13 :     */
14 :    
15 :     #ifndef _DIDEROT_INLINE_VEC4_H_
16 :     #define _DIDEROT_INLINE_VEC4_H_
17 :    
18 :     #ifndef _DIDEROT_TYPES_H_
19 :     #include "Diderot/types.h"
20 :     #endif
21 :    
22 : jhr 2356 STATIC_INLINE Diderot_vec4_t vec4 (Diderot_real_t a, Diderot_real_t b, Diderot_real_t c, Diderot_real_t d)
23 : jhr 1115 {
24 : jhr 1640 return __extension__ (Diderot_vec4_t){ a, b, c, d };
25 : jhr 1115 }
26 :    
27 : jhr 1640 STATIC_INLINE Diderot_ivec4_t vec4rtoi (Diderot_vec4_t v)
28 : jhr 1115 {
29 : jhr 1640 Diderot_union4_t u;
30 : jhr 1115 u.v = v;
31 : jhr 1640 return __extension__ (Diderot_ivec4_t){
32 :     (Diderot_int_t)u.r[0],
33 :     (Diderot_int_t)u.r[1],
34 :     (Diderot_int_t)u.r[2],
35 :     (Diderot_int_t)u.r[3]
36 :     };
37 : jhr 1115 }
38 :    
39 : jhr 1640 STATIC_INLINE Diderot_vec4_t vec4itor (Diderot_ivec4_t v)
40 : jhr 1115 {
41 :     union4i_t u;
42 :     u.v = v;
43 : jhr 2356 return __extension__ (Diderot_vec4_t){ (Diderot_real_t)u.i[0], (Diderot_real_t)u.i[1], (Diderot_real_t)u.i[2], (Diderot_real_t)u.i[3] };
44 : jhr 1115 }
45 :    
46 : jhr 2356 STATIC_INLINE Diderot_vec4_t scale4 (Diderot_real_t s, Diderot_vec4_t v)
47 : jhr 1115 {
48 : jhr 1640 return vec4(s, s, s, s) * v;
49 : jhr 1115 }
50 :    
51 : jhr 1640 STATIC_INLINE Diderot_vec4_t clamp4 (Diderot_vec4_t lo, Diderot_vec4_t hi, Diderot_vec4_t v)
52 : jhr 1295 {
53 :     // FIXME: there is probably a vectorized way to compute this
54 : jhr 1640 Diderot_union4_t a, b, c;
55 : jhr 1295 a.v = lo; b.v = hi; c.v = v;
56 : jhr 1640 return vec4(
57 :     clamp(a.r[0], b.r[0], c.r[0]),
58 :     clamp(a.r[1], b.r[1], c.r[1]),
59 :     clamp(a.r[2], b.r[2], c.r[2]),
60 :     clamp(a.r[3], b.r[3], c.r[3]));
61 : jhr 1295 }
62 :    
63 : jhr 2356 STATIC_INLINE Diderot_vec4_t lerp4 (Diderot_vec4_t a, Diderot_vec4_t b, Diderot_real_t t)
64 : jhr 1115 {
65 : jhr 1640 return a + scale4(t, b - a);
66 : jhr 1115 }
67 :    
68 : jhr 1640 STATIC_INLINE Diderot_vec4_t floor4 (Diderot_vec4_t v)
69 : jhr 1115 {
70 : jhr 1640 Diderot_union4_t u;
71 : jhr 1115 u.v = v;
72 : jhr 1640 return vec4(FLOOR(u.r[0]), FLOOR(u.r[1]), FLOOR(u.r[2]), FLOOR(u.r[3]));
73 : jhr 1115 }
74 :    
75 : jhr 1640 STATIC_INLINE Diderot_ivec4_t truncToInt4 (Diderot_vec4_t v)
76 : jhr 1115 {
77 : jhr 1640 Diderot_union4_t t;
78 : jhr 1115 t.v = v;
79 : jhr 1640 return __extension__ (Diderot_ivec4_t){
80 :     (Diderot_int_t)TRUNC(t.r[0]),
81 :     (Diderot_int_t)TRUNC(t.r[1]),
82 :     (Diderot_int_t)TRUNC(t.r[2]),
83 :     (Diderot_int_t)TRUNC(t.r[3]) };
84 : jhr 1115 }
85 :    
86 : jhr 2356 STATIC_INLINE Diderot_real_t dot4 (Diderot_vec4_t u, Diderot_vec4_t v)
87 : jhr 1115 {
88 : jhr 1640 Diderot_union4_t uv = __extension__ (Diderot_union4_t)(u*v);
89 : jhr 1115 return uv.r[0] + uv.r[1] + uv.r[2] + uv.r[3];
90 :     }
91 :    
92 : jhr 2356 STATIC_INLINE Diderot_real_t length4 (Diderot_vec4_t v)
93 : jhr 1115 {
94 : jhr 1640 return SQRT(dot4(v, v));
95 : jhr 1115 }
96 :    
97 : jhr 1640 STATIC_INLINE Diderot_vec4_t normalize4 (Diderot_vec4_t v)
98 : jhr 1115 {
99 : jhr 1640 return scale4(1.0 / length4(v), v);
100 : jhr 1115 }
101 :    
102 :     #endif /* !_DIDEROT_INLINE_VEC4_H_ */

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