Back to Mame

0.9.8: type_aligned.hpp Source File

3rdparty/glm/doc/api/a00108_source.html

latest35.1 KB
Original Source

| | 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

glm::aligned_bvec2

aligned_highp_bvec2 aligned_bvec2

2 components vector of boolean.

Definition: gtc/type_aligned.hpp:352

glm::aligned_mediump_dvec2

tvec2< double, aligned_mediump > aligned_mediump_dvec2

2 components vector of medium double-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:89

glm::aligned_highp_bvec4

tvec4< bool, aligned_highp > aligned_highp_bvec4

4 components vector of high precision bool numbers.

Definition: gtc/type_aligned.hpp:229

glm::aligned_highp_uvec3

tvec3< uint, aligned_highp > aligned_highp_uvec3

3 components vector of high precision unsigned integer numbers.

Definition: gtc/type_aligned.hpp:171

glm::aligned_dvec4

aligned_highp_dvec4 aligned_dvec4

4 components vector of double-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:284

glm::aligned_dvec1

aligned_highp_dvec1 aligned_dvec1

1 component vector of double-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:275

glm::aligned_lowp_ivec3

tvec3< int, aligned_lowp > aligned_lowp_ivec3

3 components vector of low precision signed integer numbers.

Definition: gtc/type_aligned.hpp:167

glm::aligned_mediump_dvec3

tvec3< double, aligned_mediump > aligned_mediump_dvec3

3 components vector of medium double-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:151

glm::aligned_lowp_vec3

tvec3< float, aligned_lowp > aligned_lowp_vec3

3 components vector of low single-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:143

glm::aligned_lowp_bvec2

tvec2< bool, aligned_lowp > aligned_lowp_bvec2

2 components vector of low precision bool numbers.

Definition: gtc/type_aligned.hpp:129

glm::aligned_mediump_uvec3

tvec3< uint, aligned_mediump > aligned_mediump_uvec3

3 components vector of medium precision unsigned integer numbers.

Definition: gtc/type_aligned.hpp:175

glm::aligned_lowp_vec4

tvec4< float, aligned_lowp > aligned_lowp_vec4

4 components vector of low single-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:199

glm

Definition: _noise.hpp:11

glm::aligned_mediump_dvec4

tvec4< double, aligned_mediump > aligned_mediump_dvec4

4 components vector of medium double-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:205

glm::aligned_mediump_uvec2

tvec2< uint, aligned_mediump > aligned_mediump_uvec2

2 components vector of medium precision unsigned integer numbers.

Definition: gtc/type_aligned.hpp:113

glm::aligned_mediump_ivec2

tvec2< int, aligned_mediump > aligned_mediump_ivec2

2 components vector of medium precision signed integer numbers.

Definition: gtc/type_aligned.hpp:101

glm::aligned_mediump_uvec4

tvec4< uint, aligned_mediump > aligned_mediump_uvec4

4 components vector of medium precision unsigned integer numbers.

Definition: gtc/type_aligned.hpp:223

glm::aligned_bvec4

aligned_highp_bvec4 aligned_bvec4

4 components vector of boolean.

Definition: gtc/type_aligned.hpp:358

glm::aligned_highp_bvec2

tvec2< bool, aligned_highp > aligned_highp_bvec2

2 components vector of high precision bool numbers.

Definition: gtc/type_aligned.hpp:121

glm::aligned_ivec1

aligned_highp_ivec1 aligned_ivec1

1 component vector of signed integer numbers.

Definition: gtc/type_aligned.hpp:299

glm::aligned_lowp_uvec3

tvec3< uint, aligned_lowp > aligned_lowp_uvec3

3 components vector of low precision unsigned integer numbers.

Definition: gtc/type_aligned.hpp:179

glm::aligned_lowp_bvec4

tvec4< bool, aligned_lowp > aligned_lowp_bvec4

4 components vector of low precision bool numbers.

Definition: gtc/type_aligned.hpp:235

glm::aligned_dvec3

aligned_highp_dvec3 aligned_dvec3

3 components vector of double-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:281

glm::aligned_vec2

aligned_highp_vec2 aligned_vec2

2 components vector of floating-point numbers.

Definition: gtc/type_aligned.hpp:254

glm::aligned_bvec3

aligned_highp_bvec3 aligned_bvec3

3 components vector of boolean.

Definition: gtc/type_aligned.hpp:355

glm::aligned_lowp_dvec2

tvec2< double, aligned_lowp > aligned_lowp_dvec2

2 components vector of low double-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:93

glm::aligned_highp_dvec3

tvec3< double, aligned_highp > aligned_highp_dvec3

3 components vector of high double-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:147

glm::aligned_uvec4

aligned_highp_uvec4 aligned_uvec4

4 components vector of unsigned integer numbers.

Definition: gtc/type_aligned.hpp:334

glm::aligned_highp_ivec3

tvec3< int, aligned_highp > aligned_highp_ivec3

3 components vector of high precision signed integer numbers.

Definition: gtc/type_aligned.hpp:159

glm::aligned_highp_uvec4

tvec4< uint, aligned_highp > aligned_highp_uvec4

4 components vector of high precision unsigned integer numbers.

Definition: gtc/type_aligned.hpp:220

glm::aligned_lowp_uvec2

tvec2< uint, aligned_lowp > aligned_lowp_uvec2

2 components vector of low precision unsigned integer numbers.

Definition: gtc/type_aligned.hpp:117

glm::aligned_mediump_ivec3

tvec3< int, aligned_mediump > aligned_mediump_ivec3

3 components vector of medium precision signed integer numbers.

Definition: gtc/type_aligned.hpp:163

glm::aligned_lowp_vec2

tvec2< float, aligned_lowp > aligned_lowp_vec2

2 components vector of low single-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:81

glm::aligned_uvec3

aligned_highp_uvec3 aligned_uvec3

3 components vector of unsigned integer numbers.

Definition: gtc/type_aligned.hpp:331

glm::aligned_highp_vec4

tvec4< float, aligned_highp > aligned_highp_vec4

4 components vector of high single-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:193

glm::aligned_mediump_vec4

tvec4< float, aligned_mediump > aligned_mediump_vec4

4 components vector of medium single-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:196

glm::aligned_highp_uvec2

tvec2< uint, aligned_highp > aligned_highp_uvec2

2 components vector of high precision unsigned integer numbers.

Definition: gtc/type_aligned.hpp:109

glm::aligned_lowp_bvec3

tvec3< bool, aligned_lowp > aligned_lowp_bvec3

3 components vector of low precision bool numbers.

Definition: gtc/type_aligned.hpp:188

glm::aligned_bvec1

aligned_highp_bvec1 aligned_bvec1

1 component vector of boolean.

Definition: gtc/type_aligned.hpp:349

glm::aligned_highp_vec3

tvec3< float, aligned_highp > aligned_highp_vec3

3 components vector of high single-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:135

glm::aligned_highp_dvec4

tvec4< double, aligned_highp > aligned_highp_dvec4

4 components vector of high double-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:202

glm::aligned_uvec1

aligned_highp_uvec1 aligned_uvec1

1 component vector of unsigned integer numbers.

Definition: gtc/type_aligned.hpp:325

glm::aligned_highp_vec2

tvec2< float, aligned_highp > aligned_highp_vec2

2 components vector of high single-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:73

glm::aligned_mediump_vec3

tvec3< float, aligned_mediump > aligned_mediump_vec3

3 components vector of medium single-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:139

glm::aligned_vec4

aligned_highp_vec4 aligned_vec4

4 components vector of floating-point numbers.

Definition: gtc/type_aligned.hpp:260

glm::aligned_mediump_bvec3

tvec3< bool, aligned_mediump > aligned_mediump_bvec3

3 components vector of medium precision bool numbers.

Definition: gtc/type_aligned.hpp:185

glm::aligned_mediump_bvec4

tvec4< bool, aligned_mediump > aligned_mediump_bvec4

4 components vector of medium precision bool numbers.

Definition: gtc/type_aligned.hpp:232

glm::aligned_mediump_vec2

tvec2< float, aligned_mediump > aligned_mediump_vec2

2 components vector of medium single-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:77

glm::aligned_ivec4

aligned_highp_ivec4 aligned_ivec4

4 components vector of signed integer numbers.

Definition: gtc/type_aligned.hpp:308

glm::aligned_mediump_bvec2

tvec2< bool, aligned_mediump > aligned_mediump_bvec2

2 components vector of medium precision bool numbers.

Definition: gtc/type_aligned.hpp:125

glm::aligned_lowp_dvec3

tvec3< double, aligned_lowp > aligned_lowp_dvec3

3 components vector of low double-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:155

glm::aligned_lowp_uvec4

tvec4< uint, aligned_lowp > aligned_lowp_uvec4

4 components vector of low precision unsigned integer numbers.

Definition: gtc/type_aligned.hpp:226

glm::aligned_highp_ivec2

tvec2< int, aligned_highp > aligned_highp_ivec2

2 components vector of high precision signed integer numbers.

Definition: gtc/type_aligned.hpp:97

glm::aligned_dvec2

aligned_highp_dvec2 aligned_dvec2

2 components vector of double-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:278

glm::aligned_uvec2

aligned_highp_uvec2 aligned_uvec2

2 components vector of unsigned integer numbers.

Definition: gtc/type_aligned.hpp:328

glm::aligned_lowp_ivec4

tvec4< int, aligned_lowp > aligned_lowp_ivec4

4 components vector of low precision signed integer numbers.

Definition: gtc/type_aligned.hpp:217

glm::aligned_lowp_ivec2

tvec2< int, aligned_lowp > aligned_lowp_ivec2

2 components vector of low precision signed integer numbers.

Definition: gtc/type_aligned.hpp:105

glm::aligned_vec1

aligned_highp_vec1 aligned_vec1

1 component vector of floating-point numbers.

Definition: gtc/type_aligned.hpp:251

glm::aligned_lowp_dvec4

tvec4< double, aligned_lowp > aligned_lowp_dvec4

4 components vector of low double-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:208

glm::aligned_mediump_ivec4

tvec4< int, aligned_mediump > aligned_mediump_ivec4

4 components vector of medium precision signed integer numbers.

Definition: gtc/type_aligned.hpp:214

glm::aligned_highp_bvec3

tvec3< bool, aligned_highp > aligned_highp_bvec3

3 components vector of high precision bool numbers.

Definition: gtc/type_aligned.hpp:182

glm::aligned_ivec2

aligned_highp_ivec2 aligned_ivec2

2 components vector of signed integer numbers.

Definition: gtc/type_aligned.hpp:302

glm::aligned_highp_ivec4

tvec4< int, aligned_highp > aligned_highp_ivec4

4 components vector of high precision signed integer numbers.

Definition: gtc/type_aligned.hpp:211

glm::aligned_ivec3

aligned_highp_ivec3 aligned_ivec3

3 components vector of signed integer numbers.

Definition: gtc/type_aligned.hpp:305

glm::aligned_highp_dvec2

tvec2< double, aligned_highp > aligned_highp_dvec2

2 components vector of high double-precision floating-point numbers.

Definition: gtc/type_aligned.hpp:85

glm::aligned_vec3

aligned_highp_vec3 aligned_vec3

3 components vector of floating-point numbers.

Definition: gtc/type_aligned.hpp:257


Generated by 1.8.10