3rdparty/glm/doc/api/a00108_source.html
| | 0.9.8 |
gtc/type_aligned.hpp
Go to the documentation of this file.
1
12 #pragma once
13
14 #if !GLM_HAS_ALIGNED_TYPE
15 # error "GLM: Aligned types are not supported on this platform"
16 #endif
17 #if GLM_MESSAGES == GLM_MESSAGES_ENABLED && !defined(GLM_EXT_INCLUDED)
18 # pragma message("GLM: GLM_GTC_type_aligned extension included")
19 #endif
20
21 #include "../vec2.hpp"
22 #include "../vec3.hpp"
23 #include "../vec4.hpp"
24 #include "../gtc/vec1.hpp"
25
26 namespace glm
27 {
28template <typename T, precision P> struct tvec1;
29template <typename T, precision P> struct tvec2;
30template <typename T, precision P> struct tvec3;
31template <typename T, precision P> struct tvec4;
34
35// -- *vec1 --
36
37typedef tvec1<float, aligned_highp> aligned_highp_vec1;
38typedef tvec1<float, aligned_mediump> aligned_mediump_vec1;
39typedef tvec1<float, aligned_lowp> aligned_lowp_vec1;
40typedef tvec1<double, aligned_highp> aligned_highp_dvec1;
41typedef tvec1<double, aligned_mediump> aligned_mediump_dvec1;
42typedef tvec1<double, aligned_lowp> aligned_lowp_dvec1;
43typedef tvec1<int, aligned_highp> aligned_highp_ivec1;
44typedef tvec1<int, aligned_mediump> aligned_mediump_ivec1;
45typedef tvec1<int, aligned_lowp> aligned_lowp_ivec1;
46typedef tvec1<uint, aligned_highp> aligned_highp_uvec1;
47typedef tvec1<uint, aligned_mediump> aligned_mediump_uvec1;
48typedef tvec1<uint, aligned_lowp> aligned_lowp_uvec1;
49typedef tvec1<bool, aligned_highp> aligned_highp_bvec1;
50typedef tvec1<bool, aligned_mediump> aligned_mediump_bvec1;
51typedef tvec1<bool, aligned_lowp> aligned_lowp_bvec1;
52
53typedef tvec1<float, packed_highp> packed_highp_vec1;
54typedef tvec1<float, packed_mediump> packed_mediump_vec1;
55typedef tvec1<float, packed_lowp> packed_lowp_vec1;
56typedef tvec1<double, packed_highp> packed_highp_dvec1;
57typedef tvec1<double, packed_mediump> packed_mediump_dvec1;
58typedef tvec1<double, packed_lowp> packed_lowp_dvec1;
59typedef tvec1<int, packed_highp> packed_highp_ivec1;
60typedef tvec1<int, packed_mediump> packed_mediump_ivec1;
61typedef tvec1<int, packed_lowp> packed_lowp_ivec1;
62typedef tvec1<uint, packed_highp> packed_highp_uvec1;
63typedef tvec1<uint, packed_mediump> packed_mediump_uvec1;
64typedef tvec1<uint, packed_lowp> packed_lowp_uvec1;
65typedef tvec1<bool, packed_highp> packed_highp_bvec1;
66typedef tvec1<bool, packed_mediump> packed_mediump_bvec1;
67typedef tvec1<bool, packed_lowp> packed_lowp_bvec1;
68
69// -- *vec2 --
70
73typedef tvec2<float, aligned_highp> aligned_highp_vec2;
74
77typedef tvec2<float, aligned_mediump> aligned_mediump_vec2;
78
81typedef tvec2<float, aligned_lowp> aligned_lowp_vec2;
82
85typedef tvec2<double, aligned_highp> aligned_highp_dvec2;
86
89typedef tvec2<double, aligned_mediump> aligned_mediump_dvec2;
90
93typedef tvec2<double, aligned_lowp> aligned_lowp_dvec2;
94
97typedef tvec2<int, aligned_highp> aligned_highp_ivec2;
98
101typedef tvec2<int, aligned_mediump> aligned_mediump_ivec2;
102
105typedef tvec2<int, aligned_lowp> aligned_lowp_ivec2;
106
109typedef tvec2<uint, aligned_highp> aligned_highp_uvec2;
110
113typedef tvec2<uint, aligned_mediump> aligned_mediump_uvec2;
114
117typedef tvec2<uint, aligned_lowp> aligned_lowp_uvec2;
118
121typedef tvec2<bool, aligned_highp> aligned_highp_bvec2;
122
125typedef tvec2<bool, aligned_mediump> aligned_mediump_bvec2;
126
129typedef tvec2<bool, aligned_lowp> aligned_lowp_bvec2;
130
131// -- *vec3 --
132
135typedef tvec3<float, aligned_highp> aligned_highp_vec3;
136
139typedef tvec3<float, aligned_mediump> aligned_mediump_vec3;
140
143typedef tvec3<float, aligned_lowp> aligned_lowp_vec3;
144
147typedef tvec3<double, aligned_highp> aligned_highp_dvec3;
148
151typedef tvec3<double, aligned_mediump> aligned_mediump_dvec3;
152
155typedef tvec3<double, aligned_lowp> aligned_lowp_dvec3;
156
159typedef tvec3<int, aligned_highp> aligned_highp_ivec3;
160
163typedef tvec3<int, aligned_mediump> aligned_mediump_ivec3;
164
167typedef tvec3<int, aligned_lowp> aligned_lowp_ivec3;
168
171typedef tvec3<uint, aligned_highp> aligned_highp_uvec3;
172
175typedef tvec3<uint, aligned_mediump> aligned_mediump_uvec3;
176
179typedef tvec3<uint, aligned_lowp> aligned_lowp_uvec3;
180
182typedef tvec3<bool, aligned_highp> aligned_highp_bvec3;
183
185typedef tvec3<bool, aligned_mediump> aligned_mediump_bvec3;
186
188typedef tvec3<bool, aligned_lowp> aligned_lowp_bvec3;
189
190// -- *vec4 --
191
193typedef tvec4<float, aligned_highp> aligned_highp_vec4;
194
196typedef tvec4<float, aligned_mediump> aligned_mediump_vec4;
197
199typedef tvec4<float, aligned_lowp> aligned_lowp_vec4;
200
202typedef tvec4<double, aligned_highp> aligned_highp_dvec4;
203
205typedef tvec4<double, aligned_mediump> aligned_mediump_dvec4;
206
208typedef tvec4<double, aligned_lowp> aligned_lowp_dvec4;
209
211typedef tvec4<int, aligned_highp> aligned_highp_ivec4;
212
214typedef tvec4<int, aligned_mediump> aligned_mediump_ivec4;
215
217typedef tvec4<int, aligned_lowp> aligned_lowp_ivec4;
218
220typedef tvec4<uint, aligned_highp> aligned_highp_uvec4;
221
223typedef tvec4<uint, aligned_mediump> aligned_mediump_uvec4;
224
226typedef tvec4<uint, aligned_lowp> aligned_lowp_uvec4;
227
229typedef tvec4<bool, aligned_highp> aligned_highp_bvec4;
230
232typedef tvec4<bool, aligned_mediump> aligned_mediump_bvec4;
233
235typedef tvec4<bool, aligned_lowp> aligned_lowp_bvec4;
236
237// -- default --
238
239 #if(defined(GLM_PRECISION_LOWP_FLOAT))
240typedef aligned_lowp_vec1 aligned_vec1;
241typedef aligned_lowp_vec2 aligned_vec2;
242typedef aligned_lowp_vec3 aligned_vec3;
243typedef aligned_lowp_vec4 aligned_vec4;
244 #elif(defined(GLM_PRECISION_MEDIUMP_FLOAT))
245typedef aligned_mediump_vec1 aligned_vec1;
246typedef aligned_mediump_vec2 aligned_vec2;
247typedef aligned_mediump_vec3 aligned_vec3;
248typedef aligned_mediump_vec4 aligned_vec4;
249 #else //defined(GLM_PRECISION_HIGHP_FLOAT)
250typedef aligned_highp_vec1 aligned_vec1;
252
254typedef aligned_highp_vec2 aligned_vec2;
255
257typedef aligned_highp_vec3 aligned_vec3;
258
260typedef aligned_highp_vec4 aligned_vec4;
261 #endif//GLM_PRECISION
262
263 #if(defined(GLM_PRECISION_LOWP_DOUBLE))
264typedef aligned_lowp_dvec1 aligned_dvec1;
265typedef aligned_lowp_dvec2 aligned_dvec2;
266typedef aligned_lowp_dvec3 aligned_dvec3;
267typedef aligned_lowp_dvec4 aligned_dvec4;
268 #elif(defined(GLM_PRECISION_MEDIUMP_DOUBLE))
269typedef aligned_mediump_dvec1 aligned_dvec1;
270typedef aligned_mediump_dvec2 aligned_dvec2;
271typedef aligned_mediump_dvec3 aligned_dvec3;
272typedef aligned_mediump_dvec4 aligned_dvec4;
273 #else //defined(GLM_PRECISION_HIGHP_DOUBLE)
274typedef aligned_highp_dvec1 aligned_dvec1;
276
278typedef aligned_highp_dvec2 aligned_dvec2;
279
281typedef aligned_highp_dvec3 aligned_dvec3;
282
284typedef aligned_highp_dvec4 aligned_dvec4;
285 #endif//GLM_PRECISION
286
287 #if(defined(GLM_PRECISION_LOWP_INT))
288typedef aligned_lowp_ivec1 aligned_ivec1;
289typedef aligned_lowp_ivec2 aligned_ivec2;
290typedef aligned_lowp_ivec3 aligned_ivec3;
291typedef aligned_lowp_ivec4 aligned_ivec4;
292 #elif(defined(GLM_PRECISION_MEDIUMP_INT))
293typedef aligned_mediump_ivec1 aligned_ivec1;
294typedef aligned_mediump_ivec2 aligned_ivec2;
295typedef aligned_mediump_ivec3 aligned_ivec3;
296typedef aligned_mediump_ivec4 aligned_ivec4;
297 #else //defined(GLM_PRECISION_HIGHP_INT)
298typedef aligned_highp_ivec1 aligned_ivec1;
300
302typedef aligned_highp_ivec2 aligned_ivec2;
303
305typedef aligned_highp_ivec3 aligned_ivec3;
306
308typedef aligned_highp_ivec4 aligned_ivec4;
309 #endif//GLM_PRECISION
310
311// -- Unsigned integer definition --
312
313 #if(defined(GLM_PRECISION_LOWP_UINT))
314typedef aligned_lowp_uvec1 aligned_uvec1;
315typedef aligned_lowp_uvec2 aligned_uvec2;
316typedef aligned_lowp_uvec3 aligned_uvec3;
317typedef aligned_lowp_uvec4 aligned_uvec4;
318 #elif(defined(GLM_PRECISION_MEDIUMP_UINT))
319typedef aligned_mediump_uvec1 aligned_uvec1;
320typedef aligned_mediump_uvec2 aligned_uvec2;
321typedef aligned_mediump_uvec3 aligned_uvec3;
322typedef aligned_mediump_uvec4 aligned_uvec4;
323 #else //defined(GLM_PRECISION_HIGHP_UINT)
324typedef aligned_highp_uvec1 aligned_uvec1;
326
328typedef aligned_highp_uvec2 aligned_uvec2;
329
331typedef aligned_highp_uvec3 aligned_uvec3;
332
334typedef aligned_highp_uvec4 aligned_uvec4;
335 #endif//GLM_PRECISION
336
337 #if(defined(GLM_PRECISION_LOWP_BOOL))
338typedef aligned_lowp_bvec1 aligned_bvec1;
339typedef aligned_lowp_bvec2 aligned_bvec2;
340typedef aligned_lowp_bvec3 aligned_bvec3;
341typedef aligned_lowp_bvec4 aligned_bvec4;
342 #elif(defined(GLM_PRECISION_MEDIUMP_BOOL))
343typedef aligned_mediump_bvec1 aligned_bvec1;
344typedef aligned_mediump_bvec2 aligned_bvec2;
345typedef aligned_mediump_bvec3 aligned_bvec3;
346typedef aligned_mediump_bvec4 aligned_bvec4;
347 #else //defined(GLM_PRECISION_HIGHP_BOOL)
348typedef aligned_highp_bvec1 aligned_bvec1;
350
352typedef aligned_highp_bvec2 aligned_bvec2;
353
355typedef aligned_highp_bvec3 aligned_bvec3;
356
358typedef aligned_highp_bvec4 aligned_bvec4;
359 #endif//GLM_PRECISION
360
362 }//namespace glm
aligned_highp_bvec2 aligned_bvec2
2 components vector of boolean.
Definition: gtc/type_aligned.hpp:352
tvec2< double, aligned_mediump > aligned_mediump_dvec2
2 components vector of medium double-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:89
tvec4< bool, aligned_highp > aligned_highp_bvec4
4 components vector of high precision bool numbers.
Definition: gtc/type_aligned.hpp:229
tvec3< uint, aligned_highp > aligned_highp_uvec3
3 components vector of high precision unsigned integer numbers.
Definition: gtc/type_aligned.hpp:171
aligned_highp_dvec4 aligned_dvec4
4 components vector of double-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:284
aligned_highp_dvec1 aligned_dvec1
1 component vector of double-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:275
tvec3< int, aligned_lowp > aligned_lowp_ivec3
3 components vector of low precision signed integer numbers.
Definition: gtc/type_aligned.hpp:167
tvec3< double, aligned_mediump > aligned_mediump_dvec3
3 components vector of medium double-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:151
tvec3< float, aligned_lowp > aligned_lowp_vec3
3 components vector of low single-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:143
tvec2< bool, aligned_lowp > aligned_lowp_bvec2
2 components vector of low precision bool numbers.
Definition: gtc/type_aligned.hpp:129
tvec3< uint, aligned_mediump > aligned_mediump_uvec3
3 components vector of medium precision unsigned integer numbers.
Definition: gtc/type_aligned.hpp:175
tvec4< float, aligned_lowp > aligned_lowp_vec4
4 components vector of low single-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:199
Definition: _noise.hpp:11
tvec4< double, aligned_mediump > aligned_mediump_dvec4
4 components vector of medium double-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:205
tvec2< uint, aligned_mediump > aligned_mediump_uvec2
2 components vector of medium precision unsigned integer numbers.
Definition: gtc/type_aligned.hpp:113
tvec2< int, aligned_mediump > aligned_mediump_ivec2
2 components vector of medium precision signed integer numbers.
Definition: gtc/type_aligned.hpp:101
tvec4< uint, aligned_mediump > aligned_mediump_uvec4
4 components vector of medium precision unsigned integer numbers.
Definition: gtc/type_aligned.hpp:223
aligned_highp_bvec4 aligned_bvec4
4 components vector of boolean.
Definition: gtc/type_aligned.hpp:358
tvec2< bool, aligned_highp > aligned_highp_bvec2
2 components vector of high precision bool numbers.
Definition: gtc/type_aligned.hpp:121
aligned_highp_ivec1 aligned_ivec1
1 component vector of signed integer numbers.
Definition: gtc/type_aligned.hpp:299
tvec3< uint, aligned_lowp > aligned_lowp_uvec3
3 components vector of low precision unsigned integer numbers.
Definition: gtc/type_aligned.hpp:179
tvec4< bool, aligned_lowp > aligned_lowp_bvec4
4 components vector of low precision bool numbers.
Definition: gtc/type_aligned.hpp:235
aligned_highp_dvec3 aligned_dvec3
3 components vector of double-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:281
aligned_highp_vec2 aligned_vec2
2 components vector of floating-point numbers.
Definition: gtc/type_aligned.hpp:254
aligned_highp_bvec3 aligned_bvec3
3 components vector of boolean.
Definition: gtc/type_aligned.hpp:355
tvec2< double, aligned_lowp > aligned_lowp_dvec2
2 components vector of low double-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:93
tvec3< double, aligned_highp > aligned_highp_dvec3
3 components vector of high double-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:147
aligned_highp_uvec4 aligned_uvec4
4 components vector of unsigned integer numbers.
Definition: gtc/type_aligned.hpp:334
tvec3< int, aligned_highp > aligned_highp_ivec3
3 components vector of high precision signed integer numbers.
Definition: gtc/type_aligned.hpp:159
tvec4< uint, aligned_highp > aligned_highp_uvec4
4 components vector of high precision unsigned integer numbers.
Definition: gtc/type_aligned.hpp:220
tvec2< uint, aligned_lowp > aligned_lowp_uvec2
2 components vector of low precision unsigned integer numbers.
Definition: gtc/type_aligned.hpp:117
tvec3< int, aligned_mediump > aligned_mediump_ivec3
3 components vector of medium precision signed integer numbers.
Definition: gtc/type_aligned.hpp:163
tvec2< float, aligned_lowp > aligned_lowp_vec2
2 components vector of low single-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:81
aligned_highp_uvec3 aligned_uvec3
3 components vector of unsigned integer numbers.
Definition: gtc/type_aligned.hpp:331
tvec4< float, aligned_highp > aligned_highp_vec4
4 components vector of high single-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:193
tvec4< float, aligned_mediump > aligned_mediump_vec4
4 components vector of medium single-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:196
tvec2< uint, aligned_highp > aligned_highp_uvec2
2 components vector of high precision unsigned integer numbers.
Definition: gtc/type_aligned.hpp:109
tvec3< bool, aligned_lowp > aligned_lowp_bvec3
3 components vector of low precision bool numbers.
Definition: gtc/type_aligned.hpp:188
aligned_highp_bvec1 aligned_bvec1
1 component vector of boolean.
Definition: gtc/type_aligned.hpp:349
tvec3< float, aligned_highp > aligned_highp_vec3
3 components vector of high single-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:135
tvec4< double, aligned_highp > aligned_highp_dvec4
4 components vector of high double-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:202
aligned_highp_uvec1 aligned_uvec1
1 component vector of unsigned integer numbers.
Definition: gtc/type_aligned.hpp:325
tvec2< float, aligned_highp > aligned_highp_vec2
2 components vector of high single-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:73
tvec3< float, aligned_mediump > aligned_mediump_vec3
3 components vector of medium single-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:139
aligned_highp_vec4 aligned_vec4
4 components vector of floating-point numbers.
Definition: gtc/type_aligned.hpp:260
tvec3< bool, aligned_mediump > aligned_mediump_bvec3
3 components vector of medium precision bool numbers.
Definition: gtc/type_aligned.hpp:185
tvec4< bool, aligned_mediump > aligned_mediump_bvec4
4 components vector of medium precision bool numbers.
Definition: gtc/type_aligned.hpp:232
tvec2< float, aligned_mediump > aligned_mediump_vec2
2 components vector of medium single-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:77
aligned_highp_ivec4 aligned_ivec4
4 components vector of signed integer numbers.
Definition: gtc/type_aligned.hpp:308
tvec2< bool, aligned_mediump > aligned_mediump_bvec2
2 components vector of medium precision bool numbers.
Definition: gtc/type_aligned.hpp:125
tvec3< double, aligned_lowp > aligned_lowp_dvec3
3 components vector of low double-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:155
tvec4< uint, aligned_lowp > aligned_lowp_uvec4
4 components vector of low precision unsigned integer numbers.
Definition: gtc/type_aligned.hpp:226
tvec2< int, aligned_highp > aligned_highp_ivec2
2 components vector of high precision signed integer numbers.
Definition: gtc/type_aligned.hpp:97
aligned_highp_dvec2 aligned_dvec2
2 components vector of double-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:278
aligned_highp_uvec2 aligned_uvec2
2 components vector of unsigned integer numbers.
Definition: gtc/type_aligned.hpp:328
tvec4< int, aligned_lowp > aligned_lowp_ivec4
4 components vector of low precision signed integer numbers.
Definition: gtc/type_aligned.hpp:217
tvec2< int, aligned_lowp > aligned_lowp_ivec2
2 components vector of low precision signed integer numbers.
Definition: gtc/type_aligned.hpp:105
aligned_highp_vec1 aligned_vec1
1 component vector of floating-point numbers.
Definition: gtc/type_aligned.hpp:251
tvec4< double, aligned_lowp > aligned_lowp_dvec4
4 components vector of low double-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:208
tvec4< int, aligned_mediump > aligned_mediump_ivec4
4 components vector of medium precision signed integer numbers.
Definition: gtc/type_aligned.hpp:214
tvec3< bool, aligned_highp > aligned_highp_bvec3
3 components vector of high precision bool numbers.
Definition: gtc/type_aligned.hpp:182
aligned_highp_ivec2 aligned_ivec2
2 components vector of signed integer numbers.
Definition: gtc/type_aligned.hpp:302
tvec4< int, aligned_highp > aligned_highp_ivec4
4 components vector of high precision signed integer numbers.
Definition: gtc/type_aligned.hpp:211
aligned_highp_ivec3 aligned_ivec3
3 components vector of signed integer numbers.
Definition: gtc/type_aligned.hpp:305
tvec2< double, aligned_highp > aligned_highp_dvec2
2 components vector of high double-precision floating-point numbers.
Definition: gtc/type_aligned.hpp:85
aligned_highp_vec3 aligned_vec3
3 components vector of floating-point numbers.
Definition: gtc/type_aligned.hpp:257
Generated by 1.8.10